mirror of
https://github.com/hinto-janai/cuprate.git
synced 2025-01-09 12:29:41 +00:00
4b93dbec4c
Some checks failed
Audit / audit (push) Has been cancelled
Deny / audit (push) Has been cancelled
CI / fmt (push) Has been cancelled
CI / typo (push) Has been cancelled
CI / ci (macos-latest, stable, bash) (push) Has been cancelled
CI / ci (ubuntu-latest, stable, bash) (push) Has been cancelled
CI / ci (windows-latest, stable-x86_64-pc-windows-gnu, msys2 {0}) (push) Has been cancelled
* rename all directories and crates * fix all `use` * fix doc link * `dandelion/` -> `dandelion-tower/` * fix epee-encoding test * fix `json-rpc` * fix pruning * crate import fixes * fix leftover merge conflicts * fix `epee-encoding`
132 lines
4.7 KiB
Rust
132 lines
4.7 KiB
Rust
use cuprate_pruning::{PruningError, PruningSeed};
|
|
use cuprate_wire::{CoreSyncData, PeerListEntryBase};
|
|
|
|
use crate::{
|
|
client::InternalPeerID, handles::ConnectionHandle, NetZoneAddress, NetworkAddressIncorrectZone,
|
|
NetworkZone,
|
|
};
|
|
|
|
pub enum PeerSyncRequest<N: NetworkZone> {
|
|
/// Request some peers to sync from.
|
|
///
|
|
/// This takes in the current cumulative difficulty of our chain and will return peers that
|
|
/// claim to have a higher cumulative difficulty.
|
|
PeersToSyncFrom {
|
|
current_cumulative_difficulty: u128,
|
|
block_needed: Option<u64>,
|
|
},
|
|
/// Add/update a peers core sync data to the sync state service.
|
|
IncomingCoreSyncData(InternalPeerID<N::Addr>, ConnectionHandle, CoreSyncData),
|
|
}
|
|
|
|
pub enum PeerSyncResponse<N: NetworkZone> {
|
|
/// The return value of [`PeerSyncRequest::PeersToSyncFrom`].
|
|
PeersToSyncFrom(Vec<InternalPeerID<N::Addr>>),
|
|
/// A generic ok response.
|
|
Ok,
|
|
}
|
|
|
|
pub struct CoreSyncDataRequest;
|
|
|
|
pub struct CoreSyncDataResponse(pub CoreSyncData);
|
|
|
|
#[derive(Debug, Copy, Clone, Eq, PartialEq)]
|
|
#[cfg_attr(
|
|
feature = "borsh",
|
|
derive(borsh::BorshSerialize, borsh::BorshDeserialize)
|
|
)]
|
|
pub struct ZoneSpecificPeerListEntryBase<A: NetZoneAddress> {
|
|
pub adr: A,
|
|
pub id: u64,
|
|
pub last_seen: i64,
|
|
pub pruning_seed: PruningSeed,
|
|
pub rpc_port: u16,
|
|
pub rpc_credits_per_hash: u32,
|
|
}
|
|
|
|
impl<A: NetZoneAddress> From<ZoneSpecificPeerListEntryBase<A>> for cuprate_wire::PeerListEntryBase {
|
|
fn from(value: ZoneSpecificPeerListEntryBase<A>) -> Self {
|
|
Self {
|
|
adr: value.adr.into(),
|
|
id: value.id,
|
|
last_seen: value.last_seen,
|
|
pruning_seed: value.pruning_seed.compress(),
|
|
rpc_port: value.rpc_port,
|
|
rpc_credits_per_hash: value.rpc_credits_per_hash,
|
|
}
|
|
}
|
|
}
|
|
|
|
#[derive(Debug, thiserror::Error)]
|
|
pub enum PeerListConversionError {
|
|
#[error("Address is in incorrect zone")]
|
|
Address(#[from] NetworkAddressIncorrectZone),
|
|
#[error("Pruning seed error: {0}")]
|
|
PruningSeed(#[from] PruningError),
|
|
}
|
|
|
|
impl<A: NetZoneAddress> TryFrom<cuprate_wire::PeerListEntryBase>
|
|
for ZoneSpecificPeerListEntryBase<A>
|
|
{
|
|
type Error = PeerListConversionError;
|
|
|
|
fn try_from(value: PeerListEntryBase) -> Result<Self, Self::Error> {
|
|
Ok(Self {
|
|
adr: value.adr.try_into()?,
|
|
id: value.id,
|
|
last_seen: value.last_seen,
|
|
pruning_seed: PruningSeed::decompress_p2p_rules(value.pruning_seed)?,
|
|
rpc_port: value.rpc_port,
|
|
rpc_credits_per_hash: value.rpc_credits_per_hash,
|
|
})
|
|
}
|
|
}
|
|
|
|
pub enum AddressBookRequest<Z: NetworkZone> {
|
|
/// Tells the address book that we have connected or received a connection from a peer.
|
|
NewConnection {
|
|
/// The [`InternalPeerID`] of this connection.
|
|
internal_peer_id: InternalPeerID<Z::Addr>,
|
|
/// The public address of the peer, if this peer has a reachable public address.
|
|
public_address: Option<Z::Addr>,
|
|
/// The [`ConnectionHandle`] to this peer.
|
|
handle: ConnectionHandle,
|
|
/// An ID the peer assigned itself.
|
|
id: u64,
|
|
/// The peers [`PruningSeed`].
|
|
pruning_seed: PruningSeed,
|
|
/// The peers rpc port.
|
|
rpc_port: u16,
|
|
/// The peers rpc credits per hash
|
|
rpc_credits_per_hash: u32,
|
|
},
|
|
/// Tells the address book about a peer list received from a peer.
|
|
IncomingPeerList(Vec<ZoneSpecificPeerListEntryBase<Z::Addr>>),
|
|
/// Takes a random white peer from the peer list. If height is specified
|
|
/// then the peer list should retrieve a peer that should have a full
|
|
/// block at that height according to it's pruning seed
|
|
TakeRandomWhitePeer { height: Option<u64> },
|
|
/// Takes a random gray peer from the peer list. If height is specified
|
|
/// then the peer list should retrieve a peer that should have a full
|
|
/// block at that height according to it's pruning seed
|
|
TakeRandomGrayPeer { height: Option<u64> },
|
|
/// Takes a random peer from the peer list. If height is specified
|
|
/// then the peer list should retrieve a peer that should have a full
|
|
/// block at that height according to it's pruning seed.
|
|
///
|
|
/// The address book will look in the white peer list first, then the gray
|
|
/// one if no peer is found.
|
|
TakeRandomPeer { height: Option<u64> },
|
|
/// Gets the specified number of white peers, or less if we don't have enough.
|
|
GetWhitePeers(usize),
|
|
/// Checks if the given peer is banned.
|
|
IsPeerBanned(Z::Addr),
|
|
}
|
|
|
|
pub enum AddressBookResponse<Z: NetworkZone> {
|
|
Ok,
|
|
Peer(ZoneSpecificPeerListEntryBase<Z::Addr>),
|
|
Peers(Vec<ZoneSpecificPeerListEntryBase<Z::Addr>>),
|
|
/// Contains `true` if the peer is banned.
|
|
IsPeerBanned(bool),
|
|
}
|