-
Notifications
You must be signed in to change notification settings - Fork 51
How to add a JSON RPC method
JinGyeong Jeong edited this page Dec 9, 2019
·
7 revisions
- chain module is for accessing the blockchain and the transaction queue.
- devel module is for utility functions to debug CodeChain
chain_getBlockHash example (chain_getBlockHash usage example):
/// Gets the hash of the block with given number.
# [rpc(name = "chain_getBlockHash")]
fn get_block_hash(&self, u64) -> Result<Option<H256>>;
The above declaration is a part of the pub trait Chain. It creates the RPC endpoint to "chain_getBlockHash" which receives u64 parameter. All of the parameters must be serde-Serializable. See files in the src/rpc/v1/types/ directory.
chain_getBlockHash example:
fn get_block_hash(&self, block_number: u64) -> Result<Option<H256>> {
Ok(self.client.block_hash(BlockId::Number(block_number)))
}
The above implementation is a part of the impl Chain for ChainClient. ChainClient holds Client and Miner which are structs for both the blockchain and the transaction queue.
The above shows chain_getBlockHash, which is implemented using the block_hash function in Client.