Index: net/quic/crypto/quic_random.h |
=================================================================== |
--- net/quic/crypto/quic_random.h (revision 0) |
+++ net/quic/crypto/quic_random.h (revision 0) |
@@ -0,0 +1,38 @@ |
+// 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 NET_QUIC_CRYPTO_QUIC_RANDOM_H_ |
+#define NET_QUIC_CRYPTO_QUIC_RANDOM_H_ |
+ |
+#include <stddef.h> |
+ |
+#include "base/basictypes.h" |
+#include "net/base/net_export.h" |
+ |
+namespace net { |
+ |
+// The interface for a random number generator. |
+class NET_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 RandUint64() = 0; |
+ |
+ // Reseeds the random number generator with additional entropy input. |
+ // NOTE: the constructor of a QuicRandom object is responsible for seeding |
+ // itself with enough entropy input. |
+ virtual void Reseed(const void* additional_entropy, size_t entropy_len) = 0; |
+}; |
+ |
+} // namespace net |
+ |
+#endif // NET_QUIC_CRYPTO_QUIC_RANDOM_H_ |
Property changes on: net/quic/crypto/quic_random.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |