Chromium Code Reviews| Index: base/nonce.cc |
| diff --git a/base/nonce.cc b/base/nonce.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..cf43a4d635e09161384ac41d6ce7390d7650828f |
| --- /dev/null |
| +++ b/base/nonce.cc |
| @@ -0,0 +1,44 @@ |
| +// Copyright 2016 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. |
| + |
| +#include "base/nonce.h" |
| + |
| +#include "base/format_macros.h" |
| +#include "base/rand_util.h" |
| +#include "base/strings/stringprintf.h" |
| + |
| +namespace base { |
| + |
| +// If base::Nonce is no longer 128 bits, the IPC serialization logic and Mojo |
| +// StructTraits should be updated to match the size of the struct. |
| +static_assert(sizeof(Nonce) == 2 * sizeof(uint64_t), |
| + "base::Nonce should be of size 2 * sizeof(uint64_t)."); |
| + |
| +Nonce::Nonce() : high_(0), low_(0) {} |
| + |
| +Nonce::Nonce(uint64_t high, uint64_t low) : high_(high), low_(low) {} |
| + |
| +std::string Nonce::ToString() const { |
| + return base::StringPrintf("(%" PRIu64 ":%" PRIu64 ")", high_, low_); |
| +} |
| + |
| +// static |
| +Nonce Nonce::Generate() { |
| + Nonce nonce; |
| + // Use base::RandBytes instead of crypto::RandBytes, because crypto calls the |
| + // base version directly, and to prevent the dependency from base/ to crypto/. |
| + base::RandBytes(&nonce, sizeof(nonce)); |
| + return nonce; |
| +} |
| + |
| +// static |
| +Nonce Nonce::Deserialize(uint64_t high, uint64_t low) { |
| + // Make sure we are not trying to deserialize an empty nonce. |
| + // Sending an empty nonce accross processes likely means that |
|
watk
2016/09/15 18:46:10
across
tguilbert
2016/09/15 22:57:39
Done.
|
| + // Nonce::Generate() was never called, which points to a security hole. |
| + CHECK((high | low)); |
|
danakj
2016/09/15 18:06:36
DCHECK?
tguilbert
2016/09/15 22:57:39
I think this CHECK is important. There is no case
|
| + return Nonce(high, low); |
| +} |
| + |
| +} // namespace base |