-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #13 from cppalliance/sha1
Implement, test and fuzz SHA1
- Loading branch information
Showing
16 changed files
with
1,508 additions
and
16 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
//// | ||
Copyright 2024 Matt Borland | ||
Distributed under the Boost Software License, Version 1.0. | ||
https://www.boost.org/LICENSE_1_0.txt | ||
//// | ||
|
||
[#sha1] | ||
:idprefix: sha1_ | ||
|
||
= SHA1 | ||
|
||
This library supports SHA1 as described in https://datatracker.ietf.org/doc/html/rfc3174[RFC 3174]. | ||
There is a wide range of acceptable inputs for the base sha1 function: | ||
|
||
== Hashing Functions | ||
|
||
[source, c++] | ||
---- | ||
namespace boost { | ||
namespace crypt { | ||
uisng return_type = boost::crypt::array<uint8_t, 20>; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char* str) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char* str, size_t len) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const unsigned char* str) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const unsigned char* str, size_t len) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char16_t* str) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char16_t* str, size_t len) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char32_t* str) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const char32_t* str, size_t len) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const wchar_t* str) noexcept -> return_type; | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto sha1(const wchar_t* str, size_t len) noexcept -> return_type; | ||
inline auto sha1(const std::string& str) noexcept -> return_type; | ||
inline auto sha1(const std::u16string& str) noexcept -> return_type; | ||
inline auto sha1(const std::u32string& str) noexcept -> return_type; | ||
inline auto sha1(const std::wstring& str) noexcept -> return_type; | ||
#ifdef BOOST_CRYPT_HAS_STRING_VIEW | ||
inline auto sha1(std::string_view str) noexcept -> return_type; | ||
inline auto sha1(std::u16string_view str) noexcept -> return_type; | ||
inline auto sha1(std::u32string_view str) noexcept -> return_type; | ||
inline auto sha1(std::wstring_view str) noexcept -> return_type; | ||
#endif // BOOST_CRYPT_HAS_STRING_VIEW | ||
} //namespace crypt | ||
} //namespace boost | ||
---- | ||
|
||
== File Hashing Functions | ||
|
||
We also have the ability to scan files and return the sha1 value: | ||
|
||
[source, c++] | ||
---- | ||
namespace boost { | ||
namespace crypt { | ||
uisng return_type = boost::crypt::array<uint8_t, 16>; | ||
inline auto sha1_file(const char* filepath) noexcept -> return_type; | ||
inline auto sha1_file(const std::string& filepath) noexcept -> return_type; | ||
inline auto sha1_file(std::string_view filepath) noexcept -> return_type; | ||
} // namespace crypt | ||
} // namespace boost | ||
---- | ||
|
||
== Hashing Object | ||
|
||
[#sha1_hasher] | ||
Lastly, there is also the ability to create a sha1 hashing object and feed it bytes as the user parses them. | ||
This class does not use any dynamic memory allocation. | ||
|
||
[source, c++] | ||
---- | ||
namespace boost { | ||
namespace crypt { | ||
class sha1_hasher | ||
{ | ||
init(); | ||
template <typename ByteType> | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto process_byte(ByteType byte) noexcept -> void; | ||
template <typename ForwardIter> | ||
BOOST_CRYPT_GPU_ENABLED constexpr auto process_bytes(ForwardIter buffer, size_t byte_count) noexcept -> void; | ||
constexpr auto get_digest() noexcept -> boost::crypt::array<boost::crypt::uint8_t, 20>; | ||
}; | ||
} // namespace crypt | ||
} // namespace boost | ||
---- |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
// Copyright 2024 Matt Borland | ||
// Distributed under the Boost Software License, Version 1.0. | ||
// https://www.boost.org/LICENSE_1_0.txt | ||
|
||
#include <boost/crypt/hash/sha1.hpp> | ||
#include <iostream> | ||
#include <exception> | ||
#include <string> | ||
|
||
extern "C" int LLVMFuzzerTestOneInput(const std::uint8_t* data, std::size_t size) | ||
{ | ||
try | ||
{ | ||
auto c_data = reinterpret_cast<const char*>(data); | ||
std::string c_data_str {c_data, size}; // Guarantee null termination since we can't pass the size argument | ||
|
||
boost::crypt::sha1(c_data_str); | ||
boost::crypt::sha1(c_data, size); | ||
boost::crypt::sha1(data, size); | ||
|
||
#ifdef BOOST_CRYPT_HAS_STRING_VIEW | ||
std::string_view view {c_data_str}; | ||
boost::crypt::sha1(view); | ||
#endif | ||
} | ||
catch(...) | ||
{ | ||
std::cerr << "Error with: " << data << std::endl; | ||
std::terminate(); | ||
} | ||
|
||
return 0; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,18 @@ | ||
"The quick brown fox jumps over the lazy dog" | ||
"The quick brown fox jumps over the lazy dog." | ||
"" | ||
"aB3$x9Yz" | ||
"12345" | ||
"!@#$%^&*()" | ||
"FuzzTest123" | ||
" " | ||
"Lorem ipsum dolor sit amet" | ||
"a" | ||
"9876543210" | ||
"ABCDEFGHIJKLMNOPQRSTUVWXYZ" | ||
"ñÑáéíóúÁÉÍÓÚ" | ||
"\n\r\t" | ||
"0" | ||
"ThisIsAVeryLongStringWithNoSpacesOrPunctuationToTestEdgeCases" | ||
"<?php echo 'test'; ?>" | ||
"SELECT * FROM users;" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
// Copyright 2024 Matt Borland | ||
// Distributed under the Boost Software License, Version 1.0. | ||
// https://www.boost.org/LICENSE_1_0.txt | ||
|
||
#ifndef BOOST_CRYPT_HASH_HASHER_STATE_HPP | ||
#define BOOST_CRYPT_HASH_HASHER_STATE_HPP | ||
|
||
#include <boost/crypt/utility/cstdint.hpp> | ||
|
||
namespace boost { | ||
namespace crypt { | ||
|
||
enum class hasher_state : boost::crypt::uint8_t | ||
{ | ||
success, // no issues | ||
null, // nullptr as parameter | ||
input_too_long, // input data too long (exceeded size_t) | ||
state_error // added more input after get_digest without re-init | ||
}; | ||
|
||
} // namespace crypt | ||
} // namespace boost | ||
|
||
#endif // BOOST_CRYPT_HASH_HASHER_STATE_HPP |
Oops, something went wrong.