pub trait TransactionPool: Send + Sync {
    type Block: BlockT;
    type Hash: Hash + Eq + Member + Serialize + DeserializeOwned;
    type InPoolTransaction: InPoolTransaction<Transaction = TransactionFor<Self>, Hash = TxHash<Self>>;
    type Error: From<Error> + IntoPoolError;

    fn submit_at(
        &self,
        at: &BlockId<Self::Block>,
        source: TransactionSource,
        xts: Vec<TransactionFor<Self>>
    ) -> PoolFuture<Vec<Result<TxHash<Self>, Self::Error>>, Self::Error>; fn submit_one(
        &self,
        at: &BlockId<Self::Block>,
        source: TransactionSource,
        xt: TransactionFor<Self>
    ) -> PoolFuture<TxHash<Self>, Self::Error>; fn submit_and_watch(
        &self,
        at: &BlockId<Self::Block>,
        source: TransactionSource,
        xt: TransactionFor<Self>
    ) -> PoolFuture<Pin<Box<TransactionStatusStreamFor<Self>>>, Self::Error>; fn ready_at(
        &self,
        at: NumberFor<Self::Block>
    ) -> Pin<Box<dyn Future<Output = Box<dyn ReadyTransactions<Item = Arc<Self::InPoolTransaction>> + Send>> + Send>>; fn ready(
        &self
    ) -> Box<dyn ReadyTransactions<Item = Arc<Self::InPoolTransaction>> + Send>; fn remove_invalid(
        &self,
        hashes: &[TxHash<Self>]
    ) -> Vec<Arc<Self::InPoolTransaction>> ; fn status(&self) -> PoolStatus; fn import_notification_stream(
        &self
    ) -> ImportNotificationStream<TxHash<Self>>; fn on_broadcasted(&self, propagations: HashMap<TxHash<Self>, Vec<String>>); fn hash_of(&self, xt: &TransactionFor<Self>) -> TxHash<Self>; fn ready_transaction(
        &self,
        hash: &TxHash<Self>
    ) -> Option<Arc<Self::InPoolTransaction>>; }
Expand description

Transaction pool interface.

Required Associated Types§

Block type.

Transaction hash type.

In-pool transaction type.

Error type.

Required Methods§

Returns a future that imports a bunch of unverified transactions to the pool.

Returns a future that imports one unverified transaction to the pool.

Returns a future that import a single transaction and starts to watch their progress in the pool.

Get an iterator for ready transactions ordered by priority.

Guarantees to return only when transaction pool got updated at at block. Guarantees to return immediately when None is passed.

Get an iterator for ready transactions ordered by priority.

Remove transactions identified by given hashes (and dependent transactions) from the pool.

Returns pool status.

Return an event stream of transactions imported to the pool.

Notify the pool about transactions broadcast.

Returns transaction hash

Return specific ready transaction by hash, if there is one.

Implementors§