Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(9)

Side by Side Diff: net/quic/crypto/quic_random.h

Issue 11476031: Add the QuicRandom interface with a default implementation that is (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef NET_QUIC_CRYPTO_QUIC_RANDOM_H_
6 #define NET_QUIC_CRYPTO_QUIC_RANDOM_H_
7
8 #include <stddef.h>
9
10 #include "base/basictypes.h"
11
12 namespace net {
13
14 // The interface for a random number generator.
15 class QuicRandom {
16 public:
17 virtual ~QuicRandom() {}
18
19 // Returns the default random number generator, which is cryptographically
20 // secure and thread-safe.
21 static QuicRandom* GetInstance();
22
23 // Generates |len| random bytes in the |data| buffer.
24 virtual void RandBytes(void* data, size_t len) = 0;
25
26 // Returns a random number in the range [0, kuint64max].
27 virtual uint64 RandUint64() = 0;
28
29 // Reseeds the random number generator with additional entropy input.
30 // NOTE: the constructor of a QuicRandom object is responsible for seeding
31 // itself with enough entropy input.
32 virtual void Reseed(const void* additional_entropy, size_t entropy_len) = 0;
33 };
34
35 } // namespace net
36
37 #endif // NET_QUIC_CRYPTO_QUIC_RANDOM_H_
OLDNEW
« net/net.gyp ('K') | « net/net.gyp ('k') | net/quic/crypto/quic_random.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698