pub struct BlockchainActors<P, T, DB: Clone + Send + Sync + 'static> {
provider: P,
bc: Blockchain<DB>,
pub signers: SharedState<TxSigners>,
actor_manager: ActorsManager,
encoder: Option<MulticallerSwapEncoder>,
has_mempool: bool,
has_state_update: bool,
has_signers: bool,
mutlicaller_address: Option<Address>,
relays: Vec<RelayConfig>,
_t: PhantomData<T>,
}
Fields§
§provider: P
§bc: Blockchain<DB>
§signers: SharedState<TxSigners>
§actor_manager: ActorsManager
§encoder: Option<MulticallerSwapEncoder>
§has_mempool: bool
§has_state_update: bool
§has_signers: bool
§mutlicaller_address: Option<Address>
§relays: Vec<RelayConfig>
§_t: PhantomData<T>
Implementations§
Source§impl<P, T, DB> BlockchainActors<P, T, DB>
impl<P, T, DB> BlockchainActors<P, T, DB>
pub fn new(provider: P, bc: Blockchain<DB>, relays: Vec<RelayConfig>) -> Self
pub async fn wait(self)
Sourcepub fn start_and_wait(
&mut self,
actor: impl Actor + Send + Sync + 'static,
) -> Result<&mut Self>
pub fn start_and_wait( &mut self, actor: impl Actor + Send + Sync + 'static, ) -> Result<&mut Self>
Start a custom actor and wait for it to finish
Sourcepub fn initialize_signers_with_anvil(&mut self) -> Result<&mut Self>
pub fn initialize_signers_with_anvil(&mut self) -> Result<&mut Self>
Initialize signers with the default anvil Private Key
Sourcepub fn initialize_signers_with_key(
&mut self,
key: Option<Vec<u8>>,
) -> Result<&mut Self>
pub fn initialize_signers_with_key( &mut self, key: Option<Vec<u8>>, ) -> Result<&mut Self>
Initialize signers with the private key. Random key generated if param in None
Sourcepub fn initialize_signers_with_keys(
&mut self,
keys: Vec<Vec<u8>>,
) -> Result<&mut Self>
pub fn initialize_signers_with_keys( &mut self, keys: Vec<Vec<u8>>, ) -> Result<&mut Self>
Initialize signers with multiple private keys
Sourcepub fn initialize_signers_with_encrypted_key(
&mut self,
key: Vec<u8>,
) -> Result<&mut Self>
pub fn initialize_signers_with_encrypted_key( &mut self, key: Vec<u8>, ) -> Result<&mut Self>
Initialize signers with encrypted private key
Sourcepub fn initialize_signers_with_env(&mut self) -> Result<&mut Self>
pub fn initialize_signers_with_env(&mut self) -> Result<&mut Self>
Initializes signers with encrypted key form DATA env var
Sourcepub fn with_signers(&mut self) -> Result<&mut Self>
pub fn with_signers(&mut self) -> Result<&mut Self>
Starts signer actor
Sourcepub fn with_swap_encoder(
&mut self,
multicaller_address: Option<Address>,
) -> Result<&mut Self>
pub fn with_swap_encoder( &mut self, multicaller_address: Option<Address>, ) -> Result<&mut Self>
Initializes encoder and start encoder actor
Sourcepub fn with_market_state_preloader(&mut self) -> Result<&mut Self>
pub fn with_market_state_preloader(&mut self) -> Result<&mut Self>
Starts market state preloader
Sourcepub fn with_market_state_preloader_virtual(
&mut self,
address_to_copy: Vec<Address>,
) -> Result<&mut Self>
pub fn with_market_state_preloader_virtual( &mut self, address_to_copy: Vec<Address>, ) -> Result<&mut Self>
Starts preloaded virtual artefacts
Sourcepub fn with_nonce_and_balance_monitor(&mut self) -> Result<&mut Self>
pub fn with_nonce_and_balance_monitor(&mut self) -> Result<&mut Self>
Starts nonce and balance monitor
pub fn with_nonce_and_balance_monitor_only_events( &mut self, ) -> Result<&mut Self>
Sourcepub fn with_block_history(&mut self) -> Result<&mut Self>
pub fn with_block_history(&mut self) -> Result<&mut Self>
Starts block history actor
Sourcepub fn with_price_station(&mut self) -> Result<&mut Self>
pub fn with_price_station(&mut self) -> Result<&mut Self>
Starts token price calculator
Sourcepub fn with_block_events(
&mut self,
config: NodeBlockActorConfig,
) -> Result<&mut Self>
pub fn with_block_events( &mut self, config: NodeBlockActorConfig, ) -> Result<&mut Self>
Starts receiving blocks events through RPC
Sourcepub fn reth_node_with_blocks(
&mut self,
db_path: String,
config: NodeBlockActorConfig,
) -> Result<&mut Self>
pub fn reth_node_with_blocks( &mut self, db_path: String, config: NodeBlockActorConfig, ) -> Result<&mut Self>
Starts receiving blocks events through direct Reth DB access
Sourcepub fn with_exex_events(&mut self) -> Result<&mut Self>
pub fn with_exex_events(&mut self) -> Result<&mut Self>
Starts receiving blocks and mempool events through ExEx GRPC
Sourcepub fn mempool(&mut self) -> Result<&mut Self>
pub fn mempool(&mut self) -> Result<&mut Self>
Starts mempool actor collecting pending txes from all mempools and pulling new tx hashes in mempool_events channel
Sourcepub fn with_local_mempool_events(&mut self) -> Result<&mut Self>
pub fn with_local_mempool_events(&mut self) -> Result<&mut Self>
Starts local node pending tx provider
Sourcepub fn with_remote_mempool<PM, TM>(&mut self, provider: PM) -> Result<&mut Self>
pub fn with_remote_mempool<PM, TM>(&mut self, provider: PM) -> Result<&mut Self>
Starts remote node pending tx provider
pub fn with_geth_estimator(&mut self) -> Result<&mut Self>
Sourcepub fn with_evm_estimator(&mut self) -> Result<&mut Self>
pub fn with_evm_estimator(&mut self) -> Result<&mut Self>
Starts EVM gas estimator and tips filler
Sourcepub fn with_evm_estimator_and_provider(&mut self) -> Result<&mut Self>
pub fn with_evm_estimator_and_provider(&mut self) -> Result<&mut Self>
Starts EVM gas estimator and tips filler
Sourcepub fn with_flashbots_broadcaster(
&mut self,
smart: bool,
allow_broadcast: bool,
) -> Result<&mut Self>
pub fn with_flashbots_broadcaster( &mut self, smart: bool, allow_broadcast: bool, ) -> Result<&mut Self>
Starts flashbots broadcaster
Sourcepub fn with_composers(&mut self, allow_broadcast: bool) -> Result<&mut Self>
pub fn with_composers(&mut self, allow_broadcast: bool) -> Result<&mut Self>
Start composer : estimator, signer and broadcaster
Sourcepub fn with_health_monitor_pools(&mut self) -> Result<&mut Self>
pub fn with_health_monitor_pools(&mut self) -> Result<&mut Self>
Starts pool health monitor
Sourcepub fn with_health_monitor_stuffing_tx(&mut self) -> Result<&mut Self>
pub fn with_health_monitor_stuffing_tx(&mut self) -> Result<&mut Self>
Starts state health monitor Starts stuffing tx monitor
Sourcepub fn with_new_pool_loader(
&mut self,
pools_config: PoolsConfig,
) -> Result<&mut Self>
pub fn with_new_pool_loader( &mut self, pools_config: PoolsConfig, ) -> Result<&mut Self>
Start pool loader from new block events
Sourcepub fn with_pool_history_loader(
&mut self,
pools_config: PoolsConfig,
) -> Result<&mut Self>
pub fn with_pool_history_loader( &mut self, pools_config: PoolsConfig, ) -> Result<&mut Self>
Start pool loader for last 10000 blocks
Sourcepub fn with_pool_loader(&mut self) -> Result<&mut Self>
pub fn with_pool_loader(&mut self) -> Result<&mut Self>
Start pool loader from new block events
Sourcepub fn with_curve_pool_protocol_loader(&mut self) -> Result<&mut Self>
pub fn with_curve_pool_protocol_loader(&mut self) -> Result<&mut Self>
Start pool loader for curve + steth + wsteth
Sourcepub fn with_pool_loaders(
&mut self,
pools_config: PoolsConfig,
) -> Result<&mut Self>
pub fn with_pool_loaders( &mut self, pools_config: PoolsConfig, ) -> Result<&mut Self>
Start all pool loaders
pub fn with_preloaded_state( &mut self, pools: Vec<(Address, PoolClass)>, state_required: Option<RequiredState>, ) -> Result<&mut Self>
Sourcepub fn with_swap_path_merger(&mut self) -> Result<&mut Self>
pub fn with_swap_path_merger(&mut self) -> Result<&mut Self>
Start swap path merger
Sourcepub fn with_same_path_merger(&mut self) -> Result<&mut Self>
pub fn with_same_path_merger(&mut self) -> Result<&mut Self>
Start same path merger
Sourcepub fn with_diff_path_merger(&mut self) -> Result<&mut Self>
pub fn with_diff_path_merger(&mut self) -> Result<&mut Self>
Start diff path merger
Sourcepub fn with_mergers(&mut self) -> Result<&mut Self>
pub fn with_mergers(&mut self) -> Result<&mut Self>
Start all mergers
Sourcepub fn with_backrun_block(
&mut self,
backrun_config: BackrunConfig,
) -> Result<&mut Self>
pub fn with_backrun_block( &mut self, backrun_config: BackrunConfig, ) -> Result<&mut Self>
Start backrun on block
Sourcepub fn with_backrun_mempool(
&mut self,
backrun_config: BackrunConfig,
) -> Result<&mut Self>
pub fn with_backrun_mempool( &mut self, backrun_config: BackrunConfig, ) -> Result<&mut Self>
Start backrun for pending txs
Sourcepub async fn with_backrun(
&mut self,
backrun_config: BackrunConfig,
) -> Result<&mut Self>
pub async fn with_backrun( &mut self, backrun_config: BackrunConfig, ) -> Result<&mut Self>
Start backrun for blocks and pending txs
Sourcepub fn with_influxdb_writer(
&mut self,
url: String,
database: String,
tags: HashMap<String, String>,
) -> Result<&mut Self>
pub fn with_influxdb_writer( &mut self, url: String, database: String, tags: HashMap<String, String>, ) -> Result<&mut Self>
Start influxdb writer
Sourcepub fn with_block_latency_recorder(&mut self) -> Result<&mut Self>
pub fn with_block_latency_recorder(&mut self) -> Result<&mut Self>
Start block latency recorder
Sourcepub fn with_web_server<S>(
&mut self,
host: String,
router: Router<S>,
db_pool: DbPool,
) -> Result<&mut Self>
pub fn with_web_server<S>( &mut self, host: String, router: Router<S>, db_pool: DbPool, ) -> Result<&mut Self>
Start web server
Sourcepub fn with_wait_for_node_sync(&mut self) -> Result<&mut Self>
pub fn with_wait_for_node_sync(&mut self) -> Result<&mut Self>
Wait for node sync
Auto Trait Implementations§
impl<P, T, DB> Freeze for BlockchainActors<P, T, DB>where
P: Freeze,
impl<P, T, DB> !RefUnwindSafe for BlockchainActors<P, T, DB>
impl<P, T, DB> Send for BlockchainActors<P, T, DB>
impl<P, T, DB> Sync for BlockchainActors<P, T, DB>
impl<P, T, DB> Unpin for BlockchainActors<P, T, DB>
impl<P, T, DB> !UnwindSafe for BlockchainActors<P, T, DB>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§impl<T> IntoSql for T
impl<T> IntoSql for T
§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the foreground set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red()
and
green()
, which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg()
:
use yansi::{Paint, Color};
painted.fg(Color::White);
Set foreground color to white using white()
.
use yansi::Paint;
painted.white();
§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the background set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red()
and
on_green()
, which have the same functionality but
are pithier.
§Example
Set background color to red using fg()
:
use yansi::{Paint, Color};
painted.bg(Color::Red);
Set background color to red using on_red()
.
use yansi::Paint;
painted.on_red();
§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling [Attribute
] value
.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold()
and
underline()
, which have the same functionality
but are pithier.
§Example
Make text bold using attr()
:
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);
Make text bold using using bold()
.
use yansi::Paint;
painted.bold();
§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi
[Quirk
] value
.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask()
and
wrap()
, which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk()
:
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);
Enable wrapping using wrap()
.
use yansi::Paint;
painted.wrap();
§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting()
due to conflicts with Vec::clear()
.
The clear()
method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting()
due to conflicts with Vec::clear()
.
The clear()
method will be removed in a future release.§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the [Condition
] value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted
only when both stdout
and stderr
are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T, Conn> RunQueryDsl<Conn> for T
impl<T, Conn> RunQueryDsl<Conn> for T
§fn execute<'conn, 'query>(
self,
conn: &'conn mut Conn,
) -> <Conn as AsyncConnection>::ExecuteFuture<'conn, 'query>where
Conn: AsyncConnection + Send,
Self: ExecuteDsl<Conn> + 'query,
fn execute<'conn, 'query>(
self,
conn: &'conn mut Conn,
) -> <Conn as AsyncConnection>::ExecuteFuture<'conn, 'query>where
Conn: AsyncConnection + Send,
Self: ExecuteDsl<Conn> + 'query,
§fn load<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>where
U: Send,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
fn load<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>where
U: Send,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
§fn load_stream<'conn, 'query, U>(
self,
conn: &'conn mut Conn,
) -> Self::LoadFuture<'conn>where
Conn: AsyncConnection,
U: 'conn,
Self: LoadQuery<'query, Conn, U> + 'query,
fn load_stream<'conn, 'query, U>(
self,
conn: &'conn mut Conn,
) -> Self::LoadFuture<'conn>where
Conn: AsyncConnection,
U: 'conn,
Self: LoadQuery<'query, Conn, U> + 'query,
Stream
] with the returned rows. Read more§fn get_result<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: Self::Stream<'conn>) -> Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>>where
U: Send + 'conn,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
fn get_result<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: Self::Stream<'conn>) -> Map<StreamFuture<Pin<Box<Self::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<Self::Stream<'conn>>>)) -> Result<U, Error>>>where
U: Send + 'conn,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
§fn get_results<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>where
U: Send,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
fn get_results<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<Self::LoadFuture<'conn>, TryCollect<Self::Stream<'conn>, Vec<U>>, fn(_: Self::Stream<'conn>) -> TryCollect<Self::Stream<'conn>, Vec<U>>>where
U: Send,
Conn: AsyncConnection,
Self: LoadQuery<'query, Conn, U> + 'query,
Vec
with the affected rows. Read more§fn first<'query, 'conn, U>(
self,
conn: &'conn mut Conn,
) -> AndThen<<Self::Output as LoadQuery<'query, Conn, U>>::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: <Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>) -> Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>>
fn first<'query, 'conn, U>( self, conn: &'conn mut Conn, ) -> AndThen<<Self::Output as LoadQuery<'query, Conn, U>>::LoadFuture<'conn>, Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>, fn(_: <Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>) -> Map<StreamFuture<Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>>, fn(_: (Option<Result<U, Error>>, Pin<Box<<Self::Output as LoadQuery<'query, Conn, U>>::Stream<'conn>>>)) -> Result<U, Error>>>
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where
S: Into<Dispatch>,
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeArbitrary for T
impl<T> MaybeSend for Twhere
T: Send,
impl<T> MaybeSendSync for T
Layout§
Note: Unable to compute type layout, possibly due to this type having generic parameters. Layout can only be computed for concrete, fully-instantiated types.