Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Add node authority status metric #4699

Merged
merged 21 commits into from
Jan 13, 2022
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions node/core/chain-selection/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ polkadot-node-subsystem-util = { path = "../../subsystem-util" }
kvdb = "0.10.0"
thiserror = "1.0.30"
parity-scale-codec = "2"
sp-keystore = { git = "https://github.com/paritytech/substrate", branch = "master" }

[dev-dependencies]
polkadot-node-subsystem-test-helpers = { path = "../../subsystem-test-helpers" }
Expand Down
67 changes: 56 additions & 11 deletions node/core/chain-selection/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,9 @@ use polkadot_node_subsystem::{
messages::{ChainApiMessage, ChainSelectionMessage},
overseer, FromOverseer, OverseerSignal, SpawnedSubsystem, SubsystemContext, SubsystemError,
};
use polkadot_node_subsystem_util::Validator;
use polkadot_primitives::v1::{BlockNumber, ConsensusLog, Hash, Header};
use sp_keystore::SyncCryptoStorePtr;

use futures::{channel::oneshot, future::Either, prelude::*};
use kvdb::KeyValueDB;
Expand Down Expand Up @@ -307,13 +309,23 @@ pub struct Config {
pub struct ChainSelectionSubsystem {
config: Config,
db: Arc<dyn KeyValueDB>,
keystore: SyncCryptoStorePtr,
}

/// A structure to pass arguments to the subsystem main loop.
struct ChainSelectionSubsystemArgs<'a, Context, B> {
ctx: &'a mut Context,
backend: &'a mut B,
stagnant_check_interval: &'a StagnantCheckInterval,
clock: &'a (dyn Clock + Sync),
keystore: SyncCryptoStorePtr,
}

impl ChainSelectionSubsystem {
/// Create a new instance of the subsystem with the given config
/// and key-value store.
pub fn new(config: Config, db: Arc<dyn KeyValueDB>) -> Self {
ChainSelectionSubsystem { config, db }
pub fn new(config: Config, db: Arc<dyn KeyValueDB>, keystore: SyncCryptoStorePtr) -> Self {
ChainSelectionSubsystem { config, db, keystore }
}
}

Expand All @@ -329,9 +341,15 @@ where
);

SpawnedSubsystem {
future: run(ctx, backend, self.config.stagnant_check_interval, Box::new(SystemClock))
.map(Ok)
.boxed(),
future: run(
ctx,
backend,
self.config.stagnant_check_interval,
Box::new(SystemClock),
self.keystore,
)
.map(Ok)
.boxed(),
name: "chain-selection-subsystem",
}
}
Expand All @@ -342,13 +360,21 @@ async fn run<Context, B>(
mut backend: B,
stagnant_check_interval: StagnantCheckInterval,
clock: Box<dyn Clock + Send + Sync>,
keystore: SyncCryptoStorePtr,
) where
Context: SubsystemContext<Message = ChainSelectionMessage>,
Context: overseer::SubsystemContext<Message = ChainSelectionMessage>,
B: Backend,
{
loop {
let res = run_until_error(&mut ctx, &mut backend, &stagnant_check_interval, &*clock).await;
let res = run_until_error(ChainSelectionSubsystemArgs {
ctx: &mut ctx,
backend: &mut backend,
stagnant_check_interval: &stagnant_check_interval,
clock: &*clock,
keystore,
})
.await;
match res {
Err(e) => {
e.trace();
Expand All @@ -368,18 +394,20 @@ async fn run<Context, B>(
//
// A return value of `Ok` indicates that an exit should be made, while non-fatal errors
// lead to another call to this function.
async fn run_until_error<Context, B>(
ctx: &mut Context,
backend: &mut B,
stagnant_check_interval: &StagnantCheckInterval,
clock: &(dyn Clock + Sync),
async fn run_until_error<'a, Context, B>(
args: ChainSelectionSubsystemArgs<'a, Context, B>,
) -> Result<(), Error>
where
Context: SubsystemContext<Message = ChainSelectionMessage>,
Context: overseer::SubsystemContext<Message = ChainSelectionMessage>,
B: Backend,
{
let ChainSelectionSubsystemArgs { ctx, backend, stagnant_check_interval, clock, keystore } =
args;

let mut stagnant_check_stream = stagnant_check_interval.timeout_stream();
let mut is_validator = false;
let mut sender = ctx.sender().clone();
loop {
futures::select! {
msg = ctx.recv().fuse() => {
Expand All @@ -398,6 +426,23 @@ where
).await?;

backend.write(write_ops)?;

if is_validator != Validator::new(leaf.hash, keystore.clone(), &mut sender).await.is_ok() {
is_validator = !is_validator;
tracing::info!(
"👮 Authority status changed to `{}` at block #{}({})",
sandreim marked this conversation as resolved.
Show resolved Hide resolved
is_validator,
leaf.number,
leaf.hash
);
} else {
tracing::info!(
"🚔 Authority status is `{}` at block #{}({})",
is_validator,
leaf.number,
leaf.hash
);
sandreim marked this conversation as resolved.
Show resolved Hide resolved
}
}
}
FromOverseer::Signal(OverseerSignal::BlockFinalized(h, n)) => {
Expand Down
6 changes: 5 additions & 1 deletion node/service/src/overseer.rs
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,11 @@ where
authority_discovery_service.clone(),
Metrics::register(registry)?,
))
.chain_selection(ChainSelectionSubsystem::new(chain_selection_config, parachains_db))
.chain_selection(ChainSelectionSubsystem::new(
chain_selection_config,
parachains_db,
keystore.clone(),
))
.leaves(Vec::from_iter(
leaves
.into_iter()
Expand Down