1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
// This file is part of Substrate. // Copyright (C) 2017-2020 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/>. //! Substrate state API. use jsonrpc_derive::rpc; use sp_core::storage::{StorageKey, PrefixedStorageKey, StorageData}; use crate::state::error::FutureResult; pub use self::gen_client::Client as ChildStateClient; /// Substrate child state API /// /// Note that all `PrefixedStorageKey` are desierialized /// from json and not guaranted valid. #[rpc] pub trait ChildStateApi<Hash> { /// RPC Metadata type Metadata; /// Returns the keys with prefix from a child storage, leave empty to get all the keys #[rpc(name = "childstate_getKeys")] fn storage_keys( &self, child_storage_key: PrefixedStorageKey, prefix: StorageKey, hash: Option<Hash> ) -> FutureResult<Vec<StorageKey>>; /// Returns a child storage entry at a specific block's state. #[rpc(name = "childstate_getStorage")] fn storage( &self, child_storage_key: PrefixedStorageKey, key: StorageKey, hash: Option<Hash> ) -> FutureResult<Option<StorageData>>; /// Returns the hash of a child storage entry at a block's state. #[rpc(name = "childstate_getStorageHash")] fn storage_hash( &self, child_storage_key: PrefixedStorageKey, key: StorageKey, hash: Option<Hash> ) -> FutureResult<Option<Hash>>; /// Returns the size of a child storage entry at a block's state. #[rpc(name = "childstate_getStorageSize")] fn storage_size( &self, child_storage_key: PrefixedStorageKey, key: StorageKey, hash: Option<Hash> ) -> FutureResult<Option<u64>>; }