Files
rippled/src/test/jtx/impl/token.cpp
Vito Tumas 5865bd017f refactor: Update transaction folder structure (#6483)
This change reorganizes the `tx/transactors` directory for consistency and discoverability. There are no behavioral changes, this is a pure refactor. Underscores were chosen as the way to separate multi-words as this is the more popular option in C++ projects.
 
Specific changes:
- Rename all subdirectories to lowercase/snake_case (`AMM` → `amm`, `Check` → `check`, `NFT` → `nft`, `PermissionedDomain` → `permissioned_domain`, etc.)
- Merge `AMM/` and `Offer/` into `dex/`, including `PermissionedDEXHelpers`
- Rename `MPT/` → `token/`, absorbing `SetTrust` and `Clawback`
- Move top-level transactors into named groups: `account/`, `bridge/`, `credentials/`, `did/`, `escrow/`, `oracle/`, `payment/`, `payment_channel/`, `system/`
- Update all include paths across the codebase and `transactions.macro`
2026-03-06 08:25:31 +00:00

217 lines
5.3 KiB
C++

#include <test/jtx/flags.h>
#include <test/jtx/token.h>
#include <xrpl/protocol/SField.h>
#include <xrpl/protocol/jss.h>
#include <xrpl/tx/transactors/nft/NFTokenMint.h>
namespace xrpl {
namespace test {
namespace jtx {
namespace token {
Json::Value
mint(jtx::Account const& account, std::uint32_t nfTokenTaxon)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenTaxon.jsonName] = nfTokenTaxon;
jv[sfTransactionType.jsonName] = jss::NFTokenMint;
return jv;
}
void
xferFee::operator()(Env& env, JTx& jt) const
{
jt.jv[sfTransferFee.jsonName] = xferFee_;
}
void
issuer::operator()(Env& env, JTx& jt) const
{
jt.jv[sfIssuer.jsonName] = issuer_;
}
void
uri::operator()(Env& env, JTx& jt) const
{
jt.jv[sfURI.jsonName] = uri_;
}
void
amount::operator()(Env& env, JTx& jt) const
{
jt.jv[sfAmount.jsonName] = amount_.getJson(JsonOptions::none);
}
uint256
getNextID(
jtx::Env const& env,
jtx::Account const& issuer,
std::uint32_t nfTokenTaxon,
std::uint16_t flags,
std::uint16_t xferFee)
{
// Get the nftSeq from the account root of the issuer.
std::uint32_t const nftSeq = {env.le(issuer)->at(~sfMintedNFTokens).value_or(0)};
return token::getID(env, issuer, nfTokenTaxon, nftSeq, flags, xferFee);
}
uint256
getID(
jtx::Env const& env,
jtx::Account const& issuer,
std::uint32_t nfTokenTaxon,
std::uint32_t nftSeq,
std::uint16_t flags,
std::uint16_t xferFee)
{
// We must add issuer's FirstNFTokenSequence to offset the starting NFT
// sequence number.
nftSeq += env.le(issuer)->at(~sfFirstNFTokenSequence).value_or(env.seq(issuer));
return xrpl::NFTokenMint::createNFTokenID(
flags, xferFee, issuer, nft::toTaxon(nfTokenTaxon), nftSeq);
}
Json::Value
burn(jtx::Account const& account, uint256 const& nftokenID)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenID.jsonName] = to_string(nftokenID);
jv[jss::TransactionType] = jss::NFTokenBurn;
return jv;
}
Json::Value
createOffer(jtx::Account const& account, uint256 const& nftokenID, STAmount const& amount)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenID.jsonName] = to_string(nftokenID);
jv[sfAmount.jsonName] = amount.getJson(JsonOptions::none);
jv[jss::TransactionType] = jss::NFTokenCreateOffer;
return jv;
}
void
owner::operator()(Env& env, JTx& jt) const
{
jt.jv[sfOwner.jsonName] = owner_;
}
void
expiration::operator()(Env& env, JTx& jt) const
{
jt.jv[sfExpiration.jsonName] = expires_;
}
void
destination::operator()(Env& env, JTx& jt) const
{
jt.jv[sfDestination.jsonName] = dest_;
}
template <typename T>
static Json::Value
cancelOfferImpl(jtx::Account const& account, T const& nftokenOffers)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
if (!empty(nftokenOffers))
{
jv[sfNFTokenOffers.jsonName] = Json::arrayValue;
for (uint256 const& nftokenOffer : nftokenOffers)
jv[sfNFTokenOffers.jsonName].append(to_string(nftokenOffer));
}
jv[jss::TransactionType] = jss::NFTokenCancelOffer;
return jv;
}
Json::Value
cancelOffer(jtx::Account const& account, std::initializer_list<uint256> const& nftokenOffers)
{
return cancelOfferImpl(account, nftokenOffers);
}
Json::Value
cancelOffer(jtx::Account const& account, std::vector<uint256> const& nftokenOffers)
{
return cancelOfferImpl(account, nftokenOffers);
}
void
rootIndex::operator()(Env& env, JTx& jt) const
{
jt.jv[sfRootIndex.jsonName] = rootIndex_;
}
Json::Value
acceptBuyOffer(jtx::Account const& account, uint256 const& offerIndex)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenBuyOffer.jsonName] = to_string(offerIndex);
jv[jss::TransactionType] = jss::NFTokenAcceptOffer;
return jv;
}
Json::Value
acceptSellOffer(jtx::Account const& account, uint256 const& offerIndex)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenSellOffer.jsonName] = to_string(offerIndex);
jv[jss::TransactionType] = jss::NFTokenAcceptOffer;
return jv;
}
Json::Value
brokerOffers(
jtx::Account const& account,
uint256 const& buyOfferIndex,
uint256 const& sellOfferIndex)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenBuyOffer.jsonName] = to_string(buyOfferIndex);
jv[sfNFTokenSellOffer.jsonName] = to_string(sellOfferIndex);
jv[jss::TransactionType] = jss::NFTokenAcceptOffer;
return jv;
}
void
brokerFee::operator()(Env& env, JTx& jt) const
{
jt.jv[sfNFTokenBrokerFee.jsonName] = brokerFee_.getJson(JsonOptions::none);
}
Json::Value
setMinter(jtx::Account const& account, jtx::Account const& minter)
{
Json::Value jt = fset(account, asfAuthorizedNFTokenMinter);
jt[sfNFTokenMinter.fieldName] = minter.human();
return jt;
}
Json::Value
clearMinter(jtx::Account const& account)
{
return fclear(account, asfAuthorizedNFTokenMinter);
}
Json::Value
modify(jtx::Account const& account, uint256 const& nftokenID)
{
Json::Value jv;
jv[sfAccount.jsonName] = account.human();
jv[sfNFTokenID.jsonName] = to_string(nftokenID);
jv[jss::TransactionType] = jss::NFTokenModify;
return jv;
}
} // namespace token
} // namespace jtx
} // namespace test
} // namespace xrpl