mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-31 11:01:01 +00:00
471761f4b6
* Block import notifications * Build fix * Consensus messages supported in the networking * Started consensus service * BFT service * Transaction propagation * Polkadot service * CLI integration * Build fix * Added signatures validation * Removed executor argument * Refactored steam loops; Queue size increased * Limit queue size * Fixed doc comment * Fixed wasm build * Fixed wasm build * Check id properly
58 lines
1.8 KiB
Rust
58 lines
1.8 KiB
Rust
// Copyright 2017 Parity Technologies (UK) Ltd.
|
|
// This file is part of Substrate.
|
|
|
|
// Substrate 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.
|
|
|
|
// Substrate 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 Substrate. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
//! Polkadot state API.
|
|
|
|
mod error;
|
|
|
|
#[cfg(test)]
|
|
mod tests;
|
|
|
|
use std::sync::Arc;
|
|
use client::{self, Client};
|
|
use primitives::block;
|
|
use primitives::storage::{StorageKey, StorageData};
|
|
use state_machine;
|
|
|
|
use self::error::Result;
|
|
|
|
build_rpc_trait! {
|
|
/// Polkadot state API
|
|
pub trait StateApi {
|
|
/// Returns a storage entry.
|
|
#[rpc(name = "state_getStorage")]
|
|
fn storage(&self, StorageKey, block::HeaderHash) -> Result<StorageData>;
|
|
|
|
/// Call a contract.
|
|
#[rpc(name = "state_call")]
|
|
fn call(&self, String, Vec<u8>, block::HeaderHash) -> Result<Vec<u8>>;
|
|
}
|
|
}
|
|
|
|
impl<B, E> StateApi for Arc<Client<B, E>> where
|
|
B: client::backend::Backend + Send + Sync + 'static,
|
|
E: state_machine::CodeExecutor + Send + Sync + 'static,
|
|
client::error::Error: From<<<B as client::backend::Backend>::State as state_machine::backend::Backend>::Error>,
|
|
{
|
|
fn storage(&self, key: StorageKey, block: block::HeaderHash) -> Result<StorageData> {
|
|
Ok(self.as_ref().storage(&block::Id::Hash(block), &key)?)
|
|
}
|
|
|
|
fn call(&self, method: String, data: Vec<u8>, block: block::HeaderHash) -> Result<Vec<u8>> {
|
|
Ok(self.as_ref().call(&block::Id::Hash(block), &method, &data)?.return_data)
|
|
}
|
|
}
|