|  | // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #ifndef QUICHE_QUIC_CORE_CRYPTO_QUIC_RANDOM_H_ | 
|  | #define QUICHE_QUIC_CORE_CRYPTO_QUIC_RANDOM_H_ | 
|  |  | 
|  | #include <cstddef> | 
|  | #include <cstdint> | 
|  |  | 
|  | #include "quic/platform/api/quic_export.h" | 
|  |  | 
|  | namespace quic { | 
|  |  | 
|  | // The interface for a random number generator. | 
|  | class QUIC_EXPORT_PRIVATE QuicRandom { | 
|  | public: | 
|  | virtual ~QuicRandom() {} | 
|  |  | 
|  | // Returns the default random number generator, which is cryptographically | 
|  | // secure and thread-safe. | 
|  | static QuicRandom* GetInstance(); | 
|  |  | 
|  | // Generates |len| random bytes in the |data| buffer. | 
|  | virtual void RandBytes(void* data, size_t len) = 0; | 
|  |  | 
|  | // Returns a random number in the range [0, kuint64max]. | 
|  | virtual uint64_t RandUint64() = 0; | 
|  |  | 
|  | // Generates |len| random bytes in the |data| buffer. This MUST NOT be used | 
|  | // for any application that requires cryptographically-secure randomness. | 
|  | virtual void InsecureRandBytes(void* data, size_t len) = 0; | 
|  |  | 
|  | // Returns a random number in the range [0, kuint64max]. This MUST NOT be used | 
|  | // for any application that requires cryptographically-secure randomness. | 
|  | virtual uint64_t InsecureRandUint64() = 0; | 
|  | }; | 
|  |  | 
|  | }  // namespace quic | 
|  |  | 
|  | #endif  // QUICHE_QUIC_CORE_CRYPTO_QUIC_RANDOM_H_ |