Clio  develop
The XRP Ledger API server.
Loading...
Searching...
No Matches
NFTInfo.hpp
1#pragma once
2
3#include "data/BackendInterface.hpp"
4#include "rpc/JS.hpp"
5#include "rpc/common/Specs.hpp"
6#include "rpc/common/Types.hpp"
7#include "rpc/common/Validators.hpp"
8
9#include <boost/json/conversion.hpp>
10#include <boost/json/value.hpp>
11#include <xrpl/protocol/jss.h>
12
13#include <cstdint>
14#include <memory>
15#include <optional>
16#include <string>
17
18namespace rpc {
19
26 std::shared_ptr<BackendInterface> sharedPtrBackend_;
27
28public:
32 struct Output {
33 std::string nftID;
34 uint32_t ledgerIndex;
35 std::string owner;
36 bool isBurned;
37 uint32_t flags;
38 uint32_t transferFee;
39 std::string issuer;
40 uint32_t taxon;
41 uint32_t serial; // TODO: documented as 'nft_sequence' atm.
42 // https://github.com/XRPLF/xrpl-dev-portal/issues/1841
43 std::string uri;
44
45 // validated should be sent via framework
46 bool validated = true;
47 };
48
52 struct Input {
53 std::string nftID;
54 std::optional<std::string> ledgerHash;
55 std::optional<uint32_t> ledgerIndex;
56 };
57
58 using Result = HandlerReturnType<Output>;
59
65 NFTInfoHandler(std::shared_ptr<BackendInterface> sharedPtrBackend)
66 : sharedPtrBackend_(std::move(sharedPtrBackend))
67 {
68 }
69
76 static RpcSpecConstRef
77 spec([[maybe_unused]] uint32_t apiVersion)
78 {
79 static auto const kRPC_SPEC = RpcSpec{
80 {JS(nft_id),
85 };
86
87 return kRPC_SPEC;
88 }
89
97 Result
98 process(Input const& input, Context const& ctx) const;
99
100private:
107 friend void
108 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, Output const& output);
109
116 friend Input
117 tag_invoke(boost::json::value_to_tag<Input>, boost::json::value const& jv);
118};
119
120} // namespace rpc
Result process(Input const &input, Context const &ctx) const
Process the NFTInfo command.
Definition NFTInfo.cpp:28
NFTInfoHandler(std::shared_ptr< BackendInterface > sharedPtrBackend)
Construct a new NFTInfoHandler object.
Definition NFTInfo.hpp:65
static RpcSpecConstRef spec(uint32_t apiVersion)
Returns the API specification for the command.
Definition NFTInfo.hpp:77
friend void tag_invoke(boost::json::value_from_tag, boost::json::value &jv, Output const &output)
Convert the Output to a JSON object.
Definition NFTInfo.cpp:70
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
Context of an RPC call.
Definition Types.hpp:99
A struct to hold the input data for the command.
Definition NFTInfo.hpp:52
A struct to hold the output data of the command.
Definition NFTInfo.hpp:32
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