|
xrpld
|
Slots is a container for validator's Slot and handles Slot update when a message is received from a validator. More...
#include <Slot.h>

Public Member Functions | |
| Slots (ServiceRegistry ®istry, SquelchHandler const &handler, Config const &config) | |
| ~Slots ()=default | |
| bool | baseSquelchReady () |
| Check if base squelching feature is enabled and ready. | |
| bool | reduceRelayReady () |
| Check if reduce_relay::kWaitOnBootup time passed since startup. | |
| void | updateSlotAndSquelch (uint256 const &key, PublicKey const &validator, id_t id, protocol::MessageType type) |
| Calls Slot::update of Slot associated with the validator, with a noop callback. | |
| void | updateSlotAndSquelch (uint256 const &key, PublicKey const &validator, id_t id, protocol::MessageType type, Slot< ClockType >::ignored_squelch_callback callback) |
| Calls Slot::update of Slot associated with the validator. | |
| void | deleteIdlePeers () |
| Check if peers stopped relaying messages and if slots stopped receiving messages from the validator. | |
| std::optional< std::uint16_t > | inState (PublicKey const &validator, PeerState state) const |
| Return number of peers in state. | |
| std::optional< std::uint16_t > | notInState (PublicKey const &validator, PeerState state) const |
| Return number of peers not in state. | |
| bool | inState (PublicKey const &validator, SlotState state) const |
| Return true if Slot is in state. | |
| std::set< id_t > | getSelected (PublicKey const &validator) |
| Get selected peers. | |
| std::unordered_map< Peer::id_t, std::tuple< PeerState, uint16_t, uint32_t, std::uint32_t > > | getPeers (PublicKey const &validator) |
| Get peers info. | |
| std::optional< SlotState > | getState (PublicKey const &validator) |
| Get Slot's state. | |
| void | deletePeer (id_t id, bool erase) |
| Called when a peer is deleted. | |
Private Types | |
| using | time_point = ClockType::time_point |
| using | id_t = Peer::id_t |
| using | messages |
Private Member Functions | |
| bool | addPeerMessage (uint256 const &key, id_t id) |
| Add message/peer if have not seen this message from the peer. | |
Private Attributes | |
| std::atomic_bool | reduceRelayReady_ {false} |
| hash_map< PublicKey, Slot< ClockType > > | slots_ |
| SquelchHandler const & | handler_ |
| Logs & | logs_ |
| beast::Journal const | journal_ |
| bool const | baseSquelchEnabled_ |
| uint16_t const | maxSelectedPeers_ |
Static Private Attributes | |
| static messages | peersWithMessage {beast::getAbstractClock<ClockType>()} |
Slots is a container for validator's Slot and handles Slot update when a message is received from a validator.
It also handles Slot aging and checks for peers which are disconnected or stopped relaying the messages.
Definition at line 527 of file overlay/Slot.h.
|
private |
Definition at line 529 of file overlay/Slot.h.
|
private |
Definition at line 530 of file overlay/Slot.h.
|
private |
Definition at line 531 of file overlay/Slot.h.
| xrpl::reduce_relay::Slots< ClockType >::Slots | ( | ServiceRegistry & | registry, |
| SquelchHandler const & | handler, | ||
| Config const & | config ) |
| registry | The service registry. |
| handler | Squelch/unsquelch implementation |
| config | reference to the global config |
Definition at line 543 of file overlay/Slot.h.
|
default |
| bool xrpl::reduce_relay::Slots< ClockType >::baseSquelchReady | ( | ) |
Check if base squelching feature is enabled and ready.
Definition at line 555 of file overlay/Slot.h.
| bool xrpl::reduce_relay::Slots< ClockType >::reduceRelayReady | ( | ) |
Check if reduce_relay::kWaitOnBootup time passed since startup.
Definition at line 562 of file overlay/Slot.h.
| void xrpl::reduce_relay::Slots< ClockType >::updateSlotAndSquelch | ( | uint256 const & | key, |
| PublicKey const & | validator, | ||
| id_t | id, | ||
| protocol::MessageType | type ) |
Calls Slot::update of Slot associated with the validator, with a noop callback.
| key | Message's hash |
| validator | Validator's public key |
| id | Peer's id which received the message |
| type | Received protocol message type |
Definition at line 581 of file overlay/Slot.h.
| void xrpl::reduce_relay::Slots< ClockType >::updateSlotAndSquelch | ( | uint256 const & | key, |
| PublicKey const & | validator, | ||
| id_t | id, | ||
| protocol::MessageType | type, | ||
| Slot< ClockType >::ignored_squelch_callback | callback ) |
Calls Slot::update of Slot associated with the validator.
| key | Message's hash |
| validator | Validator's public key |
| id | Peer's id which received the message |
| type | Received protocol message type |
| callback | A callback to report ignored validations |
Definition at line 739 of file overlay/Slot.h.
| void xrpl::reduce_relay::Slots< ClockType >::deleteIdlePeers | ( | ) |
Check if peers stopped relaying messages and if slots stopped receiving messages from the validator.
Definition at line 777 of file overlay/Slot.h.
|
nodiscard |
Return number of peers in state.
Definition at line 613 of file overlay/Slot.h.
|
nodiscard |
Return number of peers not in state.
Definition at line 623 of file overlay/Slot.h.
|
nodiscard |
Return true if Slot is in state.
Definition at line 633 of file overlay/Slot.h.
| std::set< id_t > xrpl::reduce_relay::Slots< ClockType >::getSelected | ( | PublicKey const & | validator | ) |
Get selected peers.
Definition at line 643 of file overlay/Slot.h.
| std::unordered_map< Peer::id_t, std::tuple< PeerState, uint16_t, uint32_t, std::uint32_t > > xrpl::reduce_relay::Slots< ClockType >::getPeers | ( | PublicKey const & | validator | ) |
Get peers info.
Return map of peer's state, count, and squelch expiration milliseconds.
Definition at line 655 of file overlay/Slot.h.
| std::optional< SlotState > xrpl::reduce_relay::Slots< ClockType >::getState | ( | PublicKey const & | validator | ) |
Get Slot's state.
Definition at line 665 of file overlay/Slot.h.
| void xrpl::reduce_relay::Slots< ClockType >::deletePeer | ( | id_t | id, |
| bool | erase ) |
Called when a peer is deleted.
If the peer was selected to be the source of messages from the validator then squelched peers have to be unsquelched.
Definition at line 769 of file overlay/Slot.h.
|
private |
Add message/peer if have not seen this message from the peer.
A message is aged after IDLED seconds. Return true if added
Definition at line 708 of file overlay/Slot.h.
|
private |
Definition at line 689 of file overlay/Slot.h.
|
private |
Definition at line 691 of file overlay/Slot.h.
|
private |
Definition at line 692 of file overlay/Slot.h.
|
private |
Definition at line 693 of file overlay/Slot.h.
|
private |
Definition at line 694 of file overlay/Slot.h.
|
private |
Definition at line 696 of file overlay/Slot.h.
|
private |
Definition at line 697 of file overlay/Slot.h.
|
staticprivate |
Definition at line 703 of file overlay/Slot.h.