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