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

rpc: Implement chainHead RPC API #12544

Merged
merged 80 commits into from
Dec 19, 2022
Merged
Show file tree
Hide file tree
Changes from 75 commits
Commits
Show all changes
80 commits
Select commit Hold shift + click to select a range
717ee38
rpc/chain_head: Add event structure for serialization
lexnv Oct 21, 2022
3716594
rpc/chain_head: Add tests for events
lexnv Oct 21, 2022
c3ac4b8
rpc/chain_head: Add API trait for `chainHead`
lexnv Oct 21, 2022
4f88981
rpc/chain_head: Add RPC errors
lexnv Oct 21, 2022
ab1bc81
rpc/chain_head: Manage subscription ID tracking for pinned blocks
lexnv Oct 21, 2022
2e2237f
rpc/chain_head: Add tests for subscription management
lexnv Oct 21, 2022
798acd2
rpc/chain_head: Constructor for the API
lexnv Oct 21, 2022
373887c
rpc/chain_head: Placeholders for API implementation
lexnv Oct 21, 2022
aa1d21b
rpc/chain_head: Accept RPC subscription sink
lexnv Oct 21, 2022
d8e60f7
rpc/chain_head: Generate the runtime API event
lexnv Oct 21, 2022
8dbdaf8
rpc/chain_head: Implement the `follow` method
lexnv Oct 21, 2022
3ed5c79
rpc/chain_head: Implement the `body` method
lexnv Oct 21, 2022
27d9a5c
rpc/chain_head: Implement the `header` method
lexnv Oct 21, 2022
9ec6b36
rpc/chain_head: Implement the `storage` method
lexnv Oct 21, 2022
70fd229
rpc/chain_head: Implement the `call` method
lexnv Oct 21, 2022
d93161a
rpc/chain_head: Implement the `unpin` method
lexnv Oct 21, 2022
2bec344
Update `Cargo.lock`
lexnv Oct 21, 2022
7e4326a
rpc/chain_head: Implement `getGenesis` method
lexnv Oct 24, 2022
0f32685
rpc/chain_head: Fix clippy
lexnv Oct 24, 2022
4ba5d77
rpc/chain_head: Parse params from hex string
lexnv Oct 24, 2022
542d360
rpc/chain_head: Constuct API with genesis hash
lexnv Oct 25, 2022
e1f5796
rpc/chain_head: Add the finalized block to reported tree route
lexnv Oct 25, 2022
cf3530c
rpc/chain_head: Export the API and events for better ergonomics
lexnv Oct 25, 2022
7ae67fa
chain_head/tests: Add test module with helper functions
lexnv Oct 25, 2022
80b8776
chain_head/tests: Test block events from the `follow` pubsub
lexnv Oct 25, 2022
83e926c
chain_head/tests: Test `genesisHash` getter
lexnv Oct 25, 2022
f047db9
chain_head/tests: Test `header` method
lexnv Oct 25, 2022
05d6219
chain_head/tests: Test `body` method
lexnv Oct 25, 2022
f9c004b
chain_head/tests: Test calling into the runtime API
lexnv Oct 25, 2022
e0ab77c
chain_head/tests: Test runtime for the `follow` method
lexnv Oct 25, 2022
04574cc
chain_head/tests: Add runtime code changes for `follow` method
lexnv Oct 25, 2022
b64a9c9
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Oct 26, 2022
2de8d6c
rpc/chain_head: Remove space from rustdoc
lexnv Oct 26, 2022
d78e04d
rpc/chain_head: Use the `child_key` for storage queries
lexnv Oct 26, 2022
ba8a257
rpc/chain_head: Test `storage` method
lexnv Oct 26, 2022
745c795
rpc/chain_head: Test child trie query for `storage` method
lexnv Oct 26, 2022
c80a428
rpc/chain_head: Event serialization typo
lexnv Oct 26, 2022
cce8e42
rpc/chain_head: Remove subscription aliases
lexnv Oct 27, 2022
a5678c4
rpc/chain_head: Add `NetworkConfig` parameter
lexnv Oct 27, 2022
e6f7df0
rpc/chain_head: Named parameters as camelCase if present
lexnv Oct 27, 2022
80ddec8
rpc/chain_head: Implement From<ApiError> for RuntimeEvents
lexnv Nov 3, 2022
08fe794
rpc/chain_head: Handle pruning of the best block in finalization window
lexnv Nov 4, 2022
76c0d2c
rpc/chain_head: Generate initial block events
lexnv Nov 4, 2022
cad484e
chain_head/tests: Verify that initial in-memory blocks are reported
lexnv Nov 7, 2022
351154f
chain_head/tests: Verify the finalized event with forks and pruned bl…
lexnv Nov 7, 2022
f185e7c
rpc/chain_head: Fix clippy
lexnv Nov 7, 2022
4742b7c
rpc/chain_head: Separate logic for generating initial events
lexnv Nov 8, 2022
06ac897
rpc/chain_head: Handle stopping a subscription ID
lexnv Nov 8, 2022
06797df
rpc/chain_head: Submit events until the "Stop" event is triggered
lexnv Nov 8, 2022
2a1b79f
rpc/chain_head: Separate logic for handling new and finalized blocks
lexnv Nov 8, 2022
e5fac2c
rpc/chain_head: Extend subscription logic with subId handle
lexnv Nov 9, 2022
6b84dd4
rpc/chain_head: Adjust to the new subscription mngmt API
lexnv Nov 9, 2022
091cd90
rpc/chain_head: Refuse RuntimeAPI calls without the runtime flag
lexnv Nov 9, 2022
f5514b8
chain_head/tests: Verify RuntimeAPI calls without runtime flag
lexnv Nov 9, 2022
a060fb8
rpc/chain_head: Add best block per subscription
lexnv Nov 9, 2022
d782cc2
rpc/chain_head: Check storage keys for prefixes
lexnv Nov 9, 2022
4ce5fe5
chain_head/tests: Check storage queries with invalid prefixes
lexnv Nov 9, 2022
60a46ab
rpc/chain_head: Allow maximum number of pinned blocks
lexnv Nov 10, 2022
239013c
chain_head/tests: Test the maximum number of pinned blocks
lexnv Nov 10, 2022
1edc4a7
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Nov 10, 2022
7804896
rpc/chain_head: Adjust to origin/master and apply clippy
lexnv Nov 10, 2022
42035bf
client/service: Enable the `chainHead` API
lexnv Nov 17, 2022
ed720a1
rpc/chain_head: Stop subscription on client disconnect and add debug …
lexnv Nov 17, 2022
3820d4f
rpc/chain_head: Fix sending `Stop` on subscription exit
lexnv Nov 17, 2022
e95fa3f
rpc/chain_head: Check best block is descendent of latest finalized
lexnv Nov 17, 2022
4372c4a
chain_head/tests: Report events before pruning the best block
lexnv Nov 18, 2022
eab917f
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Nov 23, 2022
9d25bea
rpc/chain_head: Nonrecursive initial block generation
lexnv Nov 23, 2022
1065eaf
rpc/chain_head: Generate initial events on subscription executor
lexnv Nov 23, 2022
6dbd383
rpc/chain_head: Reduce dev-dependencies for tokio
lexnv Nov 24, 2022
54b7395
Apply suggestions from code review
lexnv Nov 24, 2022
331e1bb
rpc/chain_head: Accept empty parameters
lexnv Nov 30, 2022
6da3073
rpc/chain_head: Use debug of `HexDisplay` for full format
lexnv Nov 30, 2022
cafd5ef
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Dec 12, 2022
cc4d1a5
rpc/chain_head: Enable subscription ID
lexnv Dec 12, 2022
9a3f5f7
rpc/chain_head: Use jsonrpsee 16.2 camelCase feature for paramaters
lexnv Dec 12, 2022
7e7afed
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Dec 13, 2022
22bd9fa
Merge remote-tracking branch 'origin/master' into lexnv/rpc_chainhead
lexnv Dec 19, 2022
0111353
rpc/chain_head: Use `NonZeroUsize` for `NetworkConfig` param
lexnv Dec 19, 2022
41aee3e
rpc/chain_head: Rename `runtime_updates` to `has_runtime_updates`
lexnv Dec 19, 2022
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
38 changes: 33 additions & 5 deletions Cargo.lock

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

