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 CRYPTO_SECURE_HASH_H_ | 5 #ifndef CRYPTO_SECURE_HASH_H_ |
6 #define CRYPTO_SECURE_HASH_H_ | 6 #define CRYPTO_SECURE_HASH_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include "base/basictypes.h" | 9 #include "base/basictypes.h" |
10 #include "crypto/crypto_export.h" | 10 #include "crypto/crypto_export.h" |
11 | 11 |
| 12 class Pickle; |
| 13 |
12 namespace crypto { | 14 namespace crypto { |
13 | 15 |
14 // A wrapper to calculate secure hashes incrementally, allowing to | 16 // A wrapper to calculate secure hashes incrementally, allowing to |
15 // be used when the full input is not known in advance. | 17 // be used when the full input is not known in advance. |
16 class CRYPTO_EXPORT SecureHash { | 18 class CRYPTO_EXPORT SecureHash { |
17 public: | 19 public: |
18 enum Algorithm { | 20 enum Algorithm { |
19 SHA256, | 21 SHA256, |
20 }; | 22 }; |
21 virtual ~SecureHash() {} | 23 virtual ~SecureHash() {} |
22 | 24 |
23 static SecureHash* Create(Algorithm type); | 25 static SecureHash* Create(Algorithm type); |
24 | 26 |
25 virtual void Update(const void* input, size_t len) = 0; | 27 virtual void Update(const void* input, size_t len) = 0; |
26 virtual void Finish(void* output, size_t len) = 0; | 28 virtual void Finish(void* output, size_t len) = 0; |
27 | 29 |
| 30 // Serialize the context, so it can be restored at a later time. |
| 31 // |pickle| will contain the serialized data. |
| 32 // Returns whether or not |pickle| was filled. |
| 33 virtual bool Serialize(Pickle* pickle) = 0; |
| 34 |
| 35 // Restore the context that was saved earlier. |
| 36 // |data_iterator| allows this to be used as part of a larger pickle. |
| 37 // |pickle| holds the saved data. |
| 38 // Returns success or failure. |
| 39 virtual bool Deserialize(void** data_iterator, Pickle* pickle) = 0; |
| 40 |
28 protected: | 41 protected: |
29 SecureHash() {} | 42 SecureHash() {} |
30 | 43 |
31 private: | 44 private: |
32 DISALLOW_COPY_AND_ASSIGN(SecureHash); | 45 DISALLOW_COPY_AND_ASSIGN(SecureHash); |
33 }; | 46 }; |
34 | 47 |
35 } // namespace crypto | 48 } // namespace crypto |
36 | 49 |
37 #endif // CRYPTO_SECURE_HASH_H_ | 50 #endif // CRYPTO_SECURE_HASH_H_ |
OLD | NEW |