mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-04-27 11:38:01 +00:00
c7a14db792
* meaningfull -> meaningful * initialise -> initialize * tokans -> tokens * incentivise -> incentivize * lenght -> length * incentivisation -> incentivization * doesnt't -> doesn't * overwriten -> overwritten * lifecycle -> life cycle * lifecycle -> life cycle * usefull -> useful * noone -> no one * spaming -> spamming * defered -> deferred * hieght -> height * sumation -> summation * ingore -> ignore * registed -> registered * Auxialary -> Auxiliary * loggin -> logging * independance -> independence * trailling -> trailing * responsability -> responsibility * trunkated -> truncated * Weither -> Whether * informations -> information * Runtume -> Runtime * choosen -> chosen * delcataion -> declaration * Unchekced -> Unchecked * defintion -> definition * scrach -> scratch * imput -> input * transfered -> transferred * endownment -> endowment * Determinator -> Determiner * relevent -> relevant * emited -> emitted * acocunt -> account * proprotional -> proportional * instantiaion -> instantiation * commited -> committed * tombstonedead -> tombstone * uwnrap -> unwrap * acount -> account * specialised -> specialized * existant -> existent * requried -> required * Anull -> Annul * AUTHORITES -> AUTHORITIES * underyling -> underlying * recognisable -> recognizable * Capitalise -> Capitalize * reportfor -> report for * hearbeat -> heartbeat * onlineness -> being online * creater -> creator * Bytearray -> Byte array * Despoit -> Deposit * substratced -> subtracted * Curent -> Current * imbalanes -> imbalances * countfown -> countdown * inexisting -> inexistent * additionaly -> additionally * substracted -> subtracted * auxilary -> auxiliary * parital -> partial * in't -> isn't * compatability -> compatibility * infomation -> information * etected -> detected * extrinsiscs -> extrinsics * reprensentation -> representation * coonfiguration -> configuration * primtives -> primitives * miscelanious -> miscellaneous * VERISON -> VERSION * endcoded -> encoded * Genrates -> Generates * miliseconds -> milliseconds * occured -> occurred * trully -> truely * truely -> truly * conjuction -> conjunction * encouters -> encounters * customised -> customized * deterministicly -> deterministically * finalisation -> finalization * pluggable -> plugable * wakeup -> wake-up * interemdiate -> intermediate * intepreting -> interpreting * finalzied -> finalized * throgh -> through * extinsic -> extrinsic * convient -> convenient * allocater -> allocator * propagateable -> propagatable * succesfuly -> successfully * finalising -> finalizing * publically -> publicly * phrasee -> phrase * substration -> substractions * substractions -> subtractions * neccessarily -> necessarily * Inlucde -> Include * unefficient -> inefficient * thay -> they * funtion -> function * datastructures -> data structures * infromation -> information * propagatable -> propagable * ecountered -> encountered * recognise -> recognize * intergration -> integration * lastet -> latest * datatypes -> data types * datatype -> data type * Strongarming -> Strong Arming * avaible -> available * Commiting -> Committing * Retreiving -> Retrieving * shoud -> should * canonicaliziation -> canonicalization * comitted -> committed * clonable -> cloneable * Uknown -> Unknown * reponse -> response * arbitary -> arbitrary * Capapbilities -> Capabilities * responsbile -> responsible * initialisation -> initialization * cames -> came * intemediate -> intermediate * reqeust -> request * intance -> instance * explcitly -> explicitly * neighor -> neighbor * reolving -> resolving * untill -> until * Validte -> Validate * deserailize -> deserialize * literaly -> literally * preceeding -> preceding * abpve -> above * chcecked -> checked * numbet -> number * Unknow -> Unknown * halfs -> halves * gossup -> gossip * givent -> given * immediatelly -> immediately * slicable -> sliceable * conensus -> consensus * Mimicks -> Mimics * acccept -> accept * serialise -> serialize * exstrinsics -> extrinsics * panicks -> panics * maintaince -> maintenance * repeatidely -> repeatedly * anecstor -> ancestor * becasue -> because * processer -> processor * Prunning -> Pruning * insterested -> interested * unuseful -> not useful * yeided -> yielded * descendfing -> descending * corresponts -> corresponds * survivew -> survive * keps -> keeps * ligh -> light * prerequisities -> prerequisites * positiion -> position * depedency -> dependency * extrinisic -> extrinsic * atomicaly -> atomically * staticly -> statically * resul -> result * timestamb -> timestamp * Utilites -> Utilities * ammount -> amount * pocess -> process * exteral -> external * Update client/finality-grandpa/src/tests.rs * Update primitives/io/src/lib.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update primitives/blockchain/src/lib.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update frame/support/src/weights.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update bin/node/cli/tests/common.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/api/src/execution_extensions.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/cli/src/params.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/executor/common/src/sandbox.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/api/src/execution_extensions.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/finality-grandpa/src/communication/mod.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/state-db/src/pruning.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update frame/contracts/src/tests.rs Co-Authored-By: joe petrowski <25483142+joepetrowski@users.noreply.github.com> * Update client/api/src/execution_extensions.rs * bump impl * timestamb -> timestamp Co-authored-by: joe petrowski <25483142+joepetrowski@users.noreply.github.com>
120 lines
3.6 KiB
Rust
120 lines
3.6 KiB
Rust
// Copyright 2017-2020 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/>.
|
|
|
|
use std::collections::HashMap;
|
|
use std::sync::{Arc, atomic::{self, AtomicUsize}};
|
|
|
|
use log::{error, warn};
|
|
use jsonrpc_pubsub::{SubscriptionId, typed::{Sink, Subscriber}};
|
|
use parking_lot::Mutex;
|
|
use jsonrpc_core::futures::sync::oneshot;
|
|
use jsonrpc_core::futures::{Future, future};
|
|
|
|
type Id = u64;
|
|
|
|
/// Alias for a an implementation of `futures::future::Executor`.
|
|
pub type TaskExecutor = Arc<dyn future::Executor<Box<dyn Future<Item = (), Error = ()> + Send>> + Send + Sync>;
|
|
|
|
/// Generate unique ids for subscriptions.
|
|
#[derive(Clone, Debug)]
|
|
pub struct IdProvider {
|
|
next_id: Arc<AtomicUsize>,
|
|
}
|
|
impl Default for IdProvider {
|
|
fn default() -> Self {
|
|
IdProvider {
|
|
next_id: Arc::new(AtomicUsize::new(1)),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl IdProvider {
|
|
/// Returns next id for the subscription.
|
|
pub fn next_id(&self) -> Id {
|
|
self.next_id.fetch_add(1, atomic::Ordering::AcqRel) as u64
|
|
}
|
|
}
|
|
|
|
/// Subscriptions manager.
|
|
///
|
|
/// Takes care of assigning unique subscription ids and
|
|
/// driving the sinks into completion.
|
|
#[derive(Clone)]
|
|
pub struct Subscriptions {
|
|
next_id: IdProvider,
|
|
active_subscriptions: Arc<Mutex<HashMap<Id, oneshot::Sender<()>>>>,
|
|
executor: TaskExecutor,
|
|
}
|
|
|
|
impl Subscriptions {
|
|
/// Creates new `Subscriptions` object.
|
|
pub fn new(executor: TaskExecutor) -> Self {
|
|
Subscriptions {
|
|
next_id: Default::default(),
|
|
active_subscriptions: Default::default(),
|
|
executor,
|
|
}
|
|
}
|
|
|
|
/// Borrows the internal task executor.
|
|
///
|
|
/// This can be used to spawn additional tasks on the underlying event loop.
|
|
pub fn executor(&self) -> &TaskExecutor {
|
|
&self.executor
|
|
}
|
|
|
|
/// Creates new subscription for given subscriber.
|
|
///
|
|
/// Second parameter is a function that converts Subscriber sink into a future.
|
|
/// This future will be driven to completion by the underlying event loop
|
|
/// or will be cancelled in case #cancel is invoked.
|
|
pub fn add<T, E, G, R, F>(&self, subscriber: Subscriber<T, E>, into_future: G) -> SubscriptionId where
|
|
G: FnOnce(Sink<T, E>) -> R,
|
|
R: future::IntoFuture<Future=F, Item=(), Error=()>,
|
|
F: future::Future<Item=(), Error=()> + Send + 'static,
|
|
{
|
|
let id = self.next_id.next_id();
|
|
let subscription_id: SubscriptionId = id.into();
|
|
if let Ok(sink) = subscriber.assign_id(subscription_id.clone()) {
|
|
let (tx, rx) = oneshot::channel();
|
|
let future = into_future(sink)
|
|
.into_future()
|
|
.select(rx.map_err(|e| warn!("Error timeing out: {:?}", e)))
|
|
.then(|_| Ok(()));
|
|
|
|
self.active_subscriptions.lock().insert(id, tx);
|
|
if self.executor.execute(Box::new(future)).is_err() {
|
|
error!("Failed to spawn RPC subscription task");
|
|
}
|
|
}
|
|
|
|
subscription_id
|
|
}
|
|
|
|
/// Cancel subscription.
|
|
///
|
|
/// Returns true if subscription existed or false otherwise.
|
|
pub fn cancel(&self, id: SubscriptionId) -> bool {
|
|
if let SubscriptionId::Number(id) = id {
|
|
if let Some(tx) = self.active_subscriptions.lock().remove(&id) {
|
|
let _ = tx.send(());
|
|
return true;
|
|
}
|
|
}
|
|
false
|
|
}
|
|
}
|