pub struct Client { /* private fields */ }
Expand description
Main client type
A handle and API to interacting with a single federation. End user applications that want to support interacting with multiple federations at the same time, will need to instantiate and manage multiple instances of this struct.
Under the hood it is starting and managing service tasks, state machines, database and other resources required.
This type is shared externally and internally, and
ClientHandle
is responsible for external lifecycle management
and resource freeing of the Client
.
Implementations§
Source§impl Client
impl Client
Sourcepub async fn create_backup(&self, metadata: Metadata) -> Result<ClientBackup>
pub async fn create_backup(&self, metadata: Metadata) -> Result<ClientBackup>
Create a backup, include provided metadata
Sourcepub async fn backup_to_federation(&self, metadata: Metadata) -> Result<()>
pub async fn backup_to_federation(&self, metadata: Metadata) -> Result<()>
Prepare an encrypted backup and send it to federation for storing
Sourcepub fn validate_backup(&self, backup: &EncryptedClientBackup) -> Result<()>
pub fn validate_backup(&self, backup: &EncryptedClientBackup) -> Result<()>
Validate backup before sending it to federation
Sourcepub async fn upload_backup(&self, backup: &EncryptedClientBackup) -> Result<()>
pub async fn upload_backup(&self, backup: &EncryptedClientBackup) -> Result<()>
Upload backup
to federation
pub async fn download_backup_from_federation( &self, ) -> Result<Option<ClientBackup>>
Sourcepub async fn download_backup_from_federation_static(
api: &DynGlobalApi,
root_secret: &DerivableSecret,
decoders: &ModuleDecoderRegistry,
) -> Result<Option<ClientBackup>>
pub async fn download_backup_from_federation_static( api: &DynGlobalApi, root_secret: &DerivableSecret, decoders: &ModuleDecoderRegistry, ) -> Result<Option<ClientBackup>>
Download most recent valid backup found from the Federation
Sourcepub fn get_backup_id(&self) -> PublicKey
pub fn get_backup_id(&self) -> PublicKey
Backup id derived from the root secret key (public key used to self-sign backup requests)
pub fn get_backup_id_static(root_secret: &DerivableSecret) -> PublicKey
pub async fn get_decoded_client_secret<T: Decodable>(&self) -> Result<T>
Source§impl Client
impl Client
Sourcepub async fn builder(db: Database) -> Result<ClientBuilder>
pub async fn builder(db: Database) -> Result<ClientBuilder>
Initialize a client builder that can be configured to create a new client.
pub fn api(&self) -> &(dyn IGlobalFederationApi + 'static)
pub fn api_clone(&self) -> DynGlobalApi
Sourcepub fn task_group(&self) -> &TaskGroup
pub fn task_group(&self) -> &TaskGroup
Get the TaskGroup
that is tied to Client’s lifetime.
pub async fn get_config_from_db(db: &Database) -> Option<ClientConfig>
pub async fn get_api_secret_from_db(db: &Database) -> Option<String>
pub async fn store_encodable_client_secret<T: Encodable>( db: &Database, secret: T, ) -> Result<()>
pub async fn load_decodable_client_secret<T: Decodable>( db: &Database, ) -> Result<T>
pub async fn load_decodable_client_secret_opt<T: Decodable>( db: &Database, ) -> Result<Option<T>>
pub async fn load_or_generate_client_secret(db: &Database) -> Result<[u8; 64]>
pub async fn is_initialized(db: &Database) -> bool
pub fn start_executor(self: &Arc<Self>)
pub fn federation_id(&self) -> FederationId
pub async fn config(&self) -> ClientConfig
pub fn api_secret(&self) -> &Option<String>
pub fn decoders(&self) -> &ModuleDecoderRegistry
pub fn has_module(&self, instance: ModuleInstanceId) -> bool
pub fn get_internal_payment_markers(&self) -> Result<(PublicKey, u64)>
pub fn get_meta(&self, key: &str) -> Option<String>
pub async fn add_state_machines( &self, dbtx: &mut DatabaseTransaction<'_>, states: Vec<DynState>, ) -> AddStateMachinesResult
pub async fn get_active_operations(&self) -> HashSet<OperationId>
pub fn operation_log(&self) -> &OperationLog
Sourcepub fn meta_service(&self) -> &Arc<MetaService>
pub fn meta_service(&self) -> &Arc<MetaService>
Get the meta manager to read meta fields.
Sourcepub async fn finalize_and_submit_transaction<F, M>(
&self,
operation_id: OperationId,
operation_type: &str,
operation_meta: F,
tx_builder: TransactionBuilder,
) -> Result<(TransactionId, Vec<OutPoint>)>
pub async fn finalize_and_submit_transaction<F, M>( &self, operation_id: OperationId, operation_type: &str, operation_meta: F, tx_builder: TransactionBuilder, ) -> Result<(TransactionId, Vec<OutPoint>)>
Add funding and/or change to the transaction builder as needed, finalize the transaction and submit it to the federation.
§Errors
The function will return an error if the operation with given ID already exists.
§Panics
The function will panic if the database transaction collides with other and fails with others too often, this should not happen except for excessively concurrent scenarios.
pub async fn operation_exists(&self, operation_id: OperationId) -> bool
pub async fn operation_exists_dbtx( dbtx: &mut DatabaseTransaction<'_>, operation_id: OperationId, ) -> bool
pub async fn has_active_states(&self, operation_id: OperationId) -> bool
Sourcepub async fn await_primary_module_output(
&self,
operation_id: OperationId,
out_point: OutPoint,
) -> Result<()>
pub async fn await_primary_module_output( &self, operation_id: OperationId, out_point: OutPoint, ) -> Result<()>
Waits for an output from the primary module to reach its final state.
Sourcepub fn get_first_module<M: ClientModule>(
&self,
) -> Result<ClientModuleInstance<'_, M>>
pub fn get_first_module<M: ClientModule>( &self, ) -> Result<ClientModuleInstance<'_, M>>
Returns a reference to a typed module client instance by kind
pub fn get_module_client_dyn( &self, instance_id: ModuleInstanceId, ) -> Result<&(dyn IClientModule + Send + Sync)>
pub fn db(&self) -> &Database
Sourcepub async fn transaction_updates(
&self,
operation_id: OperationId,
) -> TransactionUpdates
pub async fn transaction_updates( &self, operation_id: OperationId, ) -> TransactionUpdates
Returns a stream of transaction updates for the given operation id that can later be used to watch for a specific transaction being accepted.
Sourcepub fn get_first_instance(
&self,
module_kind: &ModuleKind,
) -> Option<ModuleInstanceId>
pub fn get_first_instance( &self, module_kind: &ModuleKind, ) -> Option<ModuleInstanceId>
Returns the instance id of the first module of the given kind. The primary module will always be returned before any other modules (which themselves are ordered by their instance ID).
Sourcepub async fn root_secret_encoding<T: Decodable>(&self) -> Result<T>
pub async fn root_secret_encoding<T: Decodable>(&self) -> Result<T>
Returns the data from which the client’s root secret is derived (e.g. BIP39 seed phrase struct).
Sourcepub async fn await_primary_module_outputs(
&self,
operation_id: OperationId,
outputs: Vec<OutPoint>,
) -> Result<()>
pub async fn await_primary_module_outputs( &self, operation_id: OperationId, outputs: Vec<OutPoint>, ) -> Result<()>
Waits for outputs from the primary module to reach its final state.
Sourcepub async fn get_config_json(&self) -> JsonClientConfig
pub async fn get_config_json(&self) -> JsonClientConfig
Returns the config of the client in JSON format.
Compared to the consensus module format where module configs are binary encoded this format cannot be cryptographically verified but is easier to consume and to some degree human-readable.
Sourcepub fn primary_module(&self) -> &DynClientModule
pub fn primary_module(&self) -> &DynClientModule
Get the primary module
Sourcepub async fn get_balance(&self) -> Amount
pub async fn get_balance(&self) -> Amount
Balance available to the client for spending
Sourcepub async fn subscribe_balance_changes(&self) -> BoxStream<'static, Amount>
pub async fn subscribe_balance_changes(&self) -> BoxStream<'static, Amount>
Returns a stream that yields the current client balance every time it changes.
Sourcepub async fn refresh_peers_api_versions(
num_peers: NumPeers,
api: DynGlobalApi,
db: Database,
num_responses_sender: Sender<usize>,
)
pub async fn refresh_peers_api_versions( num_peers: NumPeers, api: DynGlobalApi, db: Database, num_responses_sender: Sender<usize>, )
Query the federation for API version support and then calculate the best API version to use (supported by most guardians).
Sourcepub fn supported_api_versions_summary_static(
config: &ClientConfig,
client_module_init: &ClientModuleInitRegistry,
) -> SupportedApiVersionsSummary
pub fn supported_api_versions_summary_static( config: &ClientConfig, client_module_init: &ClientModuleInitRegistry, ) -> SupportedApiVersionsSummary
SupportedApiVersionsSummary
that the client and its modules support
pub async fn load_and_refresh_common_api_version(&self) -> Result<ApiVersionSet>
Sourcepub async fn get_metadata(&self) -> Metadata
pub async fn get_metadata(&self) -> Metadata
Get the client Metadata
Sourcepub async fn set_metadata(&self, metadata: &Metadata)
pub async fn set_metadata(&self, metadata: &Metadata)
Set the client Metadata
pub fn has_pending_recoveries(&self) -> bool
Sourcepub async fn wait_for_all_recoveries(&self) -> Result<()>
pub async fn wait_for_all_recoveries(&self) -> Result<()>
Wait for all module recoveries to finish
This will block until the recovery task is done with recoveries. Returns success if all recovery tasks are complete (success case), or an error if some modules could not complete the recovery at the time.
A bit of a heavy approach.
Sourcepub fn subscribe_to_recovery_progress(
&self,
) -> impl Stream<Item = (ModuleInstanceId, RecoveryProgress)>
pub fn subscribe_to_recovery_progress( &self, ) -> impl Stream<Item = (ModuleInstanceId, RecoveryProgress)>
Subscribe to recover progress for all the modules.
This stream can contain duplicate progress for a module. Don’t use this stream for detecting completion of recovery.
pub async fn wait_for_module_kind_recovery( &self, module_kind: ModuleKind, ) -> Result<()>
pub async fn wait_for_all_active_state_machines(&self) -> Result<()>
Sourcepub async fn set_metadata_dbtx(
dbtx: &mut DatabaseTransaction<'_>,
metadata: &Metadata,
)
pub async fn set_metadata_dbtx( dbtx: &mut DatabaseTransaction<'_>, metadata: &Metadata, )
Set the client Metadata
Sourcepub async fn get_peer_url_announcements(
&self,
) -> BTreeMap<PeerId, SignedApiAnnouncement>
pub async fn get_peer_url_announcements( &self, ) -> BTreeMap<PeerId, SignedApiAnnouncement>
You likely want to use Client::get_peer_urls
. This function returns
only the announcements and doesn’t use the config as fallback.
Sourcepub async fn get_peer_urls(&self) -> BTreeMap<PeerId, SafeUrl>
pub async fn get_peer_urls(&self) -> BTreeMap<PeerId, SafeUrl>
Returns a list of guardian API URLs
Sourcepub async fn invite_code(&self, peer: PeerId) -> Option<InviteCode>
pub async fn invite_code(&self, peer: PeerId) -> Option<InviteCode>
Create an invite code with the api endpoint of the given peer which can be used to download this client config
Sourcepub async fn get_guardian_public_keys_blocking(
&self,
) -> BTreeMap<PeerId, PublicKey>
pub async fn get_guardian_public_keys_blocking( &self, ) -> BTreeMap<PeerId, PublicKey>
Blocks till the client has synced the guardian public key set (introduced in version 0.4) and returns it. Once it has been fetched once this function is guaranteed to return immediately.
pub fn handle_global_rpc( &self, method: String, params: Value, ) -> BoxStream<'_, Result<Value>>
pub async fn log_event<E>(&self, module_id: Option<ModuleInstanceId>, event: E)
pub async fn log_event_dbtx<E, Cap>( &self, dbtx: &mut DatabaseTransaction<'_, Cap>, module_id: Option<ModuleInstanceId>, event: E, )
pub async fn log_event_raw_dbtx<Cap>(
&self,
dbtx: &mut DatabaseTransaction<'_, Cap>,
kind: EventKind,
module: Option<(ModuleKind, ModuleInstanceId)>,
payload: Vec<u8>,
transient: bool,
)where
Cap: Send,
pub async fn handle_events<F, R, K>(
&self,
pos_key: &K,
call_fn: F,
) -> Result<()>where
K: DatabaseKey + DatabaseRecord + MaybeSend + MaybeSync + DatabaseRecord<Value = EventLogId>,
F: Fn(&mut DatabaseTransaction<'_, NonCommittable>, EventLogEntry) -> R,
R: Future<Output = Result<()>>,
pub async fn get_event_log( &self, pos: Option<EventLogId>, limit: u64, ) -> Vec<(EventLogId, EventKind, Option<(ModuleKind, ModuleInstanceId)>, u64, Value)>
pub async fn get_event_log_dbtx<Cap>(
&self,
dbtx: &mut DatabaseTransaction<'_, Cap>,
pos: Option<EventLogId>,
limit: u64,
) -> Vec<(EventLogId, EventKind, Option<(ModuleKind, ModuleInstanceId)>, u64, Value)>where
Cap: Send,
Sourcepub fn get_event_log_transient_receiver(&self) -> Receiver<EventLogEntry>
pub fn get_event_log_transient_receiver(&self) -> Receiver<EventLogEntry>
Register to receiver all new transient (unpersisted) events
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for Client
impl !RefUnwindSafe for Client
impl Send for Client
impl Sync for Client
impl Unpin for Client
impl !UnwindSafe for Client
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> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§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
.Source§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
.Source§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.Source§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.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> FmtForward for T
impl<T> FmtForward for T
Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.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> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
Source§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Source§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 moreSource§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 moreSource§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
Source§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
Source§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.Source§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.Source§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.Source§impl<T> Tap for T
impl<T> Tap for T
Source§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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 moreSource§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.Source§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.Source§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.Source§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.Source§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.Source§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.Source§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.