| /* | 
 |  *  Copyright 2004 The WebRTC Project Authors. All rights reserved. | 
 |  * | 
 |  *  Use of this source code is governed by a BSD-style license | 
 |  *  that can be found in the LICENSE file in the root of the source | 
 |  *  tree. An additional intellectual property rights grant can be found | 
 |  *  in the file PATENTS.  All contributing project authors may | 
 |  *  be found in the AUTHORS file in the root of the source tree. | 
 |  */ | 
 |  | 
 | #ifndef RTC_BASE_CRYPTO_RANDOM_H_ | 
 | #define RTC_BASE_CRYPTO_RANDOM_H_ | 
 |  | 
 | #include <stddef.h> | 
 | #include <stdint.h> | 
 |  | 
 | #include <memory> | 
 | #include <string> | 
 |  | 
 | #include "absl/strings/string_view.h" | 
 | #include "rtc_base/system/rtc_export.h" | 
 |  | 
 | namespace webrtc { | 
 |  | 
 | // Interface for RNG implementations. | 
 | class RandomGenerator { | 
 |  public: | 
 |   virtual ~RandomGenerator() = default; | 
 |   [[deprecated]] virtual bool Init(const void* seed, size_t len) { | 
 |     return true; | 
 |   } | 
 |   virtual bool Generate(void* buf, size_t len) = 0; | 
 | }; | 
 |  | 
 | // Sets the default random generator as the source of randomness. The default | 
 | // source uses the OpenSSL RNG and provides cryptographically secure randomness. | 
 | void SetDefaultRandomGenerator(); | 
 |  | 
 | // Set a custom random generator. Results produced by CreateRandomXyz | 
 | // are cryptographically random iff the output of the supplied generator is | 
 | // cryptographically random. | 
 | void SetRandomGenerator(std::unique_ptr<RandomGenerator> generator); | 
 |  | 
 | // For testing, we can return predictable data. | 
 | void SetRandomTestMode(bool test); | 
 |  | 
 | // Initializes the RNG, and seeds it with the specified entropy. | 
 | [[deprecated]] bool InitRandom(int seed); | 
 | [[deprecated]] bool InitRandom(const char* seed, size_t len); | 
 |  | 
 | // Generates a (cryptographically) random string of the given length. | 
 | // We generate base64 values so that they will be printable. | 
 | RTC_EXPORT std::string CreateRandomString(size_t length); | 
 |  | 
 | // Generates a (cryptographically) random string of the given length. | 
 | // We generate base64 values so that they will be printable. | 
 | // Return false if the random number generator failed. | 
 | RTC_EXPORT bool CreateRandomString(size_t length, std::string* str); | 
 |  | 
 | // Generates a (cryptographically) random string of the given length, | 
 | // with characters from the given table. Return false if the random | 
 | // number generator failed. | 
 | // For ease of implementation, the function requires that the table | 
 | // size evenly divide 256; otherwise, it returns false. | 
 | RTC_EXPORT bool CreateRandomString(size_t length, | 
 |                                    absl::string_view table, | 
 |                                    std::string* str); | 
 |  | 
 | // Generates (cryptographically) random data of the given length. | 
 | // Return false if the random number generator failed. | 
 | bool CreateRandomData(size_t length, std::string* data); | 
 |  | 
 | // Generates a (cryptographically) random UUID version 4 string. | 
 | std::string CreateRandomUuid(); | 
 |  | 
 | // Generates a random id. | 
 | uint32_t CreateRandomId(); | 
 |  | 
 | // Generates a 64 bit random id. | 
 | RTC_EXPORT uint64_t CreateRandomId64(); | 
 |  | 
 | // Generates a random id > 0. | 
 | uint32_t CreateRandomNonZeroId(); | 
 |  | 
 | // Generates a random double between 0.0 (inclusive) and 1.0 (exclusive). | 
 | double CreateRandomDouble(); | 
 |  | 
 | }  //  namespace webrtc | 
 |  | 
 |  | 
 | #endif  // RTC_BASE_CRYPTO_RANDOM_H_ |