rippled
Loading...
Searching...
No Matches
MPTokenIssuanceSet.cpp
1//------------------------------------------------------------------------------
2/*
3 This file is part of rippled: https://github.com/ripple/rippled
4 Copyright (c) 2024 Ripple Labs Inc.
5
6 Permission to use, copy, modify, and/or distribute this software for any
7 purpose with or without fee is hereby granted, provided that the above
8 copyright notice and this permission notice appear in all copies.
9
10 THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17*/
18//==============================================================================
19
20#include <xrpld/app/tx/detail/MPTokenIssuanceSet.h>
21#include <xrpld/ledger/View.h>
22#include <xrpl/protocol/Feature.h>
23#include <xrpl/protocol/TxFlags.h>
24#include <xrpl/protocol/st.h>
25
26namespace ripple {
27
30{
31 if (!ctx.rules.enabled(featureMPTokensV1))
32 return temDISABLED;
33
34 if (auto const ret = preflight1(ctx); !isTesSuccess(ret))
35 return ret;
36
37 auto const txFlags = ctx.tx.getFlags();
38
39 // check flags
40 if (txFlags & tfMPTokenIssuanceSetMask)
41 return temINVALID_FLAG;
42 // fails if both flags are set
43 else if ((txFlags & tfMPTLock) && (txFlags & tfMPTUnlock))
44 return temINVALID_FLAG;
45
46 auto const accountID = ctx.tx[sfAccount];
47 auto const holderID = ctx.tx[~sfHolder];
48 if (holderID && accountID == holderID)
49 return temMALFORMED;
50
51 return preflight2(ctx);
52}
53
54TER
56{
57 // ensure that issuance exists
58 auto const sleMptIssuance =
59 ctx.view.read(keylet::mptIssuance(ctx.tx[sfMPTokenIssuanceID]));
60 if (!sleMptIssuance)
62
63 // if the mpt has disabled locking
64 if (!((*sleMptIssuance)[sfFlags] & lsfMPTCanLock))
65 return tecNO_PERMISSION;
66
67 // ensure it is issued by the tx submitter
68 if ((*sleMptIssuance)[sfIssuer] != ctx.tx[sfAccount])
69 return tecNO_PERMISSION;
70
71 if (auto const holderID = ctx.tx[~sfHolder])
72 {
73 // make sure holder account exists
74 if (!ctx.view.exists(keylet::account(*holderID)))
75 return tecNO_DST;
76
77 // the mptoken must exist
78 if (!ctx.view.exists(
79 keylet::mptoken(ctx.tx[sfMPTokenIssuanceID], *holderID)))
81 }
82
83 return tesSUCCESS;
84}
85
86TER
88{
89 auto const mptIssuanceID = ctx_.tx[sfMPTokenIssuanceID];
90 auto const txFlags = ctx_.tx.getFlags();
91 auto const holderID = ctx_.tx[~sfHolder];
93
94 if (holderID)
95 sle = view().peek(keylet::mptoken(mptIssuanceID, *holderID));
96 else
97 sle = view().peek(keylet::mptIssuance(mptIssuanceID));
98
99 if (!sle)
100 return tecINTERNAL;
101
102 std::uint32_t const flagsIn = sle->getFieldU32(sfFlags);
103 std::uint32_t flagsOut = flagsIn;
104
105 if (txFlags & tfMPTLock)
106 flagsOut |= lsfMPTLocked;
107 else if (txFlags & tfMPTUnlock)
108 flagsOut &= ~lsfMPTLocked;
109
110 if (flagsIn != flagsOut)
111 sle->setFieldU32(sfFlags, flagsOut);
112
113 view().update(sle);
114
115 return tesSUCCESS;
116}
117
118} // namespace ripple
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.
static TER preclaim(PreclaimContext const &ctx)
static NotTEC preflight(PreflightContext const &ctx)
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.
bool enabled(uint256 const &feature) const
Returns true if a feature is enabled.
Definition: Rules.cpp:122
std::uint32_t getFlags() const
Definition: STObject.cpp:507
ApplyView & view()
Definition: Transactor.h:107
ApplyContext & ctx_
Definition: Transactor.h:88
Keylet mptoken(MPTID const &issuanceID, AccountID const &holder) noexcept
Definition: Indexes.cpp:508
Keylet mptIssuance(std::uint32_t seq, AccountID const &issuer) noexcept
Definition: Indexes.cpp:494
Keylet account(AccountID const &id) noexcept
AccountID root.
Definition: Indexes.cpp:160
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition: algorithm.h:26
constexpr std::uint32_t const tfMPTokenIssuanceSetMask
Definition: TxFlags.h:157
constexpr std::uint32_t const tfMPTUnlock
Definition: TxFlags.h:156
@ lsfMPTCanLock
@ lsfMPTLocked
bool isTesSuccess(TER x)
Definition: TER.h:656
NotTEC preflight1(PreflightContext const &ctx)
Performs early sanity checks on the account and fee fields.
Definition: Transactor.cpp:82
NotTEC preflight2(PreflightContext const &ctx)
Checks whether the signature appears valid.
Definition: Transactor.cpp:134
@ tecNO_DST
Definition: TER.h:277
@ tecOBJECT_NOT_FOUND
Definition: TER.h:313
@ tecINTERNAL
Definition: TER.h:297
@ tecNO_PERMISSION
Definition: TER.h:292
constexpr std::uint32_t const tfMPTLock
Definition: TxFlags.h:155
@ tesSUCCESS
Definition: TER.h:242
TERSubset< CanCvtToNotTEC > NotTEC
Definition: TER.h:587
@ temMALFORMED
Definition: TER.h:87
@ temINVALID_FLAG
Definition: TER.h:111
@ temDISABLED
Definition: TER.h:114
State information when determining if a tx is likely to claim a fee.
Definition: Transactor.h:53
ReadView const & view
Definition: Transactor.h:56
State information when preflighting a tx.
Definition: Transactor.h:32