mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-24 03:26:19 +00:00
Configure node for a multi-node testnet
This commit is contained in:
parent
86aaadaea0
commit
e3fc3f28fb
9 changed files with 65 additions and 31 deletions
3
Cargo.lock
generated
3
Cargo.lock
generated
|
@ -7589,6 +7589,7 @@ dependencies = [
|
||||||
"frame-benchmarking-cli",
|
"frame-benchmarking-cli",
|
||||||
"frame-system",
|
"frame-system",
|
||||||
"jsonrpsee",
|
"jsonrpsee",
|
||||||
|
"log",
|
||||||
"pallet-tendermint",
|
"pallet-tendermint",
|
||||||
"pallet-transaction-payment",
|
"pallet-transaction-payment",
|
||||||
"pallet-transaction-payment-rpc",
|
"pallet-transaction-payment-rpc",
|
||||||
|
@ -7616,7 +7617,9 @@ dependencies = [
|
||||||
"sp-core",
|
"sp-core",
|
||||||
"sp-inherents",
|
"sp-inherents",
|
||||||
"sp-keyring",
|
"sp-keyring",
|
||||||
|
"sp-keystore",
|
||||||
"sp-runtime",
|
"sp-runtime",
|
||||||
|
"sp-tendermint",
|
||||||
"sp-timestamp",
|
"sp-timestamp",
|
||||||
"substrate-build-script-utils",
|
"substrate-build-script-utils",
|
||||||
"substrate-frame-rpc-system",
|
"substrate-frame-rpc-system",
|
||||||
|
|
|
@ -25,7 +25,6 @@ volumes:
|
||||||
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
|
|
||||||
_serai:
|
_serai:
|
||||||
&serai_defaults
|
&serai_defaults
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
|
@ -61,7 +60,7 @@ services:
|
||||||
- cluster-coins-lg
|
- cluster-coins-lg
|
||||||
environment:
|
environment:
|
||||||
CHAIN: dev
|
CHAIN: dev
|
||||||
NAME: Alice
|
NAME: alice
|
||||||
VALIDATOR: true
|
VALIDATOR: true
|
||||||
|
|
||||||
serai-bob:
|
serai-bob:
|
||||||
|
@ -75,7 +74,8 @@ services:
|
||||||
- cluster-coins-lg
|
- cluster-coins-lg
|
||||||
environment:
|
environment:
|
||||||
CHAIN: dev
|
CHAIN: dev
|
||||||
NAME: Bob
|
NAME: bob
|
||||||
|
VALIDATOR: true
|
||||||
|
|
||||||
serai-charlie:
|
serai-charlie:
|
||||||
<<: *serai_defaults
|
<<: *serai_defaults
|
||||||
|
@ -88,7 +88,8 @@ services:
|
||||||
- cluster-coins-lg
|
- cluster-coins-lg
|
||||||
environment:
|
environment:
|
||||||
CHAIN: dev
|
CHAIN: dev
|
||||||
NAME: Charlie
|
NAME: charlie
|
||||||
|
VALIDATOR: true
|
||||||
|
|
||||||
serai-dave:
|
serai-dave:
|
||||||
<<: *serai_defaults
|
<<: *serai_defaults
|
||||||
|
@ -122,6 +123,7 @@ services:
|
||||||
environment:
|
environment:
|
||||||
CHAIN: dev
|
CHAIN: dev
|
||||||
NAME: Ferdie
|
NAME: Ferdie
|
||||||
|
|
||||||
# Processor Services
|
# Processor Services
|
||||||
|
|
||||||
# Coin Services
|
# Coin Services
|
||||||
|
|
|
@ -26,12 +26,11 @@ RUN --mount=type=cache,target=/usr/local/cargo/git \
|
||||||
--mount=type=cache,target=/serai/target/release/build \
|
--mount=type=cache,target=/serai/target/release/build \
|
||||||
--mount=type=cache,target=/serai/target/release/deps \
|
--mount=type=cache,target=/serai/target/release/deps \
|
||||||
--mount=type=cache,target=/serai/target/release/.fingerprint \
|
--mount=type=cache,target=/serai/target/release/.fingerprint \
|
||||||
--mount=type=cache,target=/serai/target/release/incremental \
|
--mount=type=cache,target=/serai/target/release/incremental \
|
||||||
--mount=type=cache,target=/serai/target/release/wbuild \
|
--mount=type=cache,target=/serai/target/release/wbuild \
|
||||||
--mount=type=cache,target=/serai/target/release/lib* \
|
--mount=type=cache,target=/serai/target/release/lib* \
|
||||||
cargo build --release
|
cargo build --release
|
||||||
|
|
||||||
|
|
||||||
# Prepare Image
|
# Prepare Image
|
||||||
FROM ubuntu:latest as image
|
FROM ubuntu:latest as image
|
||||||
LABEL description="STAGE 2: Copy and Run"
|
LABEL description="STAGE 2: Copy and Run"
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
if [[ -z $VALIDATOR ]]; then
|
if [[ -z $VALIDATOR ]]; then
|
||||||
serai-node --chain $CHAIN --name $NAME
|
serai-node --chain $CHAIN --$NAME
|
||||||
else
|
else
|
||||||
serai-node --chain $CHAIN --name $NAME --validator
|
serai-node --chain $CHAIN --$NAME --validator
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -14,11 +14,14 @@ name = "serai-node"
|
||||||
[dependencies]
|
[dependencies]
|
||||||
async-trait = "0.1"
|
async-trait = "0.1"
|
||||||
|
|
||||||
|
log = "0.4"
|
||||||
|
|
||||||
clap = { version = "4", features = ["derive"] }
|
clap = { version = "4", features = ["derive"] }
|
||||||
jsonrpsee = { version = "0.15", features = ["server"] }
|
jsonrpsee = { version = "0.15", features = ["server"] }
|
||||||
|
|
||||||
sp-core = { git = "https://github.com/serai-dex/substrate" }
|
sp-core = { git = "https://github.com/serai-dex/substrate" }
|
||||||
sp-application-crypto = { git = "https://github.com/serai-dex/substrate" }
|
sp-application-crypto = { git = "https://github.com/serai-dex/substrate" }
|
||||||
|
sp-keystore = { git = "https://github.com/serai-dex/substrate" }
|
||||||
sp-keyring = { git = "https://github.com/serai-dex/substrate" }
|
sp-keyring = { git = "https://github.com/serai-dex/substrate" }
|
||||||
sp-inherents = { git = "https://github.com/serai-dex/substrate" }
|
sp-inherents = { git = "https://github.com/serai-dex/substrate" }
|
||||||
sp-timestamp = { git = "https://github.com/serai-dex/substrate" }
|
sp-timestamp = { git = "https://github.com/serai-dex/substrate" }
|
||||||
|
@ -53,6 +56,7 @@ sc-rpc-api = { git = "https://github.com/serai-dex/substrate" }
|
||||||
substrate-frame-rpc-system = { git = "https://github.com/serai-dex/substrate" }
|
substrate-frame-rpc-system = { git = "https://github.com/serai-dex/substrate" }
|
||||||
pallet-transaction-payment-rpc = { git = "https://github.com/serai-dex/substrate" }
|
pallet-transaction-payment-rpc = { git = "https://github.com/serai-dex/substrate" }
|
||||||
|
|
||||||
|
sp-tendermint = { path = "../tendermint/primitives" }
|
||||||
pallet-tendermint = { path = "../tendermint/pallet", default-features = false }
|
pallet-tendermint = { path = "../tendermint/pallet", default-features = false }
|
||||||
serai-runtime = { path = "../runtime" }
|
serai-runtime = { path = "../runtime" }
|
||||||
sc_tendermint = { path = "../tendermint/client" }
|
sc_tendermint = { path = "../tendermint/client" }
|
||||||
|
|
|
@ -19,7 +19,11 @@ fn account_id_from_name(name: &'static str) -> AccountId {
|
||||||
}
|
}
|
||||||
|
|
||||||
fn testnet_genesis(wasm_binary: &[u8], endowed_accounts: Vec<AccountId>) -> GenesisConfig {
|
fn testnet_genesis(wasm_binary: &[u8], endowed_accounts: Vec<AccountId>) -> GenesisConfig {
|
||||||
let alice = account_id_from_name("Alice");
|
let session_key = |name| {
|
||||||
|
let key = account_id_from_name(name);
|
||||||
|
(key, key, SessionKeys { tendermint: Public::from(key) })
|
||||||
|
};
|
||||||
|
|
||||||
GenesisConfig {
|
GenesisConfig {
|
||||||
system: SystemConfig { code: wasm_binary.to_vec() },
|
system: SystemConfig { code: wasm_binary.to_vec() },
|
||||||
balances: BalancesConfig {
|
balances: BalancesConfig {
|
||||||
|
@ -27,7 +31,7 @@ fn testnet_genesis(wasm_binary: &[u8], endowed_accounts: Vec<AccountId>) -> Gene
|
||||||
},
|
},
|
||||||
transaction_payment: Default::default(),
|
transaction_payment: Default::default(),
|
||||||
session: SessionConfig {
|
session: SessionConfig {
|
||||||
keys: vec![(alice, alice, SessionKeys { tendermint: Public::from(alice) })],
|
keys: vec![session_key("Alice"), session_key("Bob"), session_key("Charlie")],
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
use std::{boxed::Box, sync::Arc, error::Error};
|
use std::{boxed::Box, sync::Arc, error::Error};
|
||||||
|
|
||||||
|
use sp_keystore::SyncCryptoStore;
|
||||||
use sp_runtime::traits::{Block as BlockTrait};
|
use sp_runtime::traits::{Block as BlockTrait};
|
||||||
use sp_inherents::CreateInherentDataProviders;
|
use sp_inherents::CreateInherentDataProviders;
|
||||||
use sp_consensus::DisableProofRecording;
|
use sp_consensus::DisableProofRecording;
|
||||||
use sp_api::ProvideRuntimeApi;
|
use sp_api::{BlockId, ProvideRuntimeApi};
|
||||||
|
use sp_tendermint::TendermintApi;
|
||||||
|
|
||||||
use sc_executor::{NativeVersion, NativeExecutionDispatch, NativeElseWasmExecutor};
|
use sc_executor::{NativeVersion, NativeExecutionDispatch, NativeElseWasmExecutor};
|
||||||
use sc_transaction_pool::FullPool;
|
use sc_transaction_pool::FullPool;
|
||||||
|
@ -219,23 +221,44 @@ pub async fn new_full(config: Configuration) -> Result<TaskManager, ServiceError
|
||||||
})?;
|
})?;
|
||||||
|
|
||||||
if is_authority {
|
if is_authority {
|
||||||
task_manager.spawn_essential_handle().spawn(
|
let keys = keystore_container.sync_keystore();
|
||||||
"tendermint",
|
let key = SyncCryptoStore::sr25519_public_keys(&*keys, sc_tendermint::KEY_TYPE_ID)
|
||||||
None,
|
.get(0)
|
||||||
TendermintAuthority::new(authority).authority(
|
.cloned()
|
||||||
(0, keystore_container.keystore()),
|
.unwrap_or_else(|| {
|
||||||
Cidp,
|
SyncCryptoStore::sr25519_generate_new(&*keys, sc_tendermint::KEY_TYPE_ID, None).unwrap()
|
||||||
sc_basic_authorship::ProposerFactory::new(
|
});
|
||||||
task_manager.spawn_handle(),
|
|
||||||
client,
|
let mut spawned = false;
|
||||||
transaction_pool,
|
let mut validators =
|
||||||
registry.as_ref(),
|
client.runtime_api().validators(&BlockId::Hash(client.chain_info().finalized_hash)).unwrap();
|
||||||
telemetry.map(|telemtry| telemtry.handle()),
|
for (i, validator) in validators.drain(..).enumerate() {
|
||||||
),
|
if validator == key {
|
||||||
network,
|
task_manager.spawn_essential_handle().spawn(
|
||||||
None,
|
"tendermint",
|
||||||
),
|
None,
|
||||||
);
|
TendermintAuthority::new(authority).authority(
|
||||||
|
(u16::try_from(i).unwrap(), keystore_container.keystore()),
|
||||||
|
Cidp,
|
||||||
|
sc_basic_authorship::ProposerFactory::new(
|
||||||
|
task_manager.spawn_handle(),
|
||||||
|
client,
|
||||||
|
transaction_pool,
|
||||||
|
registry.as_ref(),
|
||||||
|
telemetry.map(|telemtry| telemtry.handle()),
|
||||||
|
),
|
||||||
|
network,
|
||||||
|
None,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
spawned = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if !spawned {
|
||||||
|
log::warn!("authority role yet not a validator");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
network_starter.start_network();
|
network_starter.start_network();
|
||||||
|
|
|
@ -28,8 +28,8 @@ pub use block_import::TendermintSelectChain;
|
||||||
pub(crate) mod authority;
|
pub(crate) mod authority;
|
||||||
pub use authority::TendermintAuthority;
|
pub use authority::TendermintAuthority;
|
||||||
|
|
||||||
const CONSENSUS_ID: [u8; 4] = *b"tend";
|
pub const CONSENSUS_ID: [u8; 4] = *b"tend";
|
||||||
const KEY_TYPE_ID: KeyTypeId = KeyTypeId(CONSENSUS_ID);
|
pub const KEY_TYPE_ID: KeyTypeId = KeyTypeId(CONSENSUS_ID);
|
||||||
|
|
||||||
/// Trait consolidating all generics required by sc_tendermint for processing.
|
/// Trait consolidating all generics required by sc_tendermint for processing.
|
||||||
pub trait TendermintClient: Send + Sync + 'static {
|
pub trait TendermintClient: Send + Sync + 'static {
|
||||||
|
|
|
@ -38,7 +38,6 @@ impl TendermintValidatorsStruct {
|
||||||
let api = client.runtime_api();
|
let api = client.runtime_api();
|
||||||
let session = api.current_session(&BlockId::Hash(last)).unwrap();
|
let session = api.current_session(&BlockId::Hash(last)).unwrap();
|
||||||
let validators = api.validators(&BlockId::Hash(last)).unwrap();
|
let validators = api.validators(&BlockId::Hash(last)).unwrap();
|
||||||
assert_eq!(validators.len(), 1);
|
|
||||||
|
|
||||||
Self {
|
Self {
|
||||||
session,
|
session,
|
||||||
|
|
Loading…
Reference in a new issue