mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-19 18:45:52 +00:00
To protect the identity of UNL validators, the IP addresses are redacted from the log messages sent to the common Grafana instance. However, without such identifying information it is challenging to debug issues. This change adds a node's public key to logs to improve our ability to debug issues. Co-authored-by: Bart Thomee <11445373+bthomee@users.noreply.github.com>
118 lines
3.4 KiB
C++
118 lines
3.4 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of rippled: https://github.com/ripple/rippled
|
|
Copyright (c) 2012, 2013 Ripple Labs Inc.
|
|
|
|
Permission to use, copy, modify, and/or distribute this software for any
|
|
purpose with or without fee is hereby granted, provided that the above
|
|
copyright notice and this permission notice appear in all copies.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
//==============================================================================
|
|
|
|
#ifndef RIPPLE_RESOURCE_ENTRY_H_INCLUDED
|
|
#define RIPPLE_RESOURCE_ENTRY_H_INCLUDED
|
|
|
|
#include <xrpl/basics/DecayingSample.h>
|
|
#include <xrpl/beast/clock/abstract_clock.h>
|
|
#include <xrpl/beast/core/List.h>
|
|
#include <xrpl/beast/utility/instrumentation.h>
|
|
#include <xrpl/resource/detail/Key.h>
|
|
#include <xrpl/resource/detail/Tuning.h>
|
|
|
|
namespace ripple {
|
|
namespace Resource {
|
|
|
|
using clock_type = beast::abstract_clock<std::chrono::steady_clock>;
|
|
|
|
// An entry in the table
|
|
// VFALCO DEPRECATED using boost::intrusive list
|
|
struct Entry : public beast::List<Entry>::Node
|
|
{
|
|
Entry() = delete;
|
|
|
|
/**
|
|
@param now Construction time of Entry.
|
|
*/
|
|
explicit Entry(clock_type::time_point const now)
|
|
: refcount(0)
|
|
, local_balance(now)
|
|
, remote_balance(0)
|
|
, lastWarningTime()
|
|
, whenExpires()
|
|
{
|
|
}
|
|
|
|
std::string
|
|
to_string() const
|
|
{
|
|
return getFingerprint(key->address, publicKey);
|
|
}
|
|
|
|
/**
|
|
* Returns `true` if this connection should have no
|
|
* resource limits applied--it is still possible for certain RPC commands
|
|
* to be forbidden, but that depends on Role.
|
|
*/
|
|
bool
|
|
isUnlimited() const
|
|
{
|
|
return key->kind == kindUnlimited;
|
|
}
|
|
|
|
// Balance including remote contributions
|
|
int
|
|
balance(clock_type::time_point const now)
|
|
{
|
|
return local_balance.value(now) + remote_balance;
|
|
}
|
|
|
|
// Add a charge and return normalized balance
|
|
// including contributions from imports.
|
|
int
|
|
add(int charge, clock_type::time_point const now)
|
|
{
|
|
return local_balance.add(charge, now) + remote_balance;
|
|
}
|
|
|
|
// The public key of the peer
|
|
std::optional<PublicKey> publicKey;
|
|
|
|
// Back pointer to the map key (bit of a hack here)
|
|
Key const* key;
|
|
|
|
// Number of Consumer references
|
|
int refcount;
|
|
|
|
// Exponentially decaying balance of resource consumption
|
|
DecayingSample<decayWindowSeconds, clock_type> local_balance;
|
|
|
|
// Normalized balance contribution from imports
|
|
int remote_balance;
|
|
|
|
// Time of the last warning
|
|
clock_type::time_point lastWarningTime;
|
|
|
|
// For inactive entries, time after which this entry will be erased
|
|
clock_type::time_point whenExpires;
|
|
};
|
|
|
|
inline std::ostream&
|
|
operator<<(std::ostream& os, Entry const& v)
|
|
{
|
|
os << v.to_string();
|
|
return os;
|
|
}
|
|
|
|
} // namespace Resource
|
|
} // namespace ripple
|
|
|
|
#endif
|