rippled
|
Supports data retrieval by managing a set of peers. More...
Public Member Functions | |
virtual | ~PeerSet ()=default |
virtual void | addPeers (std::size_t limit, std::function< bool(std::shared_ptr< Peer > const &)> hasItem, std::function< void(std::shared_ptr< Peer > const &)> onPeerAdded)=0 |
Try add more peers. More... | |
template<typename MessageType > | |
void | sendRequest (MessageType const &message, std::shared_ptr< Peer > const &peer) |
send a message More... | |
virtual void | sendRequest (::google::protobuf::Message const &message, protocol::MessageType type, std::shared_ptr< Peer > const &peer)=0 |
virtual const std::set< Peer::id_t > & | getPeerIds () const =0 |
get the set of ids of previously added peers More... | |
Supports data retrieval by managing a set of peers.
When desired data (such as a ledger or a transaction set) is missing locally it can be obtained by querying connected peers. This class manages common aspects of the retrieval. Callers maintain the set by adding and removing peers depending on whether the peers have useful information.
The data is represented by its hash.
|
virtualdefault |
|
pure virtual |
Try add more peers.
limit | number of peers to add |
hasItem | callback that helps to select peers |
onPeerAdded | callback called when a peer is added |
Implemented in ripple::test::TestPeerSet, ripple::DummyPeerSet, and ripple::PeerSetImpl.
void ripple::PeerSet::sendRequest | ( | MessageType const & | message, |
std::shared_ptr< Peer > const & | peer | ||
) |
|
pure virtual |
Implemented in ripple::test::TestPeerSet, ripple::DummyPeerSet, and ripple::PeerSetImpl.
|
pure virtual |
get the set of ids of previously added peers
Implemented in ripple::test::TestPeerSet, ripple::DummyPeerSet, and ripple::PeerSetImpl.