1#include <xrpld/app/tx/detail/VaultSet.h> 
    3#include <xrpl/ledger/View.h> 
    4#include <xrpl/protocol/Asset.h> 
    5#include <xrpl/protocol/Feature.h> 
    6#include <xrpl/protocol/Indexes.h> 
    7#include <xrpl/protocol/SField.h> 
    8#include <xrpl/protocol/STNumber.h> 
    9#include <xrpl/protocol/TER.h> 
   10#include <xrpl/protocol/TxFlags.h> 
   24    if (ctx.
tx[sfVaultID] == beast::zero)
 
   26        JLOG(ctx.
j.
debug()) << 
"VaultSet: zero/empty vault ID.";
 
   30    if (
auto const data = ctx.
tx[~sfData])
 
   34            JLOG(ctx.
j.
debug()) << 
"VaultSet: invalid data payload size.";
 
   39    if (
auto const assetMax = ctx.
tx[~sfAssetsMaximum])
 
   41        if (*assetMax < beast::zero)
 
   43            JLOG(ctx.
j.
debug()) << 
"VaultSet: invalid max assets.";
 
   52        JLOG(ctx.
j.
debug()) << 
"VaultSet: nothing is being updated.";
 
 
   67    if (ctx.
tx[sfAccount] != vault->at(sfOwner))
 
   69        JLOG(ctx.
j.
debug()) << 
"VaultSet: account is not an owner.";
 
   73    auto const mptIssuanceID = (*vault)[sfShareMPTID];
 
   78        JLOG(ctx.
j.
error()) << 
"VaultSet: missing issuance of vault shares.";
 
   83    if (
auto const domain = ctx.
tx[~sfDomainID])
 
   88            JLOG(ctx.
j.
debug()) << 
"VaultSet: vault is not private";
 
   92        if (*domain != beast::zero)
 
   94            auto const sleDomain =
 
  105                << 
"VaultSet: issuance of vault shares is not private.";
 
 
  128    auto const mptIssuanceID = (*vault)[sfShareMPTID];
 
  133        JLOG(
j_.
error()) << 
"VaultSet: missing issuance of vault shares.";
 
  139    if (tx.isFieldPresent(sfData))
 
  140        vault->at(sfData) = tx[sfData];
 
  141    if (tx.isFieldPresent(sfAssetsMaximum))
 
  143        if (tx[sfAssetsMaximum] != 0 &&
 
  144            tx[sfAssetsMaximum] < *vault->at(sfAssetsTotal))
 
  146        vault->at(sfAssetsMaximum) = tx[sfAssetsMaximum];
 
  149    if (
auto const domainId = tx[~sfDomainID]; domainId)
 
  151        if (*domainId != beast::zero)
 
  158            sleIssuance->setFieldH256(sfDomainID, *domainId);
 
  160        else if (sleIssuance->isFieldPresent(sfDomainID))
 
  162            sleIssuance->makeFieldAbsent(sfDomainID);
 
 
virtual void update(std::shared_ptr< SLE > const &sle)=0
Indicate changes to a peeked SLE.
 
virtual std::shared_ptr< SLE > peek(Keylet const &k)=0
Prepare to modify the SLE associated with key.
 
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
 
static bool checkExtraFeatures(PreflightContext const &ctx)
 
static TER preclaim(PreclaimContext const &ctx)
 
static NotTEC preflight(PreflightContext const &ctx)
 
Keylet permissionedDomain(AccountID const &account, std::uint32_t seq) noexcept
 
Keylet mptIssuance(std::uint32_t seq, AccountID const &issuer) noexcept
 
Keylet vault(AccountID const &owner, std::uint32_t seq) noexcept
 
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
 
std::size_t constexpr maxDataPayloadLength
The maximum length of Data payload.
 
State information when determining if a tx is likely to claim a fee.
 
State information when preflighting a tx.