mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 06:57:58 +00:00
Statement store (#13701)
* WIP Statement store * Sync with networking changes in master * WIP statement pallet * Statement validation * pallet tests * Validation queue * Store maintenance * Basic statement refactoring + tests + docs * Store metrics * Store tests * Store maintenance test * cargo fmt * Build fix * OCW Api * Offchain worker * Enable host functions * fmt * Minor tweaks * Fixed a warning * Removed tracing * Manual expiration * Reworked constraint management * Updated pallet constraint calculation * Added small test * Added remove function to the APIs * Copy-paste spec into readme * Comments * Made the store optional * Removed network protocol controller * fmt * Clippy fixes * fmt * fmt * More clippy fixes * More clippy fixes * More clippy fixes * Update client/statement-store/README.md Co-authored-by: cheme <emericchevalier.pro@gmail.com> * Apply suggestions from code review Co-authored-by: Bastian Köcher <git@kchr.de> * Removed sstore from node-template * Sort out data path * Added offline check * Removed dispatch_statement * Renamed into_generic * Fixed commit placement * Use HashSet for tracking peers/statements * fmt * Use ExtendedHostFunctions * Fixed benches * Tweaks * Apply suggestions from code review Co-authored-by: cheme <emericchevalier.pro@gmail.com> * Fixed priority mixup * Rename * newtypes for priorities * Added MAX_TOPICS * Fixed key filtering logic * Remove empty entrie * Removed prefix from signing * More documentation * fmt * Moved store setup from sc-service to node * Handle maintenance task in sc-statement-store * Use statement iterator * Renamed runtime API mod * fmt * Remove dump_encoded * fmt * Apply suggestions from code review Co-authored-by: Bastian Köcher <git@kchr.de> * Apply suggestions from code review Co-authored-by: Bastian Köcher <git@kchr.de> * Fixed build after applying review suggestions * License exceptions * fmt * Store options * Moved pallet consts to config trait * Removed global priority * Validate fields when decoding * Limit validation channel size * Made a comment into module doc * Removed submit_encoded --------- Co-authored-by: cheme <emericchevalier.pro@gmail.com> Co-authored-by: Bastian Köcher <git@kchr.de>
This commit is contained in:
@@ -0,0 +1,108 @@
|
||||
// This file is part of Substrate.
|
||||
|
||||
// Copyright (C) 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 statement store API.
|
||||
|
||||
use codec::{Decode, Encode};
|
||||
use jsonrpsee::core::{async_trait, RpcResult};
|
||||
/// Re-export the API for backward compatibility.
|
||||
pub use sc_rpc_api::statement::{error::Error, StatementApiServer};
|
||||
use sc_rpc_api::DenyUnsafe;
|
||||
use sp_core::Bytes;
|
||||
use sp_statement_store::{StatementSource, SubmitResult};
|
||||
use std::sync::Arc;
|
||||
|
||||
/// Statement store API
|
||||
pub struct StatementStore {
|
||||
store: Arc<dyn sp_statement_store::StatementStore>,
|
||||
deny_unsafe: DenyUnsafe,
|
||||
}
|
||||
|
||||
impl StatementStore {
|
||||
/// Create new instance of Offchain API.
|
||||
pub fn new(
|
||||
store: Arc<dyn sp_statement_store::StatementStore>,
|
||||
deny_unsafe: DenyUnsafe,
|
||||
) -> Self {
|
||||
StatementStore { store, deny_unsafe }
|
||||
}
|
||||
}
|
||||
|
||||
#[async_trait]
|
||||
impl StatementApiServer for StatementStore {
|
||||
fn dump(&self) -> RpcResult<Vec<Bytes>> {
|
||||
self.deny_unsafe.check_if_safe()?;
|
||||
|
||||
let statements =
|
||||
self.store.statements().map_err(|e| Error::StatementStore(e.to_string()))?;
|
||||
Ok(statements.into_iter().map(|(_, s)| s.encode().into()).collect())
|
||||
}
|
||||
|
||||
fn broadcasts(&self, match_all_topics: Vec<[u8; 32]>) -> RpcResult<Vec<Bytes>> {
|
||||
Ok(self
|
||||
.store
|
||||
.broadcasts(&match_all_topics)
|
||||
.map_err(|e| Error::StatementStore(e.to_string()))?
|
||||
.into_iter()
|
||||
.map(Into::into)
|
||||
.collect())
|
||||
}
|
||||
|
||||
fn posted(&self, match_all_topics: Vec<[u8; 32]>, dest: [u8; 32]) -> RpcResult<Vec<Bytes>> {
|
||||
Ok(self
|
||||
.store
|
||||
.posted(&match_all_topics, dest)
|
||||
.map_err(|e| Error::StatementStore(e.to_string()))?
|
||||
.into_iter()
|
||||
.map(Into::into)
|
||||
.collect())
|
||||
}
|
||||
|
||||
fn posted_clear(
|
||||
&self,
|
||||
match_all_topics: Vec<[u8; 32]>,
|
||||
dest: [u8; 32],
|
||||
) -> RpcResult<Vec<Bytes>> {
|
||||
Ok(self
|
||||
.store
|
||||
.posted_clear(&match_all_topics, dest)
|
||||
.map_err(|e| Error::StatementStore(e.to_string()))?
|
||||
.into_iter()
|
||||
.map(Into::into)
|
||||
.collect())
|
||||
}
|
||||
|
||||
fn submit(&self, encoded: Bytes) -> RpcResult<()> {
|
||||
let statement = Decode::decode(&mut &*encoded)
|
||||
.map_err(|e| Error::StatementStore(format!("Eror decoding statement: {:?}", e)))?;
|
||||
match self.store.submit(statement, StatementSource::Local) {
|
||||
SubmitResult::New(_) | SubmitResult::Known => Ok(()),
|
||||
// `KnownExpired` should not happen. Expired statements submitted with
|
||||
// `StatementSource::Rpc` should be renewed.
|
||||
SubmitResult::KnownExpired =>
|
||||
Err(Error::StatementStore("Submitted an expired statement.".into()).into()),
|
||||
SubmitResult::Bad(e) => Err(Error::StatementStore(e.into()).into()),
|
||||
SubmitResult::Ignored => Err(Error::StatementStore("Store is full.".into()).into()),
|
||||
SubmitResult::InternalError(e) => Err(Error::StatementStore(e.to_string()).into()),
|
||||
}
|
||||
}
|
||||
|
||||
fn remove(&self, hash: [u8; 32]) -> RpcResult<()> {
|
||||
Ok(self.store.remove(&hash).map_err(|e| Error::StatementStore(e.to_string()))?)
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user