OLD | NEW |
---|---|
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 BASE_SHA2_H_ | 5 #ifndef BASE_SHA2_H_ |
6 #define BASE_SHA2_H_ | 6 #define BASE_SHA2_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/basictypes.h" | |
12 | |
11 namespace base { | 13 namespace base { |
12 | 14 |
13 // These functions perform SHA-256 operations. | 15 // These functions perform SHA-256 operations. |
14 // | 16 // |
15 // Functions for SHA-384 and SHA-512 can be added when the need arises. | 17 // Functions for SHA-384 and SHA-512 can be added when the need arises. |
16 | 18 |
17 enum { | 19 enum { |
18 SHA256_LENGTH = 32 // length in bytes of a SHA-256 hash | 20 SHA256_LENGTH = 32 // length in bytes of a SHA-256 hash |
19 }; | 21 }; |
20 | 22 |
21 // Computes the SHA-256 hash of the input string 'str' and stores the first | 23 // Computes the SHA-256 hash of the input string 'str' and stores the first |
22 // 'len' bytes of the hash in the output buffer 'output'. If 'len' > 32, | 24 // 'len' bytes of the hash in the output buffer 'output'. If 'len' > 32, |
23 // only 32 bytes (the full hash) are stored in the 'output' buffer. | 25 // only 32 bytes (the full hash) are stored in the 'output' buffer. |
24 void SHA256HashString(const std::string& str, void* output, size_t len); | 26 void SHA256HashString(const std::string& str, void* output, size_t len); |
25 | 27 |
26 // Convenience version of the above that returns the result in a 32-byte | 28 // Convenience version of the above that returns the result in a 32-byte |
27 // string. | 29 // string. |
28 std::string SHA256HashString(const std::string& str); | 30 std::string SHA256HashString(const std::string& str); |
29 | 31 |
32 // A wrapper for calculating SHA256 when the full string is not known in | |
33 // advance. | |
34 class SHA256Context { | |
wtc
2011/01/21 22:48:51
Please name this class SHA256Hash or SHA256. (I a
bulach
2011/01/24 20:54:33
I liked this idea, seems more flexible.
I extracte
| |
35 public: | |
36 virtual ~SHA256Context() {} | |
37 | |
38 static SHA256Context* Create(); | |
39 | |
40 virtual void Update(const std::string& str) = 0; | |
41 virtual void Finish(void* output, size_t len) = 0; | |
wtc
2011/01/21 22:48:51
This method should be named Final.
bulach
2011/01/24 20:54:33
done, in the new files.
| |
42 | |
43 protected: | |
44 SHA256Context() {} | |
45 | |
46 private: | |
47 DISALLOW_COPY_AND_ASSIGN(SHA256Context); | |
48 }; | |
49 | |
30 } // namespace base | 50 } // namespace base |
31 | 51 |
32 #endif // BASE_SHA2_H_ | 52 #endif // BASE_SHA2_H_ |
OLD | NEW |