rippled
Loading...
Searching...
No Matches
LoadFeeTrack.h
1//------------------------------------------------------------------------------
2/*
3 This file is part of rippled: https://github.com/ripple/rippled
4 Copyright (c) 2012, 2013 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#ifndef RIPPLE_CORE_LOADFEETRACK_H_INCLUDED
21#define RIPPLE_CORE_LOADFEETRACK_H_INCLUDED
22
23#include <xrpl/basics/Log.h>
24#include <xrpl/beast/utility/Journal.h>
25#include <xrpl/protocol/XRPAmount.h>
26
27#include <algorithm>
28#include <cstdint>
29#include <mutex>
30
31namespace ripple {
32
33struct Fees;
34
44class LoadFeeTrack final
45{
46public:
56
57 ~LoadFeeTrack() = default;
58
59 void
61 {
62 JLOG(j_.trace()) << "setRemoteFee: " << f;
65 }
66
69 {
71 return remoteTxnLoadFee_;
72 }
73
76 {
78 return localTxnLoadFee_;
79 }
80
83 {
85 return clusterTxnLoadFee_;
86 }
87
90 {
91 return lftNormalFee;
92 }
93
101
111
112 void
114 {
115 JLOG(j_.trace()) << "setClusterFee: " << fee;
117 clusterTxnLoadFee_ = fee;
118 }
119
120 bool
122 bool
124
125 bool
127 {
129 return (raiseCount_ != 0) || (localTxnLoadFee_ != lftNormalFee);
130 }
131
132 bool
134 {
136 return (raiseCount_ != 0) || (localTxnLoadFee_ != lftNormalFee) ||
138 }
139
140private:
141 static std::uint32_t constexpr lftNormalFee =
142 256; // 256 is the minimum/normal load factor
144 4; // increase fee by 1/4
146 4; // decrease fee by 1/4
147 static std::uint32_t constexpr lftFeeMax = lftNormalFee * 1000000;
148
151
152 std::uint32_t localTxnLoadFee_; // Scale factor, lftNormalFee = normal fee
153 std::uint32_t remoteTxnLoadFee_; // Scale factor, lftNormalFee = normal fee
155 clusterTxnLoadFee_; // Scale factor, lftNormalFee = normal fee
157};
158
159//------------------------------------------------------------------------------
160
161// Scale using load as well as base rate
164 XRPAmount fee,
165 LoadFeeTrack const& feeTrack,
166 Fees const& fees,
167 bool bUnlimited);
168
169} // namespace ripple
170
171#endif
A generic endpoint for log messages.
Definition Journal.h:60
static Sink & getNullSink()
Returns a Sink which does nothing.
Stream trace() const
Severity stream access functions.
Definition Journal.h:322
Manages the current fee schedule.
std::uint32_t getClusterFee() const
static std::uint32_t constexpr lftFeeIncFraction
bool isLoadedCluster() const
beast::Journal const j_
static std::uint32_t constexpr lftNormalFee
std::uint32_t raiseCount_
void setRemoteFee(std::uint32_t f)
bool isLoadedLocal() const
std::uint32_t localTxnLoadFee_
std::uint32_t remoteTxnLoadFee_
std::uint32_t getLocalFee() const
std::uint32_t getLoadBase() const
LoadFeeTrack(beast::Journal journal=beast::Journal(beast::Journal::getNullSink()))
std::pair< std::uint32_t, std::uint32_t > getScalingFactors() const
std::uint32_t getRemoteFee() const
static std::uint32_t constexpr lftFeeDecFraction
std::uint32_t getLoadFactor() const
void setClusterFee(std::uint32_t fee)
std::uint32_t clusterTxnLoadFee_
static std::uint32_t constexpr lftFeeMax
T make_pair(T... args)
T max(T... args)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition algorithm.h:25
XRPAmount scaleFeeLoad(XRPAmount fee, LoadFeeTrack const &feeTrack, Fees const &fees, bool bUnlimited)
Reflects the fee settings for a particular ledger.