Clio  develop
The XRP Ledger API server.
Loading...
Searching...
No Matches
NFTOffersCommon.hpp
1#pragma once
2
3#include "data/BackendInterface.hpp"
4#include "rpc/JS.hpp"
5#include "rpc/common/Modifiers.hpp"
6#include "rpc/common/Specs.hpp"
7#include "rpc/common/Types.hpp"
8#include "rpc/common/Validators.hpp"
9
10#include <boost/asio/spawn.hpp>
11#include <boost/json/conversion.hpp>
12#include <boost/json/value.hpp>
13#include <xrpl/basics/base_uint.h>
14#include <xrpl/protocol/Keylet.h>
15#include <xrpl/protocol/STLedgerEntry.h>
16#include <xrpl/protocol/jss.h>
17
18#include <cstdint>
19#include <memory>
20#include <optional>
21#include <string>
22#include <vector>
23
24namespace rpc {
25
30 std::shared_ptr<BackendInterface> sharedPtrBackend_;
31
32public:
33 static constexpr auto kLIMIT_MIN = 50;
34 static constexpr auto kLIMIT_MAX = 500;
35 static constexpr auto kLIMIT_DEFAULT = 250;
36
40 struct Output {
41 std::string nftID;
42 std::vector<ripple::SLE> offers;
43
44 // validated should be sent via framework
45 bool validated = true;
46 std::optional<uint32_t> limit;
47 std::optional<std::string> marker;
48 };
49
53 struct Input {
54 std::string nftID;
55 std::optional<std::string> ledgerHash;
56 std::optional<uint32_t> ledgerIndex;
57 uint32_t limit = kLIMIT_DEFAULT;
58 std::optional<std::string> marker;
59 };
60
61 using Result = HandlerReturnType<Output>;
62
68 NFTOffersHandlerBase(std::shared_ptr<BackendInterface> sharedPtrBackend)
69 : sharedPtrBackend_(std::move(sharedPtrBackend))
70 {
71 }
72
79 static RpcSpecConstRef
80 spec([[maybe_unused]] uint32_t apiVersion)
81 {
82 static auto const kRPC_SPEC = RpcSpec{
83 {JS(nft_id),
88 {JS(limit),
91 modifiers::Clamp<int32_t>{kLIMIT_MIN, kLIMIT_MAX}},
93 };
94
95 return kRPC_SPEC;
96 }
97
98protected:
108 Result
110 Input input,
111 ripple::uint256 const& tokenID,
112 ripple::Keylet const& directory,
113 boost::asio::yield_context yield
114 ) const;
115
116private:
123 friend void
124 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, Output const& output);
125
132 friend Input
133 tag_invoke(boost::json::value_to_tag<Input>, boost::json::value const& jv);
134};
135
136} // namespace rpc
Result iterateOfferDirectory(Input input, ripple::uint256 const &tokenID, ripple::Keylet const &directory, boost::asio::yield_context yield) const
Iterate the NFT offer directory.
Definition NFTOffersCommon.cpp:67
friend void tag_invoke(boost::json::value_from_tag, boost::json::value &jv, Output const &output)
Convert the Output to a JSON object.
Definition NFTOffersCommon.cpp:157
static RpcSpecConstRef spec(uint32_t apiVersion)
Returns the API specification for the command.
Definition NFTOffersCommon.hpp:80
NFTOffersHandlerBase(std::shared_ptr< BackendInterface > sharedPtrBackend)
Construct a new NFTOffersHandlerBase object.
Definition NFTOffersCommon.hpp:68
Clamp value between min and max.
Definition Modifiers.hpp:23
Validate that value is equal or greater than the specified min.
Definition Validators.hpp:205
This namespace contains all the RPC logic and handlers.
Definition AMMHelpers.cpp:18
RpcSpec const & RpcSpecConstRef
An alias for a const reference to RpcSpec.
Definition Specs.hpp:130
std::expected< OutputType, Status > HandlerReturnType
Return type for each individual handler.
Definition Types.hpp:62
A struct to hold the input data for the command.
Definition NFTOffersCommon.hpp:53
A struct to hold the output data of the command.
Definition NFTOffersCommon.hpp:40
Result type used to return responses or error statuses to the Webserver subsystem.
Definition Types.hpp:110
Represents a Specification of an entire RPC command.
Definition Specs.hpp:82
static CustomValidator ledgerIndexValidator
Provides a commonly used validator for ledger index.
Definition Validators.hpp:489
static CustomValidator uint256HexStringValidator
Provides a commonly used validator for uint256 hex string.
Definition Validators.hpp:551
A validator that simply requires a field to be present.
Definition Validators.hpp:28
Validates that the type of the value is one of the given types.
Definition Validators.hpp:128