22#include "data/BackendInterface.hpp"
25#include "rpc/common/MetaProcessors.hpp"
26#include "rpc/common/Modifiers.hpp"
27#include "rpc/common/Specs.hpp"
28#include "rpc/common/Types.hpp"
29#include "rpc/common/Validators.hpp"
30#include "util/log/Logger.hpp"
32#include <boost/json/array.hpp>
33#include <boost/json/conversion.hpp>
34#include <boost/json/object.hpp>
35#include <boost/json/value.hpp>
36#include <xrpl/protocol/ErrorCodes.h>
37#include <xrpl/protocol/jss.h>
53 std::shared_ptr<BackendInterface> sharedPtrBackend_;
56 static constexpr auto kLIMIT_MIN = 1;
57 static constexpr auto kLIMIT_MAX = 100;
58 static constexpr auto kLIMIT_DEFAULT = 50;
74 uint32_t ledgerIndexMin{0};
75 uint32_t ledgerIndexMax{0};
76 std::optional<uint32_t> limit;
77 std::optional<Marker> marker;
79 boost::json::array transactions;
81 bool validated =
true;
91 std::optional<std::string> ledgerHash;
92 std::optional<uint32_t> ledgerIndex;
93 std::optional<int32_t> ledgerIndexMin;
94 std::optional<int32_t> ledgerIndexMax;
97 std::optional<uint32_t> limit;
98 std::optional<Marker> marker;
108 NFTHistoryHandler(std::shared_ptr<BackendInterface>
const& sharedPtrBackend) : sharedPtrBackend_(sharedPtrBackend)
119 spec([[maybe_unused]] uint32_t apiVersion)
121 static auto const kRPC_SPEC =
RpcSpec{
164 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, Output
const& output);
173 tag_invoke(boost::json::value_to_tag<Input>, boost::json::value
const& jv);
182 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, Marker
const& marker);
The nft_history command asks the Clio server for past transaction metadata for the NFT being queried.
Definition NFTHistory.hpp:51
static RpcSpecConstRef spec(uint32_t apiVersion)
Returns the API specification for the command.
Definition NFTHistory.hpp:119
NFTHistoryHandler(std::shared_ptr< BackendInterface > const &sharedPtrBackend)
Construct a new NFTHistoryHandler object.
Definition NFTHistory.hpp:108
friend void tag_invoke(boost::json::value_from_tag, boost::json::value &jv, Output const &output)
Convert the Output to a JSON object.
Definition NFTHistory.cpp:173
Result process(Input input, Context const &ctx) const
Process the NFTHistory command.
Definition NFTHistory.cpp:54
Clamp value between min and max.
Definition Modifiers.hpp:42
Validate that value is equal or greater than the specified min.
Definition Validators.hpp:215
A simple thread-safe logger for the channel specified in the constructor.
Definition Logger.hpp:110
This namespace contains all the RPC logic and handlers.
Definition AMMHelpers.cpp:36
RpcSpec const & RpcSpecConstRef
An alias for a const reference to RpcSpec.
Definition Specs.hpp:145
std::expected< OutputType, Status > HandlerReturnType
Return type for each individual handler.
Definition Types.hpp:81
Context of an RPC call.
Definition Types.hpp:118
A struct to hold the input data for the command.
Definition NFTHistory.hpp:87
A struct to hold the marker data.
Definition NFTHistory.hpp:64
A struct to hold the output data of the command.
Definition NFTHistory.hpp:72
Result type used to return responses or error statuses to the Webserver subsystem.
Definition Types.hpp:129
Represents a Specification of an entire RPC command.
Definition Specs.hpp:98
A status returned from any RPC handler.
Definition Errors.hpp:82
static CustomValidator ledgerIndexValidator
Provides a commonly used validator for ledger index.
Definition Validators.hpp:484
static CustomValidator uint256HexStringValidator
Provides a commonly used validator for uint256 hex string.
Definition Validators.hpp:530
A validator that simply requires a field to be present.
Definition Validators.hpp:47
Validates that the type of the value is one of the given types.
Definition Validators.hpp:142