1#include <xrpld/app/tx/detail/MPTokenAuthorize.h> 
    2#include <xrpld/app/tx/detail/MPTokenIssuanceCreate.h> 
    3#include <xrpld/app/tx/detail/VaultCreate.h> 
    5#include <xrpl/ledger/View.h> 
    6#include <xrpl/protocol/Asset.h> 
    7#include <xrpl/protocol/Feature.h> 
    8#include <xrpl/protocol/Indexes.h> 
    9#include <xrpl/protocol/Issue.h> 
   10#include <xrpl/protocol/MPTIssue.h> 
   11#include <xrpl/protocol/Protocol.h> 
   12#include <xrpl/protocol/SField.h> 
   13#include <xrpl/protocol/STNumber.h> 
   14#include <xrpl/protocol/TER.h> 
   15#include <xrpl/protocol/TxFlags.h> 
   41    if (
auto const withdrawalPolicy = ctx.
tx[~sfWithdrawalPolicy])
 
   48    if (
auto const domain = ctx.
tx[~sfDomainID])
 
   50        if (*domain == beast::zero)
 
   56    if (
auto const assetMax = ctx.
tx[~sfAssetsMaximum])
 
   58        if (*assetMax < beast::zero)
 
   62    if (
auto const metadata = ctx.
tx[~sfMPTokenMetadata])
 
   64        if (metadata->length() == 0 ||
 
   69    if (
auto const scale = ctx.
tx[~sfScale])
 
   71        auto const vaultAsset = ctx.
tx[sfAsset];
 
 
   92    auto const vaultAsset = ctx.
tx[sfAsset];
 
   93    auto const account = ctx.
tx[sfAccount];
 
  101    if (!vaultAsset.native())
 
  111    if (
auto const domain = ctx.
tx[~sfDomainID])
 
  113        auto const sleDomain =
 
  122        accountId == beast::zero)
 
 
  138    if (owner == 
nullptr)
 
  146    auto ownerCount = owner->at(sfOwnerCount);
 
  152        return maybePseudo.error();  
 
  153    auto& pseudo = *maybePseudo;
 
  154    auto pseudoId = pseudo->at(sfAccount);
 
  155    auto asset = tx[sfAsset];
 
  181            .account = pseudoId->value(),
 
  185            .metadata = tx[~sfMPTokenMetadata],
 
  186            .domainId = tx[~sfDomainID],
 
  189        return maybeShare.error();  
 
  190    auto const& mptIssuanceID = *maybeShare;
 
  192    vault->setFieldIssue(sfAsset, 
STIssue{sfAsset, asset});
 
  194    vault->at(sfSequence) = sequence;
 
  196    vault->at(sfAccount) = pseudoId;
 
  197    vault->at(sfAssetsTotal) = 
Number(0);
 
  198    vault->at(sfAssetsAvailable) = 
Number(0);
 
  199    vault->at(sfLossUnrealized) = 
Number(0);
 
  201    if (
auto value = tx[~sfAssetsMaximum])
 
  202        vault->at(sfAssetsMaximum) = *value;
 
  203    vault->at(sfShareMPTID) = mptIssuanceID;
 
  204    if (
auto value = tx[~sfData])
 
  205        vault->at(sfData) = *value;
 
  207    if (
auto value = tx[~sfWithdrawalPolicy])
 
  208        vault->at(sfWithdrawalPolicy) = *value;
 
  212        vault->at(sfScale) = scale;
 
 
beast::Journal const journal
 
virtual void insert(std::shared_ptr< SLE > const &sle)=0
Insert a new state SLE.
 
virtual std::shared_ptr< SLE > peek(Keylet const &k)=0
Prepare to modify the SLE associated with key.
 
A currency issued by an account.
 
static Expected< MPTID, TER > create(ApplyView &view, beast::Journal journal, MPTCreateArgs const &args)
 
virtual std::shared_ptr< SLE const > read(Keylet const &k) const =0
Return the state item associated with a key.
 
bool enabled(uint256 const &feature) const
Returns true if a feature is enabled.
 
bool isFieldPresent(SField const &field) const
 
std::uint32_t getFlags() const
 
std::uint32_t getSeqValue() const
Returns the first non-zero value of (Sequence, TicketSequence).
 
static XRPAmount calculateOwnerReserveFee(ReadView const &view, STTx const &tx)
 
static bool validDataLength(std::optional< Slice > const &slice, std::size_t maxLength)
 
static TER preclaim(PreclaimContext const &ctx)
 
static NotTEC preflight(PreflightContext const &ctx)
 
static bool checkExtraFeatures(PreflightContext const &ctx)
 
static std::uint32_t getFlagsMask(PreflightContext const &ctx)
 
static XRPAmount calculateBaseFee(ReadView const &view, STTx const &tx)
 
Keylet permissionedDomain(AccountID const &account, std::uint32_t seq) noexcept
 
Keylet vault(AccountID const &owner, std::uint32_t seq) noexcept
 
Keylet account(AccountID const &id) noexcept
AccountID root.
 
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
 
void adjustOwnerCount(ApplyView &view, std::shared_ptr< SLE > const &sle, std::int32_t amount, beast::Journal j)
Adjust the owner count up or down.
 
constexpr std::uint32_t const tfVaultPrivate
 
std::size_t constexpr maxDataPayloadLength
The maximum length of Data payload.
 
bool isFrozen(ReadView const &view, AccountID const &account, Currency const ¤cy, AccountID const &issuer)
 
std::size_t constexpr maxMPTokenMetadataLength
The maximum length of MPTokenMetadata.
 
Expected< std::shared_ptr< SLE >, TER > createPseudoAccount(ApplyView &view, uint256 const &pseudoOwnerKey, SField const &ownerField)
Create pseudo-account, storing pseudoOwnerKey into ownerField.
 
std::uint8_t constexpr vaultMaximumIOUScale
Maximum scale factor for a Vault.
 
@ tecINSUFFICIENT_RESERVE
 
TER addEmptyHolding(ApplyView &view, AccountID const &accountID, XRPAmount priorBalance, Issue const &issue, beast::Journal journal)
Any transactors that call addEmptyHolding() in doApply must call canAddHolding() in preflight with th...
 
constexpr std::uint32_t const tfVaultShareNonTransferable
 
AccountID pseudoAccountAddress(ReadView const &view, uint256 const &pseudoOwnerKey)
 
bool isTesSuccess(TER x) noexcept
 
std::uint8_t constexpr vaultStrategyFirstComeFirstServe
Vault withdrawal policies.
 
TER canAddHolding(ReadView const &view, Asset const &asset)
 
TER authorizeMPToken(ApplyView &view, XRPAmount const &priorBalance, MPTID const &mptIssuanceID, AccountID const &account, beast::Journal journal, std::uint32_t flags=0, std::optional< AccountID > holderID=std::nullopt)
 
constexpr std::uint32_t const tfVaultCreateMask
 
std::uint8_t constexpr vaultDefaultIOUScale
Default IOU scale factor for a Vault.
 
bool isPseudoAccount(std::shared_ptr< SLE const > sleAcct)
 
TER dirLink(ApplyView &view, AccountID const &owner, std::shared_ptr< SLE > &object)
 
State information when determining if a tx is likely to claim a fee.
 
State information when preflighting a tx.