SHA1.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. // Copyright 2017 Dolphin Emulator Project
  2. // SPDX-License-Identifier: GPL-2.0-or-later
  3. #pragma once
  4. #include <array>
  5. #include <limits>
  6. #include <memory>
  7. #include <span>
  8. #include <string_view>
  9. #include <type_traits>
  10. #include <vector>
  11. #include "Common/Assert.h"
  12. #include "Common/CommonTypes.h"
  13. namespace Common::SHA1
  14. {
  15. using Digest = std::array<u8, 160 / 8>;
  16. static constexpr size_t DIGEST_LEN = sizeof(Digest);
  17. class Context
  18. {
  19. public:
  20. virtual ~Context() = default;
  21. virtual void Update(const u8* msg, size_t len) = 0;
  22. void Update(std::span<const u8> msg) { return Update(msg.data(), msg.size()); }
  23. void Update(std::string_view msg)
  24. {
  25. return Update(reinterpret_cast<const u8*>(msg.data()), msg.size());
  26. }
  27. virtual Digest Finish() = 0;
  28. virtual bool HwAccelerated() const = 0;
  29. };
  30. std::unique_ptr<Context> CreateContext();
  31. Digest CalculateDigest(const u8* msg, size_t len);
  32. template <typename T>
  33. inline Digest CalculateDigest(const std::vector<T>& msg)
  34. {
  35. static_assert(std::is_trivially_copyable_v<T>);
  36. ASSERT(std::numeric_limits<size_t>::max() / sizeof(T) >= msg.size());
  37. return CalculateDigest(reinterpret_cast<const u8*>(msg.data()), sizeof(T) * msg.size());
  38. }
  39. inline Digest CalculateDigest(const std::string_view& msg)
  40. {
  41. return CalculateDigest(reinterpret_cast<const u8*>(msg.data()), msg.size());
  42. }
  43. template <typename T, size_t Size>
  44. inline Digest CalculateDigest(const std::array<T, Size>& msg)
  45. {
  46. static_assert(std::is_trivially_copyable_v<T>);
  47. return CalculateDigest(reinterpret_cast<const u8*>(msg.data()), sizeof(msg));
  48. }
  49. std::string DigestToString(const Digest& digest);
  50. } // namespace Common::SHA1