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
22#include <xrpl/protocol/Feature.h>
23#include <xrpl/protocol/TxFlags.h>
24
25namespace ripple {
26
29{
30 if (!ctx.rules.enabled(featureMPTokensV1))
31 return temDISABLED;
32
33 if (auto const ret = preflight1(ctx); !isTesSuccess(ret))
34 return ret;
35
36 auto const txFlags = ctx.tx.getFlags();
37
38 // check flags
39 if (txFlags & tfMPTokenIssuanceSetMask)
40 return temINVALID_FLAG;
41 // fails if both flags are set
42 else if ((txFlags & tfMPTLock) && (txFlags & tfMPTUnlock))
43 return temINVALID_FLAG;
44
45 auto const accountID = ctx.tx[sfAccount];
46 auto const holderID = ctx.tx[~sfHolder];
47 if (holderID && accountID == holderID)
48 return temMALFORMED;
49
50 return preflight2(ctx);
51}
52
53TER
55{
56 // ensure that issuance exists
57 auto const sleMptIssuance =
58 ctx.view.read(keylet::mptIssuance(ctx.tx[sfMPTokenIssuanceID]));
59 if (!sleMptIssuance)
61
62 // if the mpt has disabled locking
63 if (!((*sleMptIssuance)[sfFlags] & lsfMPTCanLock))
64 return tecNO_PERMISSION;
65
66 // ensure it is issued by the tx submitter
67 if ((*sleMptIssuance)[sfIssuer] != ctx.tx[sfAccount])
68 return tecNO_PERMISSION;
69
70 if (auto const holderID = ctx.tx[~sfHolder])
71 {
72 // make sure holder account exists
73 if (!ctx.view.exists(keylet::account(*holderID)))
74 return tecNO_DST;
75
76 // the mptoken must exist
77 if (!ctx.view.exists(
78 keylet::mptoken(ctx.tx[sfMPTokenIssuanceID], *holderID)))
80 }
81
82 return tesSUCCESS;
83}
84
85TER
87{
88 auto const mptIssuanceID = ctx_.tx[sfMPTokenIssuanceID];
89 auto const txFlags = ctx_.tx.getFlags();
90 auto const holderID = ctx_.tx[~sfHolder];
92
93 if (holderID)
94 sle = view().peek(keylet::mptoken(mptIssuanceID, *holderID));
95 else
96 sle = view().peek(keylet::mptIssuance(mptIssuanceID));
97
98 if (!sle)
99 return tecINTERNAL;
100
101 std::uint32_t const flagsIn = sle->getFieldU32(sfFlags);
102 std::uint32_t flagsOut = flagsIn;
103
104 if (txFlags & tfMPTLock)
105 flagsOut |= lsfMPTLocked;
106 else if (txFlags & tfMPTUnlock)
107 flagsOut &= ~lsfMPTLocked;
108
109 if (flagsIn != flagsOut)
110 sle->setFieldU32(sfFlags, flagsOut);
111
112 view().update(sle);
113
114 return tesSUCCESS;
115}
116
117} // 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:130
std::uint32_t getFlags() const
Definition: STObject.cpp:537
ApplyView & view()
Definition: Transactor.h:108
ApplyContext & ctx_
Definition: Transactor.h:89
Keylet mptoken(MPTID const &issuanceID, AccountID const &holder) noexcept
Definition: Indexes.cpp:523
Keylet mptIssuance(std::uint32_t seq, AccountID const &issuer) noexcept
Definition: Indexes.cpp:509
Keylet account(AccountID const &id) noexcept
AccountID root.
Definition: Indexes.cpp:175
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:54
ReadView const & view
Definition: Transactor.h:57
State information when preflighting a tx.
Definition: Transactor.h:33