Remove special MD5 / SHA-1 digest classes.
Previous users have switched to the generic MessageDigest class in
https://webrtc-review.googlesource.com/35040
Bug: webrtc:8677
Change-Id: Id58d5a02e04f53d256a41a98ead37e1844479a17
Reviewed-on: https://webrtc-review.googlesource.com/55061
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Commit-Queue: Joachim Bauch <jbauch@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#22101}
diff --git a/rtc_base/BUILD.gn b/rtc_base/BUILD.gn
index 6e01caa..117c98c 100644
--- a/rtc_base/BUILD.gn
+++ b/rtc_base/BUILD.gn
@@ -841,8 +841,6 @@
"httpbase.h",
"httpserver.cc",
"httpserver.h",
- "md5digest.cc",
- "md5digest.h",
"memory_usage.cc",
"memory_usage.h",
"natserver.cc",
@@ -854,8 +852,6 @@
"proxyserver.cc",
"proxyserver.h",
"refcount.h",
- "sha1digest.cc",
- "sha1digest.h",
"sigslottester.h",
"sigslottester.h.pump",
"testbase64.h",
@@ -882,14 +878,6 @@
public_deps = [
"//testing/gtest",
]
-
- # TODO(jbauch): Remove once "md5digest" and "sha1digest" files have been
- # removed.
- if (rtc_build_ssl) {
- deps += [ "//third_party/boringssl" ]
- } else {
- configs += [ ":external_ssl_library" ]
- }
}
rtc_source_set("rtc_task_queue_for_test") {
@@ -975,7 +963,6 @@
"file_unittest.cc",
"function_view_unittest.cc",
"logging_unittest.cc",
- "md5digest_unittest.cc",
"numerics/histogram_percentile_counter_unittest.cc",
"numerics/mod_ops_unittest.cc",
"numerics/moving_max_counter_unittest.cc",
@@ -1014,14 +1001,6 @@
"../system_wrappers:system_wrappers",
"../test:test_support",
]
-
- # TODO(jbauch): Remove once "md5digest" and "sha1digest" files have been
- # removed.
- if (rtc_build_ssl) {
- deps += [ "//third_party/boringssl" ]
- } else {
- configs += [ ":external_ssl_library" ]
- }
}
rtc_source_set("rtc_task_queue_unittests") {
@@ -1118,7 +1097,6 @@
"rollingaccumulator_unittest.cc",
"rtccertificate_unittest.cc",
"rtccertificategenerator_unittest.cc",
- "sha1digest_unittest.cc",
"signalthread_unittest.cc",
"sigslot_unittest.cc",
"sigslottester_unittest.cc",
diff --git a/rtc_base/md5digest.cc b/rtc_base/md5digest.cc
deleted file mode 100644
index 4584284..0000000
--- a/rtc_base/md5digest.cc
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright 2015 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#include "rtc_base/md5digest.h"
-
-namespace rtc {
-
-size_t Md5Digest::Size() const {
- return kSize;
-}
-
-void Md5Digest::Update(const void* buf, size_t len) {
- MD5_Update(&ctx_, static_cast<const uint8_t*>(buf), len);
-}
-
-size_t Md5Digest::Finish(void* buf, size_t len) {
- if (len < kSize) {
- return 0;
- }
- MD5_Final(static_cast<uint8_t*>(buf), &ctx_);
- MD5_Init(&ctx_); // Reset for next use.
- return kSize;
-}
-
-} // namespace rtc
diff --git a/rtc_base/md5digest.h b/rtc_base/md5digest.h
deleted file mode 100644
index 34a8200..0000000
--- a/rtc_base/md5digest.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright 2012 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#ifndef RTC_BASE_MD5DIGEST_H_
-#define RTC_BASE_MD5DIGEST_H_
-
-#include <openssl/md5.h>
-
-#include "rtc_base/messagedigest.h"
-
-namespace rtc {
-
-// A simple wrapper for the MD5 implementation.
-class Md5Digest : public MessageDigest {
- public:
- enum { kSize = MD5_DIGEST_LENGTH };
- Md5Digest() {
- MD5_Init(&ctx_);
- }
- size_t Size() const override;
- void Update(const void* buf, size_t len) override;
- size_t Finish(void* buf, size_t len) override;
-
- private:
- MD5_CTX ctx_;
-};
-
-} // namespace rtc
-
-#endif // RTC_BASE_MD5DIGEST_H_
diff --git a/rtc_base/md5digest_unittest.cc b/rtc_base/md5digest_unittest.cc
deleted file mode 100644
index dcdc198..0000000
--- a/rtc_base/md5digest_unittest.cc
+++ /dev/null
@@ -1,79 +0,0 @@
-/*
- * Copyright 2012 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#include "rtc_base/md5digest.h"
-#include "rtc_base/gunit.h"
-#include "rtc_base/stringencode.h"
-
-namespace rtc {
-
-std::string Md5(const std::string& input) {
- Md5Digest md5;
- return ComputeDigest(&md5, input);
-}
-
-TEST(Md5DigestTest, TestSize) {
- Md5Digest md5;
- EXPECT_EQ(16, static_cast<int>(Md5Digest::kSize));
- EXPECT_EQ(16U, md5.Size());
-}
-
-TEST(Md5DigestTest, TestBasic) {
- // These are the standard MD5 test vectors from RFC 1321.
- EXPECT_EQ("d41d8cd98f00b204e9800998ecf8427e", Md5(""));
- EXPECT_EQ("0cc175b9c0f1b6a831c399e269772661", Md5("a"));
- EXPECT_EQ("900150983cd24fb0d6963f7d28e17f72", Md5("abc"));
- EXPECT_EQ("f96b697d7cb7938d525a2f31aaf161d0", Md5("message digest"));
- EXPECT_EQ("c3fcd3d76192e4007dfb496cca67e13b",
- Md5("abcdefghijklmnopqrstuvwxyz"));
-}
-
-TEST(Md5DigestTest, TestMultipleUpdates) {
- Md5Digest md5;
- std::string input = "abcdefghijklmnopqrstuvwxyz";
- char output[Md5Digest::kSize];
- for (size_t i = 0; i < input.size(); ++i) {
- md5.Update(&input[i], 1);
- }
- EXPECT_EQ(md5.Size(), md5.Finish(output, sizeof(output)));
- EXPECT_EQ("c3fcd3d76192e4007dfb496cca67e13b",
- hex_encode(output, sizeof(output)));
-}
-
-TEST(Md5DigestTest, TestReuse) {
- Md5Digest md5;
- std::string input = "message digest";
- EXPECT_EQ("f96b697d7cb7938d525a2f31aaf161d0", ComputeDigest(&md5, input));
- input = "abcdefghijklmnopqrstuvwxyz";
- EXPECT_EQ("c3fcd3d76192e4007dfb496cca67e13b", ComputeDigest(&md5, input));
-}
-
-TEST(Md5DigestTest, TestBufferTooSmall) {
- Md5Digest md5;
- std::string input = "abcdefghijklmnopqrstuvwxyz";
- char output[Md5Digest::kSize - 1];
- md5.Update(input.c_str(), input.size());
- EXPECT_EQ(0U, md5.Finish(output, sizeof(output)));
-}
-
-TEST(Md5DigestTest, TestBufferConst) {
- Md5Digest md5;
- const int kLongSize = 1000000;
- std::string input(kLongSize, '\0');
- for (int i = 0; i < kLongSize; ++i) {
- input[i] = static_cast<char>(i);
- }
- md5.Update(input.c_str(), input.size());
- for (int i = 0; i < kLongSize; ++i) {
- EXPECT_EQ(static_cast<char>(i), input[i]);
- }
-}
-
-} // namespace rtc
diff --git a/rtc_base/sha1digest.cc b/rtc_base/sha1digest.cc
deleted file mode 100644
index b8a1deb..0000000
--- a/rtc_base/sha1digest.cc
+++ /dev/null
@@ -1,32 +0,0 @@
-/*
- * Copyright 2015 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#include "rtc_base/sha1digest.h"
-
-namespace rtc {
-
-size_t Sha1Digest::Size() const {
- return kSize;
-}
-
-void Sha1Digest::Update(const void* buf, size_t len) {
- SHA1_Update(&ctx_, static_cast<const uint8_t*>(buf), len);
-}
-
-size_t Sha1Digest::Finish(void* buf, size_t len) {
- if (len < kSize) {
- return 0;
- }
- SHA1_Final(static_cast<uint8_t*>(buf), &ctx_);
- SHA1_Init(&ctx_); // Reset for next use.
- return kSize;
-}
-
-} // namespace rtc
diff --git a/rtc_base/sha1digest.h b/rtc_base/sha1digest.h
deleted file mode 100644
index 43043ea..0000000
--- a/rtc_base/sha1digest.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright 2012 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#ifndef RTC_BASE_SHA1DIGEST_H_
-#define RTC_BASE_SHA1DIGEST_H_
-
-#include <openssl/sha.h>
-
-#include "rtc_base/messagedigest.h"
-
-namespace rtc {
-
-// A simple wrapper for the SHA-1 implementation.
-class Sha1Digest : public MessageDigest {
- public:
- enum { kSize = SHA_DIGEST_LENGTH };
- Sha1Digest() {
- SHA1_Init(&ctx_);
- }
- size_t Size() const override;
- void Update(const void* buf, size_t len) override;
- size_t Finish(void* buf, size_t len) override;
-
- private:
- SHA_CTX ctx_;
-};
-
-} // namespace rtc
-
-#endif // RTC_BASE_SHA1DIGEST_H_
diff --git a/rtc_base/sha1digest_unittest.cc b/rtc_base/sha1digest_unittest.cc
deleted file mode 100644
index b3dd832..0000000
--- a/rtc_base/sha1digest_unittest.cc
+++ /dev/null
@@ -1,82 +0,0 @@
-/*
- * Copyright 2012 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
-
-#include "rtc_base/sha1digest.h"
-#include "rtc_base/gunit.h"
-#include "rtc_base/stringencode.h"
-
-namespace rtc {
-
-std::string Sha1(const std::string& input) {
- Sha1Digest sha1;
- return ComputeDigest(&sha1, input);
-}
-
-TEST(Sha1DigestTest, TestSize) {
- Sha1Digest sha1;
- EXPECT_EQ(20, static_cast<int>(Sha1Digest::kSize));
- EXPECT_EQ(20U, sha1.Size());
-}
-
-TEST(Sha1DigestTest, TestBasic) {
- // Test vectors from sha1.c.
- EXPECT_EQ("da39a3ee5e6b4b0d3255bfef95601890afd80709", Sha1(""));
- EXPECT_EQ("a9993e364706816aba3e25717850c26c9cd0d89d", Sha1("abc"));
- EXPECT_EQ("84983e441c3bd26ebaae4aa1f95129e5e54670f1",
- Sha1("abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq"));
- std::string a_million_as(1000000, 'a');
- EXPECT_EQ("34aa973cd4c4daa4f61eeb2bdbad27316534016f", Sha1(a_million_as));
-}
-
-TEST(Sha1DigestTest, TestMultipleUpdates) {
- Sha1Digest sha1;
- std::string input =
- "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq";
- char output[Sha1Digest::kSize];
- for (size_t i = 0; i < input.size(); ++i) {
- sha1.Update(&input[i], 1);
- }
- EXPECT_EQ(sha1.Size(), sha1.Finish(output, sizeof(output)));
- EXPECT_EQ("84983e441c3bd26ebaae4aa1f95129e5e54670f1",
- hex_encode(output, sizeof(output)));
-}
-
-TEST(Sha1DigestTest, TestReuse) {
- Sha1Digest sha1;
- std::string input = "abc";
- EXPECT_EQ("a9993e364706816aba3e25717850c26c9cd0d89d",
- ComputeDigest(&sha1, input));
- input = "abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq";
- EXPECT_EQ("84983e441c3bd26ebaae4aa1f95129e5e54670f1",
- ComputeDigest(&sha1, input));
-}
-
-TEST(Sha1DigestTest, TestBufferTooSmall) {
- Sha1Digest sha1;
- std::string input = "abcdefghijklmnopqrstuvwxyz";
- char output[Sha1Digest::kSize - 1];
- sha1.Update(input.c_str(), input.size());
- EXPECT_EQ(0U, sha1.Finish(output, sizeof(output)));
-}
-
-TEST(Sha1DigestTest, TestBufferConst) {
- Sha1Digest sha1;
- const int kLongSize = 1000000;
- std::string input(kLongSize, '\0');
- for (int i = 0; i < kLongSize; ++i) {
- input[i] = static_cast<char>(i);
- }
- sha1.Update(input.c_str(), input.size());
- for (int i = 0; i < kLongSize; ++i) {
- EXPECT_EQ(static_cast<char>(i), input[i]);
- }
-}
-
-} // namespace rtc