4#include <xrpl/protocol/STTx.h>
5#include <xrpl/protocol/STParsedJSON.h>
6#include <xrpl/protocol/jss.h>
7#include <xrpl/protocol_autogen/TransactionBase.h>
8#include <xrpl/protocol_autogen/TransactionBuilderBase.h>
9#include <xrpl/json/json_value.h>
56 SF_AMOUNT::type::value_type
59 return this->
tx_->at(sfAmount);
72 return this->
tx_->at(sfHolder);
85 return this->
tx_->isFieldPresent(sfHolder);
122 if (tx->getTxnType() != ttCLAWBACK)
163 sign(publicKey, secretKey);
Builder for Clawback transactions.
ClawbackBuilder & setHolder(std::decay_t< typename SF_ACCOUNT::type::value_type > const &value)
Set sfHolder (soeOPTIONAL)
ClawbackBuilder & setAmount(std::decay_t< typename SF_AMOUNT::type::value_type > const &value)
Transaction-specific field setters.
ClawbackBuilder(SF_ACCOUNT::type::value_type account, std::decay_t< typename SF_AMOUNT::type::value_type > const &amount, std::optional< SF_UINT32::type::value_type > sequence=std::nullopt, std::optional< SF_AMOUNT::type::value_type > fee=std::nullopt)
Construct a new ClawbackBuilder with required fields.
ClawbackBuilder(std::shared_ptr< STTx const > tx)
Construct a ClawbackBuilder from an existing STTx object.
Clawback build(PublicKey const &publicKey, SecretKey const &secretKey)
Build and return the Clawback wrapper.
static constexpr xrpl::TxType txType
bool hasHolder() const
Check if sfHolder is present.
SF_AMOUNT::type::value_type getAmount() const
Get sfAmount (soeREQUIRED)
protocol_autogen::Optional< SF_ACCOUNT::type::value_type > getHolder() const
Get sfHolder (soeOPTIONAL)
Clawback(std::shared_ptr< STTx const > tx)
Construct a Clawback transaction wrapper from an existing STTx object.
Base class for all transaction wrapper types.
std::shared_ptr< STTx const > tx_
The underlying transaction object being wrapped.
Base class for all transaction builders.
ClawbackBuilder & sign(PublicKey const &publicKey, SecretKey const &secretKey)
Sign the transaction with the given keys.
TxType
Transaction type identifiers.