22#include "data/BackendInterface.hpp"
24#include "rpc/common/Modifiers.hpp"
25#include "rpc/common/Specs.hpp"
26#include "rpc/common/Types.hpp"
27#include "rpc/common/Validators.hpp"
29#include <boost/json/conversion.hpp>
30#include <boost/json/value.hpp>
31#include <xrpl/protocol/STLedgerEntry.h>
32#include <xrpl/protocol/jss.h>
51 std::shared_ptr<BackendInterface>
const sharedPtrBackend_;
54 static constexpr auto kLIMIT_MIN = 10;
55 static constexpr auto kLIMIT_MAX = 400;
56 static constexpr auto kLIMIT_DEFAULT = 200;
64 std::string channelID;
66 std::string accountDestination;
69 std::optional<std::string> publicKey;
70 std::optional<std::string> publicKeyHex;
71 uint32_t settleDelay{};
72 std::optional<uint32_t> expiration;
73 std::optional<uint32_t> cancelAfter;
74 std::optional<uint32_t> sourceTag;
75 std::optional<uint32_t> destinationTag;
82 std::vector<ChannelResponse> channels;
84 std::string ledgerHash;
85 uint32_t ledgerIndex{};
87 bool validated =
true;
89 std::optional<std::string> marker;
97 std::optional<std::string> destinationAccount;
98 std::optional<std::string> ledgerHash;
99 std::optional<uint32_t> ledgerIndex;
100 uint32_t limit = kLIMIT_DEFAULT;
101 std::optional<std::string> marker;
112 : sharedPtrBackend_(sharedPtrBackend)
123 spec([[maybe_unused]] uint32_t apiVersion)
125 static auto const kRPC_SPEC =
RpcSpec{
152 addChannel(std::vector<ChannelResponse>& jsonChannels, ripple::SLE
const& channelSle);
161 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, Output
const& output);
170 tag_invoke(boost::json::value_to_tag<Input>, boost::json::value
const& jv);
179 tag_invoke(boost::json::value_from_tag, boost::json::value& jv, ChannelResponse
const& channel);
The account_channels method returns information about an account's Payment Channels....
Definition AccountChannels.hpp:49
Result process(Input input, Context const &ctx) const
Process the AccountChannels command.
Definition AccountChannels.cpp:85
static RpcSpecConstRef spec(uint32_t apiVersion)
Returns the API specification for the command.
Definition AccountChannels.hpp:123
friend void tag_invoke(boost::json::value_from_tag, boost::json::value &jv, Output const &output)
Convert the Output to a JSON object.
Definition AccountChannels.cpp:168
AccountChannelsHandler(std::shared_ptr< BackendInterface > const &sharedPtrBackend)
Construct a new AccountChannelsHandler object.
Definition AccountChannels.hpp:111
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
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
A struct to hold data for one channel response.
Definition AccountChannels.hpp:63
A struct to hold the output data of the command.
Definition AccountChannels.hpp:81
Context of an RPC call.
Definition Types.hpp:118
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
static CustomValidator accountValidator
Provides a commonly used validator for accounts.
Definition Validators.hpp:491
static CustomValidator accountMarkerValidator
Provides a commonly used validator for markers.
Definition Validators.hpp:506
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