20#include <xrpld/app/tx/detail/Clawback.h>
22#include <xrpl/ledger/View.h>
23#include <xrpl/protocol/Feature.h>
24#include <xrpl/protocol/Indexes.h>
25#include <xrpl/protocol/MPTAmount.h>
26#include <xrpl/protocol/Protocol.h>
27#include <xrpl/protocol/TxFlags.h>
31template <Val
idIssueType T>
48 if (issuer == holder ||
isXRP(clawAmount) || clawAmount <= beast::zero)
61 auto const mptHolder = ctx.
tx[~sfHolder];
62 auto const clawAmount = ctx.
tx[sfAmount];
68 if (ctx.
tx[sfAccount] == *mptHolder)
71 if (clawAmount.mpt() >
MPTAmount{maxMPTokenAmount} ||
72 clawAmount <= beast::zero)
88 [&]<
typename T>(T
const&) {
return preflightHelper<T>(ctx); },
89 ctx.
tx[sfAmount].asset().value());
96template <Val
idIssueType T>
100 SLE const& sleIssuer,
109 SLE const& sleIssuer,
122 auto const sleRippleState =
127 STAmount const balance = (*sleRippleState)[sfBalance];
130 if (balance > beast::zero && issuer < holder)
134 if (balance < beast::zero && issuer > holder)
152 ctx.
j) <= beast::zero)
162 SLE const& sleIssuer,
167 auto const issuanceKey =
169 auto const sleIssuance = ctx.
view.
read(issuanceKey);
176 if (sleIssuance->getAccountID(sfIssuer) != issuer)
188 ctx.
j) <= beast::zero)
198 auto const clawAmount = ctx.
tx[sfAmount];
204 if (!sleIssuer || !sleHolder)
212 else if (sleHolder->isFieldPresent(sfAMMID))
216 [&]<
typename T>(T
const&) {
217 return preclaimHelper<T>(
218 ctx, *sleIssuer, issuer, holder, clawAmount);
220 ctx.
tx[sfAmount].asset().value());
223template <Val
idIssueType T>
237 if (holder == issuer)
253 std::min(spendableAmount, clawAmount),
263 auto clawAmount = ctx.
tx[sfAmount];
279 std::min(spendableAmount, clawAmount),
288 [&]<
typename T>(T
const&) {
return applyHelper<T>(
ctx_); },
289 ctx_.
tx[sfAmount].asset().value());
State information when applying a tx.
beast::Journal const journal
static NotTEC preflight(PreflightContext const &ctx)
static TER preclaim(PreclaimContext const &ctx)
static std::uint32_t getFlagsMask(PreflightContext const &ctx)
A currency issued by an account.
AccountID const & getIssuer() const
constexpr MPTID const & getMptID() const
virtual std::shared_ptr< SLE const > read(Keylet const &k) const =0
Return the state item associated with a key.
virtual bool exists(Keylet const &k) const =0
Determine if a state item exists.
virtual Rules const & rules() const =0
Returns the tx processing rules.
bool enabled(uint256 const &feature) const
Returns true if a feature is enabled.
constexpr TIss const & get() const
void setIssuer(AccountID const &uIssuer)
Currency const & getCurrency() const
AccountID const & getIssuer() const
std::uint32_t getFieldU32(SField const &field) const
bool isFieldPresent(SField const &field) const
Keylet mptoken(MPTID const &issuanceID, AccountID const &holder) noexcept
Keylet line(AccountID const &id0, AccountID const &id1, Currency const ¤cy) noexcept
The index of a trust line for a given currency.
Keylet mptIssuance(std::uint32_t seq, AccountID const &issuer) noexcept
Keylet account(AccountID const &id) noexcept
AccountID root.
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
bool isXRP(AccountID const &c)
static NotTEC preflightHelper(PreflightContext const &ctx)
constexpr std::uint32_t const tfClawbackMask
@ lsfAllowTrustLineClawback
TER preclaimHelper< MPTIssue >(PreclaimContext const &ctx, SLE const &sleIssuer, AccountID const &issuer, AccountID const &holder, STAmount const &clawAmount)
NotTEC preflightHelper< Issue >(PreflightContext const &ctx)
TER applyHelper< Issue >(ApplyContext &ctx)
TER preclaimHelper< Issue >(PreclaimContext const &ctx, SLE const &sleIssuer, AccountID const &issuer, AccountID const &holder, STAmount const &clawAmount)
NotTEC preflightHelper< MPTIssue >(PreflightContext const &ctx)
TER rippleCredit(ApplyView &view, AccountID const &uSenderID, AccountID const &uReceiverID, STAmount const &saAmount, bool bCheckIssuer, beast::Journal j)
Calls static rippleCreditIOU if saAmount represents Issue.
static TER applyHelper(ApplyContext &ctx)
STAmount accountHolds(ReadView const &view, AccountID const &account, Currency const ¤cy, AccountID const &issuer, FreezeHandling zeroIfFrozen, beast::Journal j)
bool isTesSuccess(TER x) noexcept
static TER preclaimHelper(PreclaimContext const &ctx, SLE const &sleIssuer, AccountID const &issuer, AccountID const &holder, STAmount const &clawAmount)
TER applyHelper< MPTIssue >(ApplyContext &ctx)
TERSubset< CanCvtToTER > TER
bool isPseudoAccount(std::shared_ptr< SLE const > sleAcct)
TERSubset< CanCvtToNotTEC > NotTEC
State information when determining if a tx is likely to claim a fee.
State information when preflighting a tx.