xrpld
Loading...
Searching...
No Matches
ChannelVerify.cpp
1#include <xrpld/rpc/Context.h>
2#include <xrpld/rpc/detail/RPCHelpers.h>
3
4#include <xrpl/basics/Slice.h>
5#include <xrpl/basics/StringUtilities.h>
6#include <xrpl/basics/base_uint.h>
7#include <xrpl/json/json_value.h>
8#include <xrpl/protocol/ErrorCodes.h>
9#include <xrpl/protocol/PayChan.h>
10#include <xrpl/protocol/PublicKey.h>
11#include <xrpl/protocol/RPCErr.h>
12#include <xrpl/protocol/Serializer.h>
13#include <xrpl/protocol/XRPAmount.h>
14#include <xrpl/protocol/jss.h>
15#include <xrpl/protocol/tokens.h>
16
17#include <cstdint>
18#include <optional>
19#include <string>
20
21namespace xrpl {
22
23// {
24// public_key: <public_key>
25// channel_id: 256-bit channel id
26// drops: 64-bit uint (as string)
27// signature: signature to verify
28// }
29json::Value
31{
32 auto const& params(context.params);
33 for (auto const& p : {jss::public_key, jss::channel_id, jss::amount, jss::signature})
34 {
35 if (!params.isMember(p))
36 return RPC::missingFieldError(p);
37 }
38
40 {
41 std::string const strPk = params[jss::public_key].asString();
43
44 if (!pk)
45 {
46 auto pkHex = strUnHex(strPk);
47 if (!pkHex)
49 auto const pkType = publicKeyType(makeSlice(*pkHex));
50 if (!pkType)
52 pk.emplace(makeSlice(*pkHex));
53 }
54 }
55
56 uint256 channelId;
57 if (!channelId.parseHex(params[jss::channel_id].asString()))
59
60 std::optional<std::uint64_t> const optDrops =
61 params[jss::amount].isString() ? toUInt64(params[jss::amount].asString()) : std::nullopt;
62
63 if (!optDrops)
65
66 std::uint64_t const drops = *optDrops;
67
68 auto sig = strUnHex(params[jss::signature].asString());
69 if (!sig || sig->empty())
71
72 Serializer msg;
73 serializePayChanAuthorization(msg, channelId, XRPAmount(drops));
74
75 json::Value result;
76 result[jss::signature_verified] = verify(*pk, msg.slice(), makeSlice(*sig));
77 return result;
78}
79
80} // namespace xrpl
Represents a JSON value.
Definition json_value.h:130
constexpr bool parseHex(std::string_view sv)
Parse a hex string into a base_uint.
Definition base_uint.h:507
Slice slice() const noexcept
Definition Serializer.h:44
T emplace(T... args)
json::Value missingFieldError(std::string const &name)
Definition ErrorCodes.h:231
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition algorithm.h:5
@ RpcChannelAmtMalformed
Definition ErrorCodes.h:83
@ RpcPublicMalformed
Definition ErrorCodes.h:99
@ RpcInvalidParams
Definition ErrorCodes.h:66
@ RpcChannelMalformed
Definition ErrorCodes.h:82
std::optional< AccountID > parseBase58(std::string const &s)
Parse AccountID from checked, base58 string.
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)
Definition PayChan.h:11
std::optional< KeyType > publicKeyType(Slice const &slice)
Returns the type of public key.
json::Value rpcError(ErrorCodeI iError)
Definition RPCErr.cpp:13
std::optional< Blob > strUnHex(std::size_t strSize, Iterator begin, Iterator end)
std::optional< std::uint64_t > toUInt64(std::string const &s)
json::Value doChannelVerify(RPC::JsonContext &context)
BaseUInt< 256 > uint256
Definition base_uint.h:562
std::enable_if_t< std::is_same_v< T, char >||std::is_same_v< T, unsigned char >, Slice > makeSlice(std::array< T, N > const &a)
Definition Slice.h:215
json::Value params
Definition Context.h:43