mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-06-01 04:31:02 +00:00
ead6815ae4
* Make WASM browser thing compile * Fix * updated exit-future (github repo) * Switch to broadcast crate * Migrate client/cli * Switch exit-future to modernize branch * Small changes * Switch to cargo version and fix fg tests * fix basic-authorship * Fix crash on grafana macro * Fix grafana macro * Switch node python version * Disable record_metrics_slice in grafana macro on wasm * Update client/grafana-data-source/src/lib.rs * Revert "Update client/grafana-data-source/src/lib.rs" This reverts commit 888009a8e0b7051bd4bfbbfdb0448bcf2e2aae93. * Add wasm support for state machine * Switch to my own libp2p version * Revert "Switch to my own libp2p version" This reverts commit ce613871b59264b3165b45c37943e6560240daa7. * Revert "Add wasm support for state machine" This reverts commit de7eaa0694d9534fc3b164621737968e9a6a7c5f. * Add sc-browser * Squash * remove sc-browser * Fix keystore on wasm * stubs for removed functions to make env compatible with old runtimes * Add test (that doesn't work) * Fix build scripts * Revert basic-authorship due to no panics * Revert cli/informant * Revert consensus * revert offchain * Update utils/browser/Cargo.toml Co-Authored-By: Benjamin Kampmann <ben@gnunicorn.org> * export console functions * Add new chainspec * Fix ws in chain spec * revert chainspec * Fix chainspec * Use an Option<PathBuf> in keystore instead of cfg flags * Remove crud * Only use wasm-timer for instant and systemtime * Remove telemetry changes * Assuming this is ok * Add a KeystoreConfig * Add stubs back in * Update libp2p * Revert "Add stubs back in" This reverts commit 4690cf1882aa0f99f7f00a58c4080c8aa9b77c36. * Remove commented js again * Bump kvdb-web version * Fix cli * Switch branch on futures-timer * Fix tests * Remove sc-client test build in check-web-wasm because there isn't a good way to build futures-timer with wasm-bindgen support in the build * Remove more things ^^ * Switch branch on futures-timer back * Put DB io stats behind a cfg flag * Fix things * Don't timeout transports on wasm * Update branch of futures-timer and fix bad merge * Spawn informant * Fix network test * Fix delay resets * Changes * Fix tests * use wasm_timer for transaction pool * Fixes * Switch futures-timer to crates * Only diagnose futures on native * Fix sc-network-test tests * Select log level in js * Fix syncing ;^) * Allow disabling colours in the informant * Use OutputFormat enum for informant * MallocSizeOf impl on transaction pool broke stuff because wasm_timer::Instant doesnt impl it so just revert the transaction pool to master * Update futures-diagnose * Revert "MallocSizeOf impl on transaction pool broke stuff because wasm_timer::Instant doesnt impl it so just revert the transaction pool to master" This reverts commit baa4ffc94fd968b6660a2c17ba8113e06af15548. * Pass whole chain spec in start_client * Get Instant::now to work in transaction pool again * Informant dep reordering Co-authored-by: Pierre Krieger <pierre.krieger1708@gmail.com> Co-authored-by: Bastian Köcher <bkchr@users.noreply.github.com> Co-authored-by: Svyatoslav Nikolsky <svyatonik@gmail.com> Co-authored-by: Benjamin Kampmann <ben.kampmann@googlemail.com> Co-authored-by: Demi Obenour <48690212+DemiMarie-parity@users.noreply.github.com>
112 lines
3.9 KiB
Rust
112 lines
3.9 KiB
Rust
// Copyright 2019-2020 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Substrate is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Periodic rebroadcast of neighbor packets.
|
|
|
|
use futures_timer::Delay;
|
|
use futures::{channel::mpsc, future::{FutureExt as _}, prelude::*, ready, stream::Stream};
|
|
use log::debug;
|
|
use std::{pin::Pin, task::{Context, Poll}, time::Duration};
|
|
|
|
use sc_network::PeerId;
|
|
use sp_runtime::traits::{NumberFor, Block as BlockT};
|
|
use super::gossip::{NeighborPacket, GossipMessage};
|
|
|
|
// How often to rebroadcast, in cases where no new packets are created.
|
|
const REBROADCAST_AFTER: Duration = Duration::from_secs(2 * 60);
|
|
|
|
/// A sender used to send neighbor packets to a background job.
|
|
#[derive(Clone)]
|
|
pub(super) struct NeighborPacketSender<B: BlockT>(
|
|
mpsc::UnboundedSender<(Vec<PeerId>, NeighborPacket<NumberFor<B>>)>
|
|
);
|
|
|
|
impl<B: BlockT> NeighborPacketSender<B> {
|
|
/// Send a neighbor packet for the background worker to gossip to peers.
|
|
pub fn send(
|
|
&self,
|
|
who: Vec<sc_network::PeerId>,
|
|
neighbor_packet: NeighborPacket<NumberFor<B>>,
|
|
) {
|
|
if let Err(err) = self.0.unbounded_send((who, neighbor_packet)) {
|
|
debug!(target: "afg", "Failed to send neighbor packet: {:?}", err);
|
|
}
|
|
}
|
|
}
|
|
|
|
/// NeighborPacketWorker is listening on a channel for new neighbor packets being produced by
|
|
/// components within `finality-grandpa` and forwards those packets to the underlying
|
|
/// `NetworkEngine` through the `NetworkBridge` that it is being polled by (see `Stream`
|
|
/// implementation). Periodically it sends out the last packet in cases where no new ones arrive.
|
|
pub(super) struct NeighborPacketWorker<B: BlockT> {
|
|
last: Option<(Vec<PeerId>, NeighborPacket<NumberFor<B>>)>,
|
|
delay: Delay,
|
|
rx: mpsc::UnboundedReceiver<(Vec<PeerId>, NeighborPacket<NumberFor<B>>)>,
|
|
}
|
|
|
|
impl<B: BlockT> Unpin for NeighborPacketWorker<B> {}
|
|
|
|
impl<B: BlockT> NeighborPacketWorker<B> {
|
|
pub(super) fn new() -> (Self, NeighborPacketSender<B>){
|
|
let (tx, rx) = mpsc::unbounded::<(Vec<PeerId>, NeighborPacket<NumberFor<B>>)>();
|
|
let delay = Delay::new(REBROADCAST_AFTER);
|
|
|
|
(NeighborPacketWorker {
|
|
last: None,
|
|
delay,
|
|
rx,
|
|
}, NeighborPacketSender(tx))
|
|
}
|
|
}
|
|
|
|
impl <B: BlockT> Stream for NeighborPacketWorker<B> {
|
|
type Item = (Vec<PeerId>, GossipMessage<B>);
|
|
|
|
fn poll_next(mut self: Pin<&mut Self>, cx: &mut Context) -> Poll<Option<Self::Item>>
|
|
{
|
|
let this = &mut *self;
|
|
match this.rx.poll_next_unpin(cx) {
|
|
Poll::Ready(None) => return Poll::Ready(None),
|
|
Poll::Ready(Some((to, packet))) => {
|
|
this.delay.reset(REBROADCAST_AFTER);
|
|
this.last = Some((to.clone(), packet.clone()));
|
|
|
|
return Poll::Ready(Some((to, GossipMessage::<B>::from(packet.clone()))));
|
|
}
|
|
// Don't return yet, maybe the timer fired.
|
|
Poll::Pending => {},
|
|
};
|
|
|
|
ready!(this.delay.poll_unpin(cx));
|
|
|
|
// Getting this far here implies that the timer fired.
|
|
|
|
this.delay.reset(REBROADCAST_AFTER);
|
|
|
|
// Make sure the underlying task is scheduled for wake-up.
|
|
//
|
|
// Note: In case poll_unpin is called after the resetted delay fires again, this
|
|
// will drop one tick. Deemed as very unlikely and also not critical.
|
|
while let Poll::Ready(()) = this.delay.poll_unpin(cx) {};
|
|
|
|
if let Some((ref to, ref packet)) = this.last {
|
|
return Poll::Ready(Some((to.clone(), GossipMessage::<B>::from(packet.clone()))));
|
|
}
|
|
|
|
return Poll::Pending;
|
|
}
|
|
}
|