13 changes: 13 additions & 0 deletions client/rpc-spec-v2/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -22,12 +22,25 @@ sp-core = { version = "7.0.0", path = "../../primitives/core" }
sp-runtime = { version = "7.0.0", path = "../../primitives/runtime" }
sp-api = { version = "4.0.0-dev", path = "../../primitives/api" }
sp-blockchain = { version = "4.0.0-dev", path = "../../primitives/blockchain" }
sp-version = { version = "5.0.0", path = "../../primitives/version" }
sc-client-api = { version = "4.0.0-dev", path = "../api" }
codec = { package = "parity-scale-codec", version = "3.0.0" }
thiserror = "1.0"
serde = "1.0"
hex = "0.4"
futures = "0.3.21"
parking_lot = "0.12.1"
tokio-stream = { version = "0.1", features = ["sync"] }
array-bytes = "4.1"
log = "0.4.17"
futures-util = { version = "0.3.19", default-features = false }

[dev-dependencies]
serde_json = "1.0"
tokio = { version = "1.22.0", features = ["macros"] }
substrate-test-runtime-client = { version = "2.0.0", path = "../../test-utils/runtime/client" }
substrate-test-runtime = { version = "2.0.0", path = "../../test-utils/runtime" }
sp-consensus = { version = "0.10.0-dev", path = "../../primitives/consensus/common" }
sp-maybe-compressed-blob = { version = "4.1.0-dev", path = "../../primitives/maybe-compressed-blob" }
sc-block-builder = { version = "0.10.0-dev", path = "../block-builder" }
assert_matches = "1.3.0"
137 changes: 137 additions & 0 deletions client/rpc-spec-v2/src/chain_head/api.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,137 @@
// This file is part of Substrate.

