1#include <xrpld/app/paths/TrustLine.h>
2#include <xrpld/rpc/Context.h>
3#include <xrpld/rpc/detail/RPCHelpers.h>
4#include <xrpld/rpc/detail/Tuning.h>
6#include <xrpl/ledger/ReadView.h>
7#include <xrpl/protocol/ErrorCodes.h>
8#include <xrpl/protocol/RPCErr.h>
9#include <xrpl/protocol/jss.h>
10#include <xrpl/resource/Fees.h>
17 STAmount const& saBalance(line.getBalance());
18 STAmount const& saLimit(line.getLimit());
19 STAmount const& saLimitPeer(line.getLimitPeer());
22 jPeer[jss::account] =
to_string(line.getAccountIDPeer());
28 jPeer[jss::balance] = saBalance.
getText();
30 jPeer[jss::limit] = saLimit.
getText();
31 jPeer[jss::limit_peer] = saLimitPeer.
getText();
32 jPeer[jss::quality_in] = line.getQualityIn().value;
33 jPeer[jss::quality_out] = line.getQualityOut().value;
35 jPeer[jss::authorized] =
true;
36 if (line.getAuthPeer())
37 jPeer[jss::peer_authorized] =
true;
38 if (line.getNoRipple())
39 jPeer[jss::no_ripple] =
true;
40 if (line.getNoRipplePeer())
41 jPeer[jss::no_ripple_peer] =
true;
43 jPeer[jss::freeze] =
true;
44 if (line.getFreezePeer())
45 jPeer[jss::freeze_peer] =
true;
46 if (line.getDeepFreeze())
47 jPeer[jss::deep_freeze] =
true;
48 if (line.getDeepFreezePeer())
49 jPeer[jss::deep_freeze_peer] =
true;
64 auto const& params(context.
params);
65 if (!params.isMember(jss::account))
68 if (!params[jss::account].isString())
76 auto id = parseBase58<AccountID>(params[jss::account].asString());
82 auto const accountID{std::move(
id.value())};
88 if (params.isMember(jss::peer))
89 strPeer = params[jss::peer].asString();
94 if (!strPeer.
empty() && !raPeerAccount)
106 bool ignoreDefault = params.isMember(jss::ignore_default) &&
107 params[jss::ignore_default].asBool();
118 VisitData visitData = {{}, accountID, raPeerAccount, ignoreDefault, 0};
119 uint256 startAfter = beast::zero;
122 if (params.isMember(jss::marker))
124 if (!params[jss::marker].isString())
142 startHint = boost::lexical_cast<std::uint64_t>(value);
144 catch (boost::bad_lexical_cast&)
151 auto const sle = ledger->read({
ltANY, startAfter});
170 [&visitData, &count, &marker, &limit, &nextHint](
175 UNREACHABLE(
"ripple::doAccountLines : null SLE");
180 if (++count == limit)
182 marker = sleCur->key();
187 if (sleCur->getType() != ltRIPPLE_STATE)
191 if (visitData.ignoreDefault)
193 if (sleCur->getFieldAmount(sfLowLimit).getIssuer() ==
202 if (!ignore && count <= limit)
208 (!visitData.raPeerAccount ||
209 *visitData.raPeerAccount ==
210 line->getAccountIDPeer()))
212 visitData.items.emplace_back(*line);
226 if (count == limit + 1 && marker)
228 result[jss::limit] = limit;
229 result[jss::marker] =
233 result[jss::account] =
toBase58(accountID);
235 for (
auto const& item : visitData.items)
Value & append(Value const &value)
Append value to array at the end.
static std::optional< RPCTrustLine > makeItem(AccountID const &accountID, std::shared_ptr< SLE const > const &sle)
std::string getText() const override
Issue const & issue() const
constexpr bool parseHex(std::string_view sv)
Parse a hex string into a base_uint.
@ arrayValue
array value (ordered list)
@ objectValue
object value (collection of name/value pairs).
static LimitRange constexpr accountLines
Limits for the account_lines command.
Json::Value invalid_field_error(std::string const &name)
bool isRelatedToAccount(ReadView const &ledger, std::shared_ptr< SLE const > const &sle, AccountID const &accountID)
Tests if a SLE is owned by accountID.
void inject_error(error_code_i code, JsonValue &json)
Add or update the json update to reflect the error code.
Json::Value expected_field_error(std::string const &name, std::string const &type)
Status lookupLedger(std::shared_ptr< ReadView const > &ledger, JsonContext &context, Json::Value &result)
Look up a ledger from a request and fill a Json::Result with the data representing a ledger.
std::uint64_t getStartHint(std::shared_ptr< SLE const > const &sle, AccountID const &accountID)
Gets the start hint for traversing account objects.
Json::Value missing_field_error(std::string const &name)
Charge const feeMediumBurdenRPC
Keylet account(AccountID const &id) noexcept
AccountID root.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
std::string toBase58(AccountID const &v)
Convert AccountID to base58 checked string.
void addLine(Json::Value &jsonLines, RPCTrustLine const &line)
Json::Value doAccountLines(RPC::JsonContext &context)
Json::Value rpcError(int iError)
bool forEachItemAfter(ReadView const &view, Keylet const &root, uint256 const &after, std::uint64_t const hint, unsigned int limit, std::function< bool(std::shared_ptr< SLE const > const &)> const &f)
Iterate all items after an item in the given directory.
std::string to_string(base_uint< Bits, Tag > const &a)
@ ltANY
A special type, matching any ledger entry type.
Resource::Charge & loadType