20#include <xrpld/shamap/SHAMapAccountStateLeafNode.h>
21#include <xrpld/shamap/SHAMapInnerNode.h>
22#include <xrpld/shamap/SHAMapLeafNode.h>
23#include <xrpld/shamap/SHAMapTreeNode.h>
24#include <xrpld/shamap/SHAMapTxLeafNode.h>
25#include <xrpld/shamap/SHAMapTxPlusMetaLeafNode.h>
26#include <xrpl/basics/Log.h>
27#include <xrpl/basics/Slice.h>
28#include <xrpl/basics/contract.h>
29#include <xrpl/basics/safe_cast.h>
30#include <xrpl/beast/core/LexicalCast.h>
31#include <xrpl/protocol/HashPrefix.h>
32#include <xrpl/protocol/digest.h>
35#include <openssl/sha.h>
49 return std::make_shared<SHAMapTxLeafNode>(std::move(item), 0, hash);
51 return std::make_shared<SHAMapTxLeafNode>(std::move(item), 0);
65 Throw<std::runtime_error>(
"Short TXN+MD node");
69 Throw<std::out_of_range>(
77 return std::make_shared<SHAMapTxPlusMetaLeafNode>(
78 std::move(item), 0, hash);
80 return std::make_shared<SHAMapTxPlusMetaLeafNode>(std::move(item), 0);
94 Throw<std::runtime_error>(
"short AS node");
98 Throw<std::out_of_range>(
104 Throw<std::runtime_error>(
"Invalid AS node");
109 return std::make_shared<SHAMapAccountStateLeafNode>(
110 std::move(item), 0, hash);
112 return std::make_shared<SHAMapAccountStateLeafNode>(std::move(item), 0);
121 auto const type = rawNode[rawNode.
size() - 1];
125 bool const hashValid =
false;
143 Throw<std::runtime_error>(
150 if (rawNode.
size() < 4)
151 Throw<std::runtime_error>(
"prefix: short node");
155 auto const type = safe_cast<HashPrefix>(
156 (safe_cast<std::uint32_t>(rawNode[0]) << 24) +
157 (safe_cast<std::uint32_t>(rawNode[1]) << 16) +
158 (safe_cast<std::uint32_t>(rawNode[2]) << 8) +
159 (safe_cast<std::uint32_t>(rawNode[3])));
163 bool const hashValid =
true;
177 Throw<std::runtime_error>(
178 "prefix: unknown type (" +
static std::shared_ptr< SHAMapTreeNode > makeCompressedInner(Slice data)
static std::shared_ptr< SHAMapTreeNode > makeFullInner(Slice data, SHAMapHash const &hash, bool hashValid)
Identifies a node inside a SHAMap.
static std::shared_ptr< SHAMapTreeNode > makeTransactionWithMeta(Slice data, SHAMapHash const &hash, bool hashValid)
virtual std::string getString(SHAMapNodeID const &) const
static std::shared_ptr< SHAMapTreeNode > makeAccountState(Slice data, SHAMapHash const &hash, bool hashValid)
static std::shared_ptr< SHAMapTreeNode > makeFromPrefix(Slice rawNode, SHAMapHash const &hash)
static std::shared_ptr< SHAMapTreeNode > makeTransaction(Slice data, SHAMapHash const &hash, bool hashValid)
static std::shared_ptr< SHAMapTreeNode > makeFromWire(Slice rawNode)
std::size_t size() const noexcept
bool getBitString(base_uint< Bits, Tag > &data, int offset) const
Slice slice() const noexcept
An immutable linear range of bytes.
bool empty() const noexcept
Return true if the byte range is empty.
void remove_suffix(std::size_t n)
Shrinks the slice by moving its end backward by n characters.
void remove_prefix(std::size_t n)
Shrinks the slice by moving its start forward by n characters.
std::size_t size() const noexcept
Returns the number of bytes in the storage.
static std::size_t constexpr bytes
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
static constexpr unsigned char const wireTypeAccountState
static constexpr unsigned char const wireTypeCompressedInner
constexpr std::enable_if_t< std::is_integral_v< Dest > &&std::is_integral_v< Src >, Dest > safe_cast(Src s) noexcept
boost::intrusive_ptr< SHAMapItem > make_shamapitem(uint256 const &tag, Slice data)
std::string to_string(base_uint< Bits, Tag > const &a)
static constexpr unsigned char const wireTypeInner
static constexpr unsigned char const wireTypeTransaction
static constexpr unsigned char const wireTypeTransactionWithMeta
@ txNode
transaction plus metadata
@ transactionID
transaction plus signature to give transaction ID
@ innerNode
inner node in V1 tree
sha512_half_hasher::result_type sha512Half(Args const &... args)
Returns the SHA512-Half of a series of objects.