xref: /aosp_15_r20/external/cronet/crypto/sha2.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2012 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #ifndef CRYPTO_SHA2_H_
6*6777b538SAndroid Build Coastguard Worker #define CRYPTO_SHA2_H_
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #include <stddef.h>
9*6777b538SAndroid Build Coastguard Worker 
10*6777b538SAndroid Build Coastguard Worker #include <array>
11*6777b538SAndroid Build Coastguard Worker #include <string>
12*6777b538SAndroid Build Coastguard Worker #include <string_view>
13*6777b538SAndroid Build Coastguard Worker 
14*6777b538SAndroid Build Coastguard Worker #include "base/containers/span.h"
15*6777b538SAndroid Build Coastguard Worker #include "crypto/crypto_export.h"
16*6777b538SAndroid Build Coastguard Worker 
17*6777b538SAndroid Build Coastguard Worker namespace crypto {
18*6777b538SAndroid Build Coastguard Worker 
19*6777b538SAndroid Build Coastguard Worker // These functions perform SHA-256 operations.
20*6777b538SAndroid Build Coastguard Worker //
21*6777b538SAndroid Build Coastguard Worker // Functions for SHA-384 and SHA-512 can be added when the need arises.
22*6777b538SAndroid Build Coastguard Worker 
23*6777b538SAndroid Build Coastguard Worker static const size_t kSHA256Length = 32;  // Length in bytes of a SHA-256 hash.
24*6777b538SAndroid Build Coastguard Worker 
25*6777b538SAndroid Build Coastguard Worker // Computes the SHA-256 hash of |input|.
26*6777b538SAndroid Build Coastguard Worker CRYPTO_EXPORT std::array<uint8_t, kSHA256Length> SHA256Hash(
27*6777b538SAndroid Build Coastguard Worker     base::span<const uint8_t> input);
28*6777b538SAndroid Build Coastguard Worker 
29*6777b538SAndroid Build Coastguard Worker // Convenience version of the above that returns the result in a 32-byte
30*6777b538SAndroid Build Coastguard Worker // string.
31*6777b538SAndroid Build Coastguard Worker CRYPTO_EXPORT std::string SHA256HashString(std::string_view str);
32*6777b538SAndroid Build Coastguard Worker 
33*6777b538SAndroid Build Coastguard Worker // Computes the SHA-256 hash of the input string 'str' and stores the first
34*6777b538SAndroid Build Coastguard Worker // 'len' bytes of the hash in the output buffer 'output'.  If 'len' > 32,
35*6777b538SAndroid Build Coastguard Worker // only 32 bytes (the full hash) are stored in the 'output' buffer.
36*6777b538SAndroid Build Coastguard Worker CRYPTO_EXPORT void SHA256HashString(std::string_view str,
37*6777b538SAndroid Build Coastguard Worker                                     void* output,
38*6777b538SAndroid Build Coastguard Worker                                     size_t len);
39*6777b538SAndroid Build Coastguard Worker 
40*6777b538SAndroid Build Coastguard Worker }  // namespace crypto
41*6777b538SAndroid Build Coastguard Worker 
42*6777b538SAndroid Build Coastguard Worker #endif  // CRYPTO_SHA2_H_
43