Skip to content

Commit

Permalink
Add assume_valid_target to sync_state RPC
Browse files Browse the repository at this point in the history
Signed-off-by: Eval EXEC <[email protected]>
  • Loading branch information
eval-exec committed Jun 21, 2024
1 parent 247befe commit 503b3ae
Show file tree
Hide file tree
Showing 5 changed files with 49 additions and 3 deletions.
12 changes: 12 additions & 0 deletions rpc/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4138,12 +4138,16 @@ Response
"id": 42,
"jsonrpc": "2.0",
"result": {
"assume_valid_target": "0x0000000000000000000000000000000000000000000000000000000000000000",
"assume_valid_target_reached": true,
"best_known_block_number": "0x400",
"best_known_block_timestamp": "0x5cd2b117",
"fast_time": "0x3e8",
"ibd": true,
"inflight_blocks_count": "0x0",
"low_time": "0x5dc",
"min_chain_work": "0x3314412053c82802a7",
"min_chain_work_reached": true,
"normal_time": "0x4e2",
"orphan_blocks_count": "0x0",
"orphan_blocks_size": "0x0"
Expand Down Expand Up @@ -6833,6 +6837,10 @@ The overall chain synchronization state of this local node.

`SyncState` is a JSON object with the following fields.

* `assume_valid_target`: [`Byte32`](#type-byte32) - The assume_valid_target specified by ckb, if no assume_valid_target, this will be all zero.

* `assume_valid_target_reached`: `boolean` - Is ckb reached the assume_valid_target? If no assume_valid_target, this will be true.

* `best_known_block_number`: [`Uint64`](#type-uint64) - This is the best known block number observed by the local node from the P2P network.

The best here means that the block leads a chain which has the best known accumulated difficulty.
Expand All @@ -6853,6 +6861,10 @@ The overall chain synchronization state of this local node.

* `low_time`: [`Uint64`](#type-uint64) - The download scheduler's time analysis data, the low is the 9/10 of the cut-off point, unit ms

* `min_chain_work`: [`Uint128`](#type-uint128) - The CKB hardcoded MIN_CHAIN_WORK_500K

* `min_chain_work_reached`: `boolean` - Is ckb reached the MIN_CHAIN_WORK_500K?

* `normal_time`: [`Uint64`](#type-uint64) - The download scheduler's time analysis data, the normal is the 4/5 of the cut-off point, unit ms

* `orphan_blocks_count`: [`Uint64`](#type-uint64) - Count of orphan blocks the local node has downloaded.
Expand Down
19 changes: 19 additions & 0 deletions rpc/src/module/net.rs
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
use crate::error::RPCError;
use async_trait::async_trait;
use ckb_app_config::MIN_CHAIN_WORK_500K;
use ckb_jsonrpc_types::{
BannedAddr, LocalNode, LocalNodeProtocol, NodeAddress, PeerSyncState, RemoteNode,
RemoteNodeProtocol, SyncState, Timestamp,
};
use ckb_network::{extract_peer_id, multiaddr::Multiaddr, NetworkController};
use ckb_sync::SyncShared;
use ckb_systemtime::unix_time_as_millis;
use ckb_types::prelude::Pack;
use jsonrpc_core::Result;
use jsonrpc_utils::rpc;
use std::sync::Arc;
Expand Down Expand Up @@ -361,12 +363,16 @@ pub trait NetRpc {
/// "id": 42,
/// "jsonrpc": "2.0",
/// "result": {
/// "assume_valid_target": "0x0000000000000000000000000000000000000000000000000000000000000000",
/// "assume_valid_target_reached": true,
/// "best_known_block_number": "0x400",
/// "best_known_block_timestamp": "0x5cd2b117",
/// "fast_time": "0x3e8",
/// "ibd": true,
/// "inflight_blocks_count": "0x0",
/// "low_time": "0x5dc",
/// "min_chain_work": "0x3314412053c82802a7",
/// "min_chain_work_reached": true,
/// "normal_time": "0x4e2",
/// "orphan_blocks_count": "0x0",
/// "orphan_blocks_size": "0x0"
Expand Down Expand Up @@ -719,8 +725,21 @@ impl NetRpc for NetRpcImpl {
let state = chain.shared().state();
let (fast_time, normal_time, low_time) = state.read_inflight_blocks().division_point();
let best_known = state.shared_best_header();
let min_chain_work = {
let mut min_chain_work_500k_u128: [u8; 16] = [0; 16];
min_chain_work_500k_u128.copy_from_slice(&MIN_CHAIN_WORK_500K.to_le_bytes()[..16]);
u128::from_le_bytes(min_chain_work_500k_u128)
};
let sync_state = SyncState {
ibd: chain.is_initial_block_download(),
assume_valid_target_reached: state.assume_valid_target().is_none(),
assume_valid_target: state
.assume_valid_target_specified()
.unwrap_or_default()
.pack()
.into(),
min_chain_work: min_chain_work.into(),
min_chain_work_reached: state.min_chain_work_ready(),
best_known_block_number: best_known.number().into(),
best_known_block_timestamp: best_known.timestamp().into(),
orphan_blocks_count: (state.orphan_pool().len() as u64).into(),
Expand Down
8 changes: 7 additions & 1 deletion sync/src/types/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1332,7 +1332,8 @@ impl SyncShared {
inflight_blocks: RwLock::new(InflightBlocks::default()),
pending_get_headers: RwLock::new(LruCache::new(GET_HEADERS_CACHE_SIZE)),
tx_relay_receiver,
assume_valid_target: Mutex::new(sync_config.assume_valid_target),
assume_valid_target: Mutex::new(sync_config.assume_valid_target.clone()),
assume_valid_target_specified: sync_config.assume_valid_target,
min_chain_work: sync_config.min_chain_work,
};

Expand Down Expand Up @@ -1693,6 +1694,7 @@ pub struct SyncState {
/* cached for sending bulk */
tx_relay_receiver: Receiver<TxVerificationResult>,
assume_valid_target: Mutex<Option<H256>>,
assume_valid_target_specified: Option<H256>,
min_chain_work: U256,
}

Expand All @@ -1701,6 +1703,10 @@ impl SyncState {
self.assume_valid_target.lock()
}

pub fn assume_valid_target_specified(&self) -> Option<H256> {
self.assume_valid_target_specified.clone()
}

pub fn min_chain_work(&self) -> &U256 {
&self.min_chain_work
}
Expand Down
3 changes: 2 additions & 1 deletion util/app-config/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,8 @@ use clap::ArgMatches;
use std::{path::PathBuf, str::FromStr};

// 500_000 total difficulty
const MIN_CHAIN_WORK_500K: U256 = u256!("0x3314412053c82802a7");
// The hexadecimal value "0x3314412053c82802a7" fits within a u128 data type.
pub const MIN_CHAIN_WORK_500K: U256 = u256!("0x3314412053c82802a7");

/// A struct including all the information to start the ckb process.
pub struct Setup {
Expand Down
10 changes: 9 additions & 1 deletion util/jsonrpc-types/src/net.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
use crate::{BlockNumber, Byte32, Timestamp, Uint64};
use crate::{BlockNumber, Byte32, Timestamp, Uint128, Uint64};
use schemars::JsonSchema;
use serde::{Deserialize, Serialize};

Expand Down Expand Up @@ -258,6 +258,14 @@ pub struct SyncState {
/// During IBD, the local node only synchronizes the chain with one selected remote node and
/// stops responding to most P2P requests.
pub ibd: bool,
/// Is ckb reached the assume_valid_target? If no assume_valid_target, this will be true.
pub assume_valid_target_reached: bool,
/// The assume_valid_target specified by ckb, if no assume_valid_target, this will be all zero.
pub assume_valid_target: Byte32,
/// Is ckb reached the MIN_CHAIN_WORK_500K?
pub min_chain_work_reached: bool,
/// The CKB hardcoded MIN_CHAIN_WORK_500K
pub min_chain_work: Uint128,
/// This is the best known block number observed by the local node from the P2P network.
///
/// The best here means that the block leads a chain which has the best known accumulated
Expand Down

0 comments on commit 503b3ae

Please sign in to comment.