Chromium Code Reviews| 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 |