// Copyright (C) 2022 Parity Technologies (UK) Ltd.
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0

// This program 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.

// This program 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 this program. If not, see <https://www.gnu.org/licenses/>.

#![allow(non_snake_case)]

//! API trait of the chain head.
use crate::chain_head::event::{ChainHeadEvent, FollowEvent, NetworkConfig};
use jsonrpsee::{core::RpcResult, proc_macros::rpc};

#[rpc(client, server)]
pub trait ChainHeadApi<Hash> {
/// Track the state of the head of the chain: the finalized, non-finalized, and best blocks.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[subscription(
name = "chainHead_unstable_follow",
unsubscribe = "chainHead_unstable_unfollow",
item = FollowEvent<Hash>,
)]
fn chain_head_unstable_follow(&self, runtimeUpdates: bool);

/// Retrieves the body (list of transactions) of a pinned block.
///
/// This method should be seen as a complement to `chainHead_unstable_follow`,
/// allowing the JSON-RPC client to retrieve more information about a block
/// that has been reported.
///
/// Use `archive_unstable_body` if instead you want to retrieve the body of an arbitrary block.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[subscription(
name = "chainHead_unstable_body",
unsubscribe = "chainHead_unstable_stopBody",
item = ChainHeadEvent<String>,
)]
fn chain_head_unstable_body(
&self,
followSubscription: String,
lexnv marked this conversation as resolved.
Show resolved Hide resolved
hash: Hash,
networkConfig: Option<NetworkConfig>,
);

/// Retrieves the header of a pinned block.
///
/// This method should be seen as a complement to `chainHead_unstable_follow`,
/// allowing the JSON-RPC client to retrieve more information about a block
/// that has been reported.
///
/// Use `archive_unstable_header` if instead you want to retrieve the header of an arbitrary
/// block.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[method(name = "chainHead_unstable_header", blocking)]
fn chain_head_unstable_header(
&self,
followSubscription: String,
hash: Hash,
) -> RpcResult<Option<String>>;

/// Get the chain's genesis hash.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[method(name = "chainHead_unstable_genesisHash", blocking)]
fn chain_head_unstable_genesis_hash(&self) -> RpcResult<String>;

/// Return a storage entry at a specific block's state.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[subscription(
name = "chainHead_unstable_storage",
unsubscribe = "chainHead_unstable_stopStorage",
item = ChainHeadEvent<String>,
)]
fn chain_head_unstable_storage(
&self,
followSubscription: String,
hash: Hash,
key: String,
childKey: Option<String>,
networkConfig: Option<NetworkConfig>,
);

/// Call into the Runtime API at a specified block's state.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[subscription(
name = "chainHead_unstable_call",
unsubscribe = "chainHead_unstable_stopCall",
item = ChainHeadEvent<String>,
)]
fn chain_head_unstable_call(
&self,
followSubscription: String,
hash: Hash,
function: String,
callParameters: String,
networkConfig: Option<NetworkConfig>,
);

/// Unpin a block reported by the `follow` method.
///
/// Ongoing operations that require the provided block
/// will continue normally.
///
/// # Unstable
///
/// This method is unstable and subject to change in the future.
#[method(name = "chainHead_unstable_unpin", blocking)]
fn chain_head_unstable_unpin(&self, followSubscription: String, hash: Hash) -> RpcResult<()>;
}
Loading