OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ | 5 #ifndef CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ |
6 #define CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ | 6 #define CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/crypto/symmetric_key.h" | |
12 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 12 #include "crypto/symmetric_key.h" |
13 | 13 |
14 namespace browser_sync { | 14 namespace browser_sync { |
15 | 15 |
16 // A (partial) implementation of Nigori, a protocol to securely store secrets in | 16 // A (partial) implementation of Nigori, a protocol to securely store secrets in |
17 // the cloud. This implementation does not support server authentication or | 17 // the cloud. This implementation does not support server authentication or |
18 // assisted key derivation. | 18 // assisted key derivation. |
19 // | 19 // |
20 // To store secrets securely, use the |Permute| method to derive a lookup name | 20 // To store secrets securely, use the |Permute| method to derive a lookup name |
21 // for your secret (basically a map key), and |Encrypt| and |Decrypt| to store | 21 // for your secret (basically a map key), and |Encrypt| and |Decrypt| to store |
22 // and retrieve the secret. | 22 // and retrieve the secret. |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
66 static const size_t kDerivedKeySizeInBits = 128; | 66 static const size_t kDerivedKeySizeInBits = 128; |
67 static const size_t kIvSize = 16; | 67 static const size_t kIvSize = 16; |
68 static const size_t kHashSize = 32; | 68 static const size_t kHashSize = 32; |
69 | 69 |
70 static const size_t kSaltIterations = 1001; | 70 static const size_t kSaltIterations = 1001; |
71 static const size_t kUserIterations = 1002; | 71 static const size_t kUserIterations = 1002; |
72 static const size_t kEncryptionIterations = 1003; | 72 static const size_t kEncryptionIterations = 1003; |
73 static const size_t kSigningIterations = 1004; | 73 static const size_t kSigningIterations = 1004; |
74 | 74 |
75 private: | 75 private: |
76 scoped_ptr<base::SymmetricKey> user_key_; | 76 scoped_ptr<crypto::SymmetricKey> user_key_; |
77 scoped_ptr<base::SymmetricKey> encryption_key_; | 77 scoped_ptr<crypto::SymmetricKey> encryption_key_; |
78 scoped_ptr<base::SymmetricKey> mac_key_; | 78 scoped_ptr<crypto::SymmetricKey> mac_key_; |
79 }; | 79 }; |
80 | 80 |
81 } // namespace browser_sync | 81 } // namespace browser_sync |
82 | 82 |
83 #endif // CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ | 83 #endif // CHROME_BROWSER_SYNC_UTIL_NIGORI_H_ |
OLD | NEW |