2016-01-09 18:50:45 +01:00
|
|
|
use client::BlockChainClient;
|
2016-01-10 15:08:57 +01:00
|
|
|
use util::network::{HandlerIo, PeerId, PacketId,};
|
|
|
|
use util::error::UtilError;
|
2016-01-09 18:50:45 +01:00
|
|
|
|
|
|
|
pub trait SyncIo {
|
|
|
|
fn disable_peer(&mut self, peer_id: &PeerId);
|
2016-01-10 15:08:57 +01:00
|
|
|
fn respond(&mut self, packet_id: PacketId, data: Vec<u8>) -> Result<(), UtilError>;
|
|
|
|
fn send(&mut self, peer_id: PeerId, packet_id: PacketId, data: Vec<u8>) -> Result<(), UtilError>;
|
2016-01-09 18:50:45 +01:00
|
|
|
fn chain<'s>(&'s mut self) -> &'s mut BlockChainClient;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct NetSyncIo<'s, 'h> where 'h:'s {
|
|
|
|
network: &'s mut HandlerIo<'h>,
|
|
|
|
chain: &'s mut BlockChainClient
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'s, 'h> NetSyncIo<'s, 'h> {
|
|
|
|
pub fn new(network: &'s mut HandlerIo<'h>, chain: &'s mut BlockChainClient) -> NetSyncIo<'s,'h> {
|
|
|
|
NetSyncIo {
|
|
|
|
network: network,
|
|
|
|
chain: chain,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'s, 'h> SyncIo for NetSyncIo<'s, 'h> {
|
|
|
|
fn disable_peer(&mut self, peer_id: &PeerId) {
|
|
|
|
self.network.disable_peer(*peer_id);
|
|
|
|
}
|
|
|
|
|
2016-01-10 15:08:57 +01:00
|
|
|
fn respond(&mut self, packet_id: PacketId, data: Vec<u8>) -> Result<(), UtilError>{
|
2016-01-09 18:50:45 +01:00
|
|
|
self.network.respond(packet_id, data)
|
|
|
|
}
|
|
|
|
|
2016-01-10 15:08:57 +01:00
|
|
|
fn send(&mut self, peer_id: PeerId, packet_id: PacketId, data: Vec<u8>) -> Result<(), UtilError>{
|
2016-01-09 18:50:45 +01:00
|
|
|
self.network.send(peer_id, packet_id, data)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn chain<'a>(&'a mut self) -> &'a mut BlockChainClient {
|
|
|
|
self.chain
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|