1#include <xrpld/rpc/Context.h>
2#include <xrpld/rpc/detail/RPCHelpers.h>
4#include <xrpl/basics/StringUtilities.h>
5#include <xrpl/protocol/ErrorCodes.h>
6#include <xrpl/protocol/PayChan.h>
7#include <xrpl/protocol/RPCErr.h>
8#include <xrpl/protocol/jss.h>
23 auto const& params(context.
params);
24 for (
auto const& p : {jss::public_key, jss::channel_id, jss::amount, jss::signature})
26 if (!params.isMember(p))
32 std::string const strPk = params[jss::public_key].asString();
48 if (!channelId.
parseHex(params[jss::channel_id].asString()))
59 auto sig =
strUnHex(params[jss::signature].asString());
60 if (!sig || sig->empty())
Slice slice() const noexcept
constexpr bool parseHex(std::string_view sv)
Parse a hex string into a base_uint.
Json::Value missing_field_error(std::string const &name)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Json::Value doChannelVerify(RPC::JsonContext &context)
std::optional< std::uint64_t > to_uint64(std::string const &s)
bool verify(PublicKey const &publicKey, Slice const &m, Slice const &sig) noexcept
Verify a signature on a message.
void serializePayChanAuthorization(Serializer &msg, uint256 const &key, XRPAmount const &amt)
std::optional< KeyType > publicKeyType(Slice const &slice)
Returns the type of public key.
std::optional< Blob > strUnHex(std::size_t strSize, Iterator begin, Iterator end)
Json::Value rpcError(error_code_i iError)
std::enable_if_t< std::is_same< T, char >::value||std::is_same< T, unsigned char >::value, Slice > makeSlice(std::array< T, N > const &a)
@ rpcCHANNEL_AMT_MALFORMED