pub struct Gateway {Show 13 fields
pub(crate) federation_manager: Arc<RwLock<FederationManager>>,
pub(crate) lightning_builder: Arc<dyn LightningBuilder + Send + Sync>,
pub(crate) state: Arc<RwLock<GatewayState>>,
pub(crate) client_builder: GatewayClientBuilder,
pub(crate) gateway_db: Database,
pub(crate) gateway_id: PublicKey,
pub(crate) versioned_api: SafeUrl,
pub(crate) listen: SocketAddr,
pub(crate) lightning_module_mode: LightningModuleMode,
pub(crate) task_group: TaskGroup,
pub(crate) bcrypt_password_hash: Arc<HashParts>,
pub(crate) num_route_hints: u32,
pub(crate) network: Network,
}
Fields§
§federation_manager: Arc<RwLock<FederationManager>>
The gateway’s federation manager.
lightning_builder: Arc<dyn LightningBuilder + Send + Sync>
Builder struct that allows the gateway to build a ILnRpcClient
, which
represents a connection to a lightning node.
state: Arc<RwLock<GatewayState>>
The current state of the Gateway.
client_builder: GatewayClientBuilder
Builder struct that allows the gateway to build a Fedimint client, which handles the communication with a federation.
gateway_db: Database
Database for Gateway metadata.
gateway_id: PublicKey
A public key representing the identity of the gateway. Private key is not used.
versioned_api: SafeUrl
The Gateway’s API URL.
listen: SocketAddr
The socket the gateway listens on.
lightning_module_mode: LightningModuleMode
The “module mode” of the gateway. Options are LNv1, LNv2, or All.
task_group: TaskGroup
The task group for all tasks related to the gateway.
bcrypt_password_hash: Arc<HashParts>
The bcrypt password hash used to authenticate the gateway.
This is an Arc
because bcrypt::HashParts
does not implement Clone
.
num_route_hints: u32
The number of route hints to include in LNv1 invoices.
network: Network
The Bitcoin network that the Lightning network is configured to.
Implementations§
Source§impl Gateway
impl Gateway
Sourcepub async fn new_with_custom_registry(
lightning_builder: Arc<dyn LightningBuilder + Send + Sync>,
client_builder: GatewayClientBuilder,
listen: SocketAddr,
api_addr: SafeUrl,
bcrypt_password_hash: HashParts,
network: Network,
num_route_hints: u32,
gateway_db: Database,
gateway_state: GatewayState,
lightning_module_mode: LightningModuleMode,
) -> Result<Gateway>
pub async fn new_with_custom_registry( lightning_builder: Arc<dyn LightningBuilder + Send + Sync>, client_builder: GatewayClientBuilder, listen: SocketAddr, api_addr: SafeUrl, bcrypt_password_hash: HashParts, network: Network, num_route_hints: u32, gateway_db: Database, gateway_state: GatewayState, lightning_module_mode: LightningModuleMode, ) -> Result<Gateway>
Creates a new gateway but with a custom module registry provided inside
client_builder
. Currently only used for testing.
Sourcepub async fn new_with_default_modules() -> Result<Gateway>
pub async fn new_with_default_modules() -> Result<Gateway>
Default function for creating a gateway with the Mint
, Wallet
, and
Gateway
modules.
Sourcepub(crate) async fn new(
lightning_builder: Arc<dyn LightningBuilder + Send + Sync>,
gateway_parameters: GatewayParameters,
gateway_db: Database,
client_builder: GatewayClientBuilder,
gateway_state: GatewayState,
) -> Result<Gateway>
pub(crate) async fn new( lightning_builder: Arc<dyn LightningBuilder + Send + Sync>, gateway_parameters: GatewayParameters, gateway_db: Database, client_builder: GatewayClientBuilder, gateway_state: GatewayState, ) -> Result<Gateway>
Helper function for creating a gateway from either
new_with_default_modules
or new_with_custom_registry
.
Sourcepub(crate) async fn load_or_create_gateway_id(
gateway_db: &Database,
) -> PublicKey
pub(crate) async fn load_or_create_gateway_id( gateway_db: &Database, ) -> PublicKey
Returns a PublicKey
that uniquely identifies the Gateway.
pub fn gateway_id(&self) -> PublicKey
pub fn versioned_api(&self) -> &SafeUrl
pub(crate) async fn get_state(&self) -> GatewayState
Sourcepub async fn dump_database(
dbtx: &mut DatabaseTransaction<'_>,
prefix_names: Vec<String>,
) -> BTreeMap<String, Box<dyn Serialize + Send>>
pub async fn dump_database( dbtx: &mut DatabaseTransaction<'_>, prefix_names: Vec<String>, ) -> BTreeMap<String, Box<dyn Serialize + Send>>
Reads and serializes structures from the Gateway’s database for the purpose for serializing to JSON for inspection.
Sourcepub async fn run(self, runtime: Arc<Runtime>) -> Result<TaskShutdownToken>
pub async fn run(self, runtime: Arc<Runtime>) -> Result<TaskShutdownToken>
Main entrypoint into the gateway that starts the client registration timer, loads the federation clients from the persisted config, begins listening for intercepted payments, and starts the webserver to service requests.
Sourcepub(crate) fn start_gateway(&self, runtime: Arc<Runtime>)
pub(crate) fn start_gateway(&self, runtime: Arc<Runtime>)
Begins the task for listening for intercepted payments from the lightning node.
Sourcepub(crate) async fn route_lightning_payments<'a>(
&'a self,
handle: &TaskHandle,
stream: RouteHtlcStream<'a>,
ln_client: Arc<dyn ILnRpcClient>,
) -> ReceivePaymentStreamAction
pub(crate) async fn route_lightning_payments<'a>( &'a self, handle: &TaskHandle, stream: RouteHtlcStream<'a>, ln_client: Arc<dyn ILnRpcClient>, ) -> ReceivePaymentStreamAction
Handles a stream of incoming payments from the lightning node after ensuring the gateway is properly configured. Awaits until the stream is closed, then returns with the appropriate action to take.
Sourcepub(crate) async fn is_shutting_down_safely(&self)
pub(crate) async fn is_shutting_down_safely(&self)
Polls the Gateway’s state waiting for it to shutdown so the thread processing payment requests can exit.
Sourcepub(crate) async fn handle_lightning_payment(
&self,
payment_request: InterceptPaymentRequest,
lightning_context: &LightningContext,
)
pub(crate) async fn handle_lightning_payment( &self, payment_request: InterceptPaymentRequest, lightning_context: &LightningContext, )
Handles an intercepted lightning payment. If the payment is part of an incoming payment to a federation, spawns a state machine and hands the payment off to it. Otherwise, forwards the payment to the next hop like a normal lightning node.
Sourcepub(crate) async fn try_handle_lightning_payment_lnv2(
&self,
htlc_request: &InterceptPaymentRequest,
lightning_context: &LightningContext,
) -> Result<()>
pub(crate) async fn try_handle_lightning_payment_lnv2( &self, htlc_request: &InterceptPaymentRequest, lightning_context: &LightningContext, ) -> Result<()>
Tries to handle a lightning payment using the LNv2 protocol.
Returns Ok
if the payment was handled, Err
otherwise.
Sourcepub(crate) async fn try_handle_lightning_payment_ln_legacy(
&self,
htlc_request: &InterceptPaymentRequest,
) -> Result<()>
pub(crate) async fn try_handle_lightning_payment_ln_legacy( &self, htlc_request: &InterceptPaymentRequest, ) -> Result<()>
Tries to handle a lightning payment using the legacy lightning protocol.
Returns Ok
if the payment was handled, Err
otherwise.
Sourcepub(crate) async fn forward_lightning_payment(
htlc_request: InterceptPaymentRequest,
lightning_context: &LightningContext,
)
pub(crate) async fn forward_lightning_payment( htlc_request: InterceptPaymentRequest, lightning_context: &LightningContext, )
Forwards a lightning payment to the next hop like a normal lightning node. Only necessary for LNv1, since LNv2 uses hold invoices instead of HTLC interception for routing incoming payments.
Sourcepub(crate) async fn set_gateway_state(&self, state: GatewayState)
pub(crate) async fn set_gateway_state(&self, state: GatewayState)
Helper function for atomically changing the Gateway’s internal state.
Sourcepub async fn handle_get_info(&self) -> AdminResult<GatewayInfo>
pub async fn handle_get_info(&self) -> AdminResult<GatewayInfo>
Returns information about the Gateway back to the client when requested via the webserver.
Sourcepub async fn handle_get_federation_config(
&self,
federation_id_or: Option<FederationId>,
) -> AdminResult<GatewayFedConfig>
pub async fn handle_get_federation_config( &self, federation_id_or: Option<FederationId>, ) -> AdminResult<GatewayFedConfig>
If the Gateway is connected to the Lightning node, returns the
ClientConfig
for each federation that the Gateway is connected to.
Sourcepub async fn handle_address_msg(
&self,
payload: DepositAddressPayload,
) -> AdminResult<Address>
pub async fn handle_address_msg( &self, payload: DepositAddressPayload, ) -> AdminResult<Address>
Returns a Bitcoin deposit on-chain address for pegging in Bitcoin for a specific connected federation.
Sourcepub async fn handle_withdraw_msg(
&self,
payload: WithdrawPayload,
) -> AdminResult<WithdrawResponse>
pub async fn handle_withdraw_msg( &self, payload: WithdrawPayload, ) -> AdminResult<WithdrawResponse>
Returns a Bitcoin TXID from a peg-out transaction for a specific connected federation.
Sourcepub(crate) async fn handle_create_invoice_for_operator_msg(
&self,
payload: CreateInvoiceForOperatorPayload,
) -> AdminResult<Bolt11Invoice>
pub(crate) async fn handle_create_invoice_for_operator_msg( &self, payload: CreateInvoiceForOperatorPayload, ) -> AdminResult<Bolt11Invoice>
Creates an invoice that is directly payable to the gateway’s lightning node.
Sourcepub(crate) async fn handle_pay_invoice_for_operator_msg(
&self,
payload: PayInvoiceForOperatorPayload,
) -> AdminResult<Preimage>
pub(crate) async fn handle_pay_invoice_for_operator_msg( &self, payload: PayInvoiceForOperatorPayload, ) -> AdminResult<Preimage>
Requests the gateway to pay an outgoing LN invoice using its own funds. Returns the payment hash’s preimage on success.
Sourcepub(crate) async fn handle_pay_invoice_msg(
&self,
payload: PayInvoicePayload,
) -> Result<Preimage>
pub(crate) async fn handle_pay_invoice_msg( &self, payload: PayInvoicePayload, ) -> Result<Preimage>
Requests the gateway to pay an outgoing LN invoice on behalf of a Fedimint client. Returns the payment hash’s preimage on success.
Sourcepub async fn handle_connect_federation(
&self,
payload: ConnectFedPayload,
) -> AdminResult<FederationInfo>
pub async fn handle_connect_federation( &self, payload: ConnectFedPayload, ) -> AdminResult<FederationInfo>
Handles a connection request to join a new federation. The gateway will download the federation’s client configuration, construct a new client, registers, the gateway with the federation, and persists the necessary config to reconstruct the client when restarting the gateway.
Sourcepub async fn handle_leave_federation(
&self,
payload: LeaveFedPayload,
) -> AdminResult<FederationInfo>
pub async fn handle_leave_federation( &self, payload: LeaveFedPayload, ) -> AdminResult<FederationInfo>
Handle a request to have the Gateway leave a federation. The Gateway will request the federation to remove the registration record and the gateway will remove the configuration needed to construct the federation client.
Sourcepub async fn handle_backup_msg(&self, __arg1: BackupPayload) -> AdminResult<()>
pub async fn handle_backup_msg(&self, __arg1: BackupPayload) -> AdminResult<()>
Handles a request for the gateway to backup a connected federation’s ecash.
Sourcepub async fn handle_mnemonic_msg(&self) -> AdminResult<MnemonicResponse>
pub async fn handle_mnemonic_msg(&self) -> AdminResult<MnemonicResponse>
Handles an authenticated request for the gateway’s mnemonic. This also returns a vector of federations that are not using the mnemonic backup strategy.
Sourcepub async fn handle_set_fees_msg(
&self,
__arg1: SetFeesPayload,
) -> AdminResult<()>
pub async fn handle_set_fees_msg( &self, __arg1: SetFeesPayload, ) -> AdminResult<()>
Handles a request to change the lightning or transaction fees for all
federations or a federation specified by the FederationId
.
Sourcepub async fn handle_get_ln_onchain_address_msg(&self) -> AdminResult<Address>
pub async fn handle_get_ln_onchain_address_msg(&self) -> AdminResult<Address>
Generates an onchain address to fund the gateway’s lightning node.
Sourcepub async fn handle_open_channel_msg(
&self,
payload: OpenChannelPayload,
) -> AdminResult<Txid>
pub async fn handle_open_channel_msg( &self, payload: OpenChannelPayload, ) -> AdminResult<Txid>
Instructs the Gateway’s Lightning node to open a channel to a peer
specified by pubkey
.
Sourcepub async fn handle_close_channels_with_peer_msg(
&self,
payload: CloseChannelsWithPeerPayload,
) -> AdminResult<CloseChannelsWithPeerResponse>
pub async fn handle_close_channels_with_peer_msg( &self, payload: CloseChannelsWithPeerPayload, ) -> AdminResult<CloseChannelsWithPeerResponse>
Instructs the Gateway’s Lightning node to close all channels with a peer
specified by pubkey
.
Sourcepub async fn handle_list_active_channels_msg(
&self,
) -> AdminResult<Vec<ChannelInfo>>
pub async fn handle_list_active_channels_msg( &self, ) -> AdminResult<Vec<ChannelInfo>>
Returns a list of Lightning network channels from the Gateway’s Lightning node.
Sourcepub async fn handle_send_onchain_msg(
&self,
payload: SendOnchainPayload,
) -> AdminResult<Txid>
pub async fn handle_send_onchain_msg( &self, payload: SendOnchainPayload, ) -> AdminResult<Txid>
Send funds from the gateway’s lightning node on-chain wallet.
Sourcepub async fn handle_get_balances_msg(&self) -> AdminResult<GatewayBalances>
pub async fn handle_get_balances_msg(&self) -> AdminResult<GatewayBalances>
Returns the ecash, lightning, and onchain balances for the gateway and the gateway’s lightning node.
pub async fn handle_spend_ecash_msg( &self, payload: SpendEcashPayload, ) -> AdminResult<SpendEcashResponse>
Sourcepub async fn handle_receive_ecash_msg(
&self,
payload: ReceiveEcashPayload,
) -> Result<ReceiveEcashResponse>
pub async fn handle_receive_ecash_msg( &self, payload: ReceiveEcashPayload, ) -> Result<ReceiveEcashResponse>
Handles a request to receive ecash into the gateway.
Sourcepub async fn handle_shutdown_msg(
&self,
task_group: TaskGroup,
) -> AdminResult<()>
pub async fn handle_shutdown_msg( &self, task_group: TaskGroup, ) -> AdminResult<()>
Instructs the gateway to shutdown, but only after all incoming payments have been handlded.
Sourcepub async fn handle_payment_log_msg(
&self,
__arg1: PaymentLogPayload,
) -> AdminResult<PaymentLogResponse>
pub async fn handle_payment_log_msg( &self, __arg1: PaymentLogPayload, ) -> AdminResult<PaymentLogResponse>
Queries the client log for payment events and returns to the user.
Sourcepub(crate) async fn register_federations(
&self,
federations: &BTreeMap<FederationId, FederationConfig>,
register_task_group: &TaskGroup,
)
pub(crate) async fn register_federations( &self, federations: &BTreeMap<FederationId, FederationConfig>, register_task_group: &TaskGroup, )
Registers the gateway with each specified federation.
Sourcepub async fn select_client(
&self,
federation_id: FederationId,
) -> Result<Spanned<ClientHandleArc>, FederationNotConnected>
pub async fn select_client( &self, federation_id: FederationId, ) -> Result<Spanned<ClientHandleArc>, FederationNotConnected>
Retrieves a ClientHandleArc
from the Gateway’s in memory structures
that keep track of available clients, given a federation_id
.
Sourcepub(crate) async fn load_or_generate_mnemonic(
gateway_db: &Database,
) -> AdminResult<Mnemonic>
pub(crate) async fn load_or_generate_mnemonic( gateway_db: &Database, ) -> AdminResult<Mnemonic>
Loads a mnemonic from the database or generates a new one if the mnemonic does not exist. Before generating a new mnemonic, this function will check if a mnemonic has been provided in the environment variable and use that if provided.
Sourcepub(crate) async fn load_clients(&self) -> AdminResult<()>
pub(crate) async fn load_clients(&self) -> AdminResult<()>
Reads the connected federation client configs from the Gateway’s database and reconstructs the clients necessary for interacting with connection federations.
Sourcepub(crate) fn register_clients_timer(&self)
pub(crate) fn register_clients_timer(&self)
Legacy mechanism for registering the Gateway with connected federations. This will spawn a task that will re-register the Gateway with connected federations every 8.5 mins. Only registers the Gateway if it has successfully connected to the Lightning node, so that it can include route hints in the registration.
Sourcepub(crate) async fn check_lnv1_federation_network(
client: &ClientHandleArc,
network: Network,
) -> AdminResult<()>
pub(crate) async fn check_lnv1_federation_network( client: &ClientHandleArc, network: Network, ) -> AdminResult<()>
Verifies that the supplied network
matches the Bitcoin network in the
connected client’s LNv1 configuration.
Sourcepub(crate) async fn check_lnv2_federation_network(
client: &ClientHandleArc,
network: Network,
) -> AdminResult<()>
pub(crate) async fn check_lnv2_federation_network( client: &ClientHandleArc, network: Network, ) -> AdminResult<()>
Verifies that the supplied network
matches the Bitcoin network in the
connected client’s LNv2 configuration.
Sourcepub async fn get_lightning_context(
&self,
) -> Result<LightningContext, LightningRpcError>
pub async fn get_lightning_context( &self, ) -> Result<LightningContext, LightningRpcError>
Checks the Gateway’s current state and returns the proper
LightningContext
if it is available. Sometimes the lightning node
will not be connected and this will return an error.
Sourcepub async fn unannounce_from_all_federations(&self)
pub async fn unannounce_from_all_federations(&self)
Iterates through all of the federations the gateway is registered with and requests to remove the registration record.
Source§impl Gateway
impl Gateway
Sourcepub(crate) async fn public_key_v2(
&self,
federation_id: &FederationId,
) -> Option<PublicKey>
pub(crate) async fn public_key_v2( &self, federation_id: &FederationId, ) -> Option<PublicKey>
Retrieves the PublicKey
of the Gateway module for a given federation
for LNv2. This is NOT the same as the gateway_id
, it is different
per-connected federation.
Sourcepub async fn routing_info_v2(
&self,
federation_id: &FederationId,
) -> Result<Option<RoutingInfo>>
pub async fn routing_info_v2( &self, federation_id: &FederationId, ) -> Result<Option<RoutingInfo>>
Returns payment information that LNv2 clients can use to instruct this Gateway to pay an invoice or receive a payment.
Sourcepub(crate) async fn send_payment_v2(
&self,
payload: SendPaymentPayload,
) -> Result<Result<[u8; 32], Signature>>
pub(crate) async fn send_payment_v2( &self, payload: SendPaymentPayload, ) -> Result<Result<[u8; 32], Signature>>
Instructs this gateway to pay a Lightning network invoice via the LNv2 protocol.
Sourcepub(crate) async fn create_bolt11_invoice_v2(
&self,
payload: CreateBolt11InvoicePayload,
) -> Result<Bolt11Invoice>
pub(crate) async fn create_bolt11_invoice_v2( &self, payload: CreateBolt11InvoicePayload, ) -> Result<Bolt11Invoice>
For the LNv2 protocol, this will create an invoice by fetching it from the connected Lightning node, then save the payment hash so that incoming lightning payments can be matched as a receive attempt to a specific federation.
Sourcepub async fn create_invoice_via_lnrpc_v2(
&self,
payment_hash: Hash,
amount: Amount,
description: Bolt11InvoiceDescription,
expiry_time: u32,
) -> Result<Bolt11Invoice, LightningRpcError>
pub async fn create_invoice_via_lnrpc_v2( &self, payment_hash: Hash, amount: Amount, description: Bolt11InvoiceDescription, expiry_time: u32, ) -> Result<Bolt11Invoice, LightningRpcError>
Retrieves a BOLT11 invoice from the connected Lightning node with a
specific payment_hash
.
Sourcepub async fn get_registered_incoming_contract_and_client_v2(
&self,
payment_image: PaymentImage,
amount_msats: u64,
) -> Result<(IncomingContract, ClientHandleArc)>
pub async fn get_registered_incoming_contract_and_client_v2( &self, payment_image: PaymentImage, amount_msats: u64, ) -> Result<(IncomingContract, ClientHandleArc)>
Retrieves the persisted CreateInvoicePayload
from the database
specified by the payment_hash
and the ClientHandleArc
specified
by the payload’s federation_id
.
Sourcepub(crate) fn is_running_lnv2(&self) -> bool
pub(crate) fn is_running_lnv2(&self) -> bool
Helper function for determining if the gateway supports LNv2.
Sourcepub(crate) fn is_running_lnv1(&self) -> bool
pub(crate) fn is_running_lnv1(&self) -> bool
Helper function for determining if the gateway supports LNv1.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for Gateway
impl !RefUnwindSafe for Gateway
impl Send for Gateway
impl Sync for Gateway
impl Unpin for Gateway
impl !UnwindSafe for Gateway
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.§impl<T> DowncastSync for T
impl<T> DowncastSync 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> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§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> 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
Source§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> 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> 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.