henrike@webrtc.org | f048872 | 2014-05-13 18:00:26 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license |
| 5 | * that can be found in the LICENSE file in the root of the source |
| 6 | * tree. An additional intellectual property rights grant can be found |
| 7 | * in the file PATENTS. All contributing project authors may |
| 8 | * be found in the AUTHORS file in the root of the source tree. |
| 9 | */ |
| 10 | |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 11 | #ifndef RTC_BASE_OPENSSL_DIGEST_H_ |
| 12 | #define RTC_BASE_OPENSSL_DIGEST_H_ |
henrike@webrtc.org | f048872 | 2014-05-13 18:00:26 | [diff] [blame] | 13 | |
Sergey Sablin | 3c119fb | 2019-02-13 02:30:45 | [diff] [blame] | 14 | #include <openssl/ossl_typ.h> |
Yves Gerey | 988cc08 | 2018-10-23 10:03:01 | [diff] [blame] | 15 | #include <stddef.h> |
Jonas Olsson | a4d8737 | 2019-07-05 17:08:33 | [diff] [blame] | 16 | |
Yves Gerey | 2e00abc | 2018-10-05 13:39:24 | [diff] [blame] | 17 | #include <string> |
henrike@webrtc.org | f048872 | 2014-05-13 18:00:26 | [diff] [blame] | 18 | |
Ali Tofigh | 7fa9057 | 2022-03-17 14:47:49 | [diff] [blame] | 19 | #include "absl/strings/string_view.h" |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 20 | #include "rtc_base/message_digest.h" |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 21 | |
| 22 | namespace rtc { |
| 23 | |
| 24 | // An implementation of the digest class that uses OpenSSL. |
Benjamin Wright | 61c5cc8 | 2018-10-27 00:50:00 | [diff] [blame] | 25 | class OpenSSLDigest final : public MessageDigest { |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 26 | public: |
Artem Titov | 96e3b99 | 2021-07-26 14:03:14 | [diff] [blame] | 27 | // Creates an OpenSSLDigest with `algorithm` as the hash algorithm. |
Ali Tofigh | 7fa9057 | 2022-03-17 14:47:49 | [diff] [blame] | 28 | explicit OpenSSLDigest(absl::string_view algorithm); |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 29 | ~OpenSSLDigest() override; |
| 30 | // Returns the digest output size (e.g. 16 bytes for MD5). |
| 31 | size_t Size() const override; |
Artem Titov | 96e3b99 | 2021-07-26 14:03:14 | [diff] [blame] | 32 | // Updates the digest with `len` bytes from `buf`. |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 33 | void Update(const void* buf, size_t len) override; |
Artem Titov | 96e3b99 | 2021-07-26 14:03:14 | [diff] [blame] | 34 | // Outputs the digest value to `buf` with length `len`. |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 35 | size_t Finish(void* buf, size_t len) override; |
| 36 | |
| 37 | // Helper function to look up a digest's EVP by name. |
Ali Tofigh | 7fa9057 | 2022-03-17 14:47:49 | [diff] [blame] | 38 | static bool GetDigestEVP(absl::string_view algorithm, const EVP_MD** md); |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 39 | // Helper function to look up a digest's name by EVP. |
Yves Gerey | 665174f | 2018-06-19 13:03:05 | [diff] [blame] | 40 | static bool GetDigestName(const EVP_MD* md, std::string* algorithm); |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 41 | // Helper function to get the length of a digest. |
Ali Tofigh | 7fa9057 | 2022-03-17 14:47:49 | [diff] [blame] | 42 | static bool GetDigestSize(absl::string_view algorithm, size_t* len); |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 43 | |
| 44 | private: |
Jiawei Ou | eb0df08 | 2018-02-02 22:51:18 | [diff] [blame] | 45 | EVP_MD_CTX* ctx_ = nullptr; |
Henrik Kjellander | ec78f1c | 2017-06-29 05:52:50 | [diff] [blame] | 46 | const EVP_MD* md_; |
| 47 | }; |
| 48 | |
| 49 | } // namespace rtc |
henrike@webrtc.org | f048872 | 2014-05-13 18:00:26 | [diff] [blame] | 50 | |
Steve Anton | 10542f2 | 2019-01-11 17:11:00 | [diff] [blame] | 51 | #endif // RTC_BASE_OPENSSL_DIGEST_H_ |