Struct arti_client::builder::TorClientBuilder
source · pub struct TorClientBuilder<R: Runtime> {
runtime: R,
config: TorClientConfig,
bootstrap_behavior: BootstrapBehavior,
dirmgr_builder: Arc<dyn DirProviderBuilder<R>>,
local_resource_timeout: Option<Duration>,
dirfilter: FilterConfig,
}
Expand description
An object for constructing a TorClient
.
Returned by TorClient::builder()
.
Fields§
§runtime: R
The runtime for the client to use
config: TorClientConfig
The client’s configuration.
bootstrap_behavior: BootstrapBehavior
How the client should behave when it is asked to do something on the Tor
network before bootstrap()
is called.
dirmgr_builder: Arc<dyn DirProviderBuilder<R>>
Optional object to construct a DirProvider.
Wrapped in an Arc so that we don’t need to force DirProviderBuilder to implement Clone.
local_resource_timeout: Option<Duration>
If present, an amount of time to wait when trying to acquire the filesystem locks for our storage.
dirfilter: FilterConfig
dirfilter
only.Optional directory filter to install for testing purposes.
Only available when arti-client
is built with the dirfilter
and experimental-api
features.
Implementations§
source§impl<R: Runtime> TorClientBuilder<R>
impl<R: Runtime> TorClientBuilder<R>
sourcepub fn config(self, config: TorClientConfig) -> Self
pub fn config(self, config: TorClientConfig) -> Self
Set the configuration for the TorClient
under construction.
If not called, then a compiled-in default configuration will be used.
sourcepub fn bootstrap_behavior(self, bootstrap_behavior: BootstrapBehavior) -> Self
pub fn bootstrap_behavior(self, bootstrap_behavior: BootstrapBehavior) -> Self
Set the bootstrap behavior for the TorClient
under construction.
If not called, then the default (BootstrapBehavior::OnDemand
) will
be used.
sourcepub fn local_resource_timeout(self, timeout: Duration) -> Self
pub fn local_resource_timeout(self, timeout: Duration) -> Self
Set a timeout that we should allow when trying to acquire our local resources (including lock files.)
If no timeout is set, we wait for a short while (currently 500 msec) when invoked with
create_bootstrapped
or
create_unbootstrapped_async
,
and we do not wait at all if invoked with
create_unbootstrapped
.
(This difference in default behavior is meant to avoid unintentional blocking.
If you call this method, subsequent calls to crate_bootstrapped
may block
the current thread.)
The provided timeout value may not be larger than MAX_LOCAL_RESOURCE_TIMEOUT
.
sourcepub fn dirmgr_builder<B>(self, builder: Arc<dyn DirProviderBuilder<R>>) -> Selfwhere
B: DirProviderBuilder<R> + 'static,
Available on crate features experimental-api
and error_detail
only.
pub fn dirmgr_builder<B>(self, builder: Arc<dyn DirProviderBuilder<R>>) -> Selfwhere
B: DirProviderBuilder<R> + 'static,
experimental-api
and error_detail
only.Override the default function used to construct the directory provider.
Only available when compiled with the experimental-api
feature: this
code is unstable.
sourcepub fn dirfilter<F>(self, filter: F) -> Self
Available on crate feature dirfilter
only.
pub fn dirfilter<F>(self, filter: F) -> Self
dirfilter
only.Install a DirFilter
to
Only available when compiled with the dirfilter
feature: this code
is unstable and not recommended for production use.
sourcepub fn create_unbootstrapped(&self) -> Result<TorClient<R>>
pub fn create_unbootstrapped(&self) -> Result<TorClient<R>>
Create a TorClient
from this builder, without automatically launching
the bootstrap process.
If you have left the default BootstrapBehavior
in place, the client
will bootstrap itself as soon any attempt is made to use it. You can
also bootstrap the client yourself by running its
bootstrap()
method.
If you have replaced the default behavior with BootstrapBehavior::Manual
,
any attempts to use the client will fail with an error of kind
ErrorKind::BootstrapRequired
,
until you have called TorClient::bootstrap
yourself.
This option is useful if you wish to have control over the bootstrap
process (for example, you might wish to avoid initiating network
connections until explicit user confirmation is given).
If a local_resource_timeout has been set, this function may
block the current thread.
Use create_unbootstrapped_async
if that is not what you want.
sourcepub async fn create_unbootstrapped_async(&self) -> Result<TorClient<R>>
pub async fn create_unbootstrapped_async(&self) -> Result<TorClient<R>>
Like create_unbootstrapped, but does not block the thread while trying to acquire the lock.
If no local_resource_timeout
has been set, this function may
delay a short while (currently 500 msec) for local resources (such as lock files) to be available.
Set local_resource_timeout
to 0 if you do not want this behavior.
sourcefn create_unbootstrapped_inner<F>(
&self,
now: F,
give_up_at: Instant,
first_attempt: bool,
) -> StdResult<Result<TorClient<R>>, Duration>
fn create_unbootstrapped_inner<F>( &self, now: F, give_up_at: Instant, first_attempt: bool, ) -> StdResult<Result<TorClient<R>>, Duration>
Helper for create_bootstrapped and create_bootstrapped_async.
Does not retry on LocalResourceAlreadyInUse
; instead, returns a time that we should wait,
and log a message if first_attempt
is true.
sourcepub async fn create_bootstrapped(&self) -> Result<TorClient<R>>
pub async fn create_bootstrapped(&self) -> Result<TorClient<R>>
Create a TorClient from this builder, and try to bootstrap it.
sourcefn local_resource_timeout_or(&self, dflt: Duration) -> Result<Duration>
fn local_resource_timeout_or(&self, dflt: Duration) -> Result<Duration>
Return the local_resource_timeout, or dflt
if none is defined.
Give an error if the value is above MAX_LOCAL_RESOURCE_TIMEOUT
sourcepub fn create_inert(&self) -> Result<InertTorClient>
pub fn create_inert(&self) -> Result<InertTorClient>
Create an InertTorClient
from this builder, without launching
the bootstrap process, or connecting to the network.
It is currently unspecified whether constructing an InertTorClient
will hold any locks that prevent opening a TorClient
with the same
directories.
Trait Implementations§
source§impl<R: Clone + Runtime> Clone for TorClientBuilder<R>
impl<R: Clone + Runtime> Clone for TorClientBuilder<R>
source§fn clone(&self) -> TorClientBuilder<R>
fn clone(&self) -> TorClientBuilder<R>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moreAuto Trait Implementations§
impl<R> Freeze for TorClientBuilder<R>where
R: Freeze,
impl<R> !RefUnwindSafe for TorClientBuilder<R>
impl<R> Send for TorClientBuilder<R>
impl<R> Sync for TorClientBuilder<R>
impl<R> Unpin for TorClientBuilder<R>where
R: Unpin,
impl<R> !UnwindSafe for TorClientBuilder<R>
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,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)§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> 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> 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 more§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> 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.