rippled
Loading...
Searching...
No Matches
CancelCheck.cpp
1//------------------------------------------------------------------------------
2/*
3 This file is part of rippled: https://github.com/ripple/rippled
4 Copyright (c) 2017 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/CancelCheck.h>
21
22#include <xrpld/app/ledger/Ledger.h>
23#include <xrpld/ledger/ApplyView.h>
24#include <xrpl/basics/Log.h>
25#include <xrpl/protocol/Feature.h>
26#include <xrpl/protocol/Indexes.h>
27#include <xrpl/protocol/STAccount.h>
28#include <xrpl/protocol/TER.h>
29#include <xrpl/protocol/TxFlags.h>
30
31namespace ripple {
32
35{
36 if (!ctx.rules.enabled(featureChecks))
37 return temDISABLED;
38
39 NotTEC const ret{preflight1(ctx)};
40 if (!isTesSuccess(ret))
41 return ret;
42
43 if (ctx.tx.getFlags() & tfUniversalMask)
44 {
45 // There are no flags (other than universal) for CreateCheck yet.
46 JLOG(ctx.j.warn()) << "Malformed transaction: Invalid flags set.";
47 return temINVALID_FLAG;
48 }
49
50 return preflight2(ctx);
51}
52
53TER
55{
56 auto const sleCheck = ctx.view.read(keylet::check(ctx.tx[sfCheckID]));
57 if (!sleCheck)
58 {
59 JLOG(ctx.j.warn()) << "Check does not exist.";
60 return tecNO_ENTRY;
61 }
62
63 using duration = NetClock::duration;
64 using timepoint = NetClock::time_point;
65 auto const optExpiry = (*sleCheck)[~sfExpiration];
66
67 // Expiration is defined in terms of the close time of the parent
68 // ledger, because we definitively know the time that it closed but
69 // we do not know the closing time of the ledger that is under
70 // construction.
71 if (!optExpiry ||
72 (ctx.view.parentCloseTime() < timepoint{duration{*optExpiry}}))
73 {
74 // If the check is not yet expired, then only the creator or the
75 // destination may cancel the check.
76 AccountID const acctId{ctx.tx[sfAccount]};
77 if (acctId != (*sleCheck)[sfAccount] &&
78 acctId != (*sleCheck)[sfDestination])
79 {
80 JLOG(ctx.j.warn()) << "Check is not expired and canceler is "
81 "neither check source nor destination.";
82 return tecNO_PERMISSION;
83 }
84 }
85 return tesSUCCESS;
86}
87
88TER
89CancelCheck::doApply()
90{
91 auto const sleCheck = view().peek(keylet::check(ctx_.tx[sfCheckID]));
92 if (!sleCheck)
93 {
94 // Error should have been caught in preclaim.
95 JLOG(j_.warn()) << "Check does not exist.";
96 return tecNO_ENTRY;
97 }
98
99 AccountID const srcId{sleCheck->getAccountID(sfAccount)};
100 AccountID const dstId{sleCheck->getAccountID(sfDestination)};
101 auto viewJ = ctx_.app.journal("View");
102
103 // If the check is not written to self (and it shouldn't be), remove the
104 // check from the destination account root.
105 if (srcId != dstId)
106 {
107 std::uint64_t const page{(*sleCheck)[sfDestinationNode]};
108 if (!view().dirRemove(
109 keylet::ownerDir(dstId), page, sleCheck->key(), true))
110 {
111 JLOG(j_.fatal()) << "Unable to delete check from destination.";
112 return tefBAD_LEDGER;
113 }
114 }
115 {
116 std::uint64_t const page{(*sleCheck)[sfOwnerNode]};
117 if (!view().dirRemove(
118 keylet::ownerDir(srcId), page, sleCheck->key(), true))
119 {
120 JLOG(j_.fatal()) << "Unable to delete check from owner.";
121 return tefBAD_LEDGER;
122 }
123 }
124
125 // If we succeeded, update the check owner's reserve.
126 auto const sleSrc = view().peek(keylet::account(srcId));
127 adjustOwnerCount(view(), sleSrc, -1, viewJ);
128
129 // Remove check from ledger.
130 view().erase(sleCheck);
131 return tesSUCCESS;
132}
133
134} // namespace ripple
Stream fatal() const
Definition: Journal.h:351
Stream warn() const
Definition: Journal.h:339
static TER preclaim(PreclaimContext const &ctx)
Definition: CancelCheck.cpp:54
static NotTEC preflight(PreflightContext const &ctx)
Definition: CancelCheck.cpp:34
std::chrono::time_point< NetClock > time_point
Definition: chrono.h:70
std::chrono::duration< rep, period > duration
Definition: chrono.h:69
virtual std::shared_ptr< SLE const > read(Keylet const &k) const =0
Return the state item associated with a key.
NetClock::time_point parentCloseTime() const
Returns the close time of the previous ledger.
Definition: ReadView.h:115
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
Keylet check(AccountID const &id, std::uint32_t seq) noexcept
A Check.
Definition: Indexes.cpp:312
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition: algorithm.h:26
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
@ tefBAD_LEDGER
Definition: TER.h:170
void adjustOwnerCount(ApplyView &view, std::shared_ptr< SLE > const &sle, std::int32_t amount, beast::Journal j)
Adjust the owner count up or down.
Definition: View.cpp:907
NotTEC preflight2(PreflightContext const &ctx)
Checks whether the signature appears valid.
Definition: Transactor.cpp:134
@ tecNO_ENTRY
Definition: TER.h:293
@ tecNO_PERMISSION
Definition: TER.h:292
@ tesSUCCESS
Definition: TER.h:242
constexpr std::uint32_t tfUniversalMask
Definition: TxFlags.h:62
TERSubset< CanCvtToTER > TER
Definition: TER.h:627
TERSubset< CanCvtToNotTEC > NotTEC
Definition: TER.h:587
@ temINVALID_FLAG
Definition: TER.h:111
@ temDISABLED
Definition: TER.h:114
uint256 key
Definition: Keylet.h:40
State information when determining if a tx is likely to claim a fee.
Definition: Transactor.h:53
ReadView const & view
Definition: Transactor.h:56
beast::Journal const j
Definition: Transactor.h:60
State information when preflighting a tx.
Definition: Transactor.h:32
beast::Journal const j
Definition: Transactor.h:38