pub struct Context { /* private fields */ }
Expand description
The gosling protocol implementation.
The Context
object provides various methods for starting and progressing identity and endpoint handshakes. The general usage pattern developers will follow is to construct a Context
object, connect to the Tor Network using Context::bootstrap()
, optionally start an identity or endpoint servers, and listen for and handle incoming identity and endpoint clients using Context::update()
and the various associated methods. Depending on the application’s requirements, the developer can also initiate identity and endpoint handshakes as necessary.
The Gosling Protocol specification can be found here:
Implementations§
Source§impl Context
impl Context
Sourcepub fn new(
tor_provider: Box<dyn TorProvider>,
identity_port: u16,
endpoint_port: u16,
identity_timeout: Duration,
identity_max_message_size: i32,
endpoint_timeout: Option<Duration>,
identity_private_key: Ed25519PrivateKey,
) -> Result<Self, Error>
pub fn new( tor_provider: Box<dyn TorProvider>, identity_port: u16, endpoint_port: u16, identity_timeout: Duration, identity_max_message_size: i32, endpoint_timeout: Option<Duration>, identity_private_key: Ed25519PrivateKey, ) -> Result<Self, Error>
Construct a new Context
object.
§Parameters
tor_provider
: an implementation of theTorProvider
trait which provides our Tor Network connectivityidentity_port
: the virt-port thisContext
’s identity server’s onion-service will listen on for new identity handshakes.endpoint_port
: the virt-port thisContext
‘s endpoint servers’ onion-services will listen on for new endpoint handshakes.identity_timeout
: the maximum amount of time thisContext
’ will allow an identity handshake to delay between steps before rejecting the request.identity_max_message_size
: the maximum size of the underlying Honk-RPC BSON message thisContext
’s identity handshake will send and accept.endpoint_timeout
: the maximum amount of time thisContext
’ will allow an endpoint handshake to delay between steps before rejecting the request.identity_private_key
: the ed25519 private key used to start thisContext
’s identity server’s onion-service
§Returns
A newly constructed Context
.
Sourcepub fn bootstrap(&mut self) -> Result<(), Error>
pub fn bootstrap(&mut self) -> Result<(), Error>
Initiate bootstrap of the Context
’s owned TorProvider
. Bootstrap status is communicated through ContextEvent
s returned from the Context::update()
method.
Sourcepub fn identity_client_begin_handshake(
&mut self,
identity_server_id: V3OnionServiceId,
endpoint: String,
) -> Result<HandshakeHandle, Error>
pub fn identity_client_begin_handshake( &mut self, identity_server_id: V3OnionServiceId, endpoint: String, ) -> Result<HandshakeHandle, Error>
Initiate an identity handshake with an identity server. Handshake progression is communicated through ContextEvent
s returned from the Context::update()
method.
§Parameters
identitity_server_id
: the long term identity onion-service service-id of a remote peerendpoint
: the ASCII-encoded requested endpoint
§Returns
A HandshakeHandle
used to refer to this particular identity handshake.
Sourcepub fn identity_client_abort_handshake(
&mut self,
handle: HandshakeHandle,
) -> Result<(), Error>
pub fn identity_client_abort_handshake( &mut self, handle: HandshakeHandle, ) -> Result<(), Error>
Abort an in-process outgoing identity handshake.
§Parameters
handle
: the handle of the in-progress outoing identity handshake to abort
Sourcepub fn identity_client_handle_challenge_received(
&mut self,
handle: HandshakeHandle,
challenge_response: Document,
) -> Result<(), Error>
pub fn identity_client_handle_challenge_received( &mut self, handle: HandshakeHandle, challenge_response: Document, ) -> Result<(), Error>
Handle an identity server’s endpoint challenge. Callers must construct an identity client’s endpoint challenge-response. The particulars of creating and verifying the challenge-response BSON documents are undefined and application-specific.
§Parameters
handle
: the handle of the in-progress outgoing identity handshakechallenge_response
: an application-specific BSON document which somehow responds to an identity server’s challenge.
Sourcepub fn identity_server_start(&mut self) -> Result<(), Error>
pub fn identity_server_start(&mut self) -> Result<(), Error>
Start this Context
’s identity server. Publish status is communicated through ContextEvent
s returned from the Context::update()
method.
Sourcepub fn identity_server_stop(&mut self) -> Result<(), Error>
pub fn identity_server_stop(&mut self) -> Result<(), Error>
Stops this Context
’s identity server and ends any in-progress incoming identity handshakes.
Sourcepub fn identity_server_handle_endpoint_request_received(
&mut self,
handle: HandshakeHandle,
client_allowed: bool,
endpoint_supported: bool,
endpoint_challenge: Document,
) -> Result<(), Error>
pub fn identity_server_handle_endpoint_request_received( &mut self, handle: HandshakeHandle, client_allowed: bool, endpoint_supported: bool, endpoint_challenge: Document, ) -> Result<(), Error>
Handle an identity client’s incoming endpoint request. Callers must determine whether the connected identity client is allowed to access the requested endpoint, decide whether the requested endpoint is supported by this Context
, and build an endpoint challenge for the identity client. The particulars of creating the endpoint challenge is undefined and application-specific.
§Parameters
handle
: the handle of the in-progress incoming identity handshakeclient_allowed
: whether the connected identity client is allowed to access the requested endpointendpoint_supported
: whether the requested endpoint is supportedendpoint_challenge
: an application-specific BSON document which the connected identity client must respond to
Sourcepub fn identity_server_handle_challenge_response_received(
&mut self,
handle: HandshakeHandle,
challenge_response_valid: bool,
) -> Result<(), Error>
pub fn identity_server_handle_challenge_response_received( &mut self, handle: HandshakeHandle, challenge_response_valid: bool, ) -> Result<(), Error>
Handle an identity client’s incoming endpoint challenge-response. Callers must determine whether the connected identity client’s challenge-response is valid. The particulars of verifying the challenge-response is undefined and application-specific.
§Parameters
handle
: the handle of the in-progress incoming identity handshakechallenge_response_valid
: whether the received challenge-response is valid
Sourcepub fn endpoint_client_begin_handshake(
&mut self,
endpoint_server_id: V3OnionServiceId,
client_auth_key: X25519PrivateKey,
channel: String,
) -> Result<HandshakeHandle, Error>
pub fn endpoint_client_begin_handshake( &mut self, endpoint_server_id: V3OnionServiceId, client_auth_key: X25519PrivateKey, channel: String, ) -> Result<HandshakeHandle, Error>
Initiate an endpoint handshake with an identity server. An endpoint client acquires the endpoint_server_id
and client_auth_key
by completing an identity handshake or through some other side-channnel. Handshake progression is communicated through ContextEvent
s returned from the Context::update()
method.
§Parameters
endpoint_server_id
: the endpoint onion-service service-id of a remote peerclient_uath_key
: the x25519 private-key required to decrypt the endpoint server’s onion-service descriptorchannel
: the ASCII-encoded requested channel
Sourcepub fn endpoint_client_abort_handshake(
&mut self,
handle: HandshakeHandle,
) -> Result<(), Error>
pub fn endpoint_client_abort_handshake( &mut self, handle: HandshakeHandle, ) -> Result<(), Error>
Abort an in-process outgoing endpoint handshake
§Parameters
handle
: the handle of the in-progress outoing identity handshake to abort
Sourcepub fn endpoint_server_start(
&mut self,
endpoint_private_key: Ed25519PrivateKey,
endpoint_name: String,
client_identity: V3OnionServiceId,
client_auth: X25519PublicKey,
) -> Result<(), Error>
pub fn endpoint_server_start( &mut self, endpoint_private_key: Ed25519PrivateKey, endpoint_name: String, client_identity: V3OnionServiceId, client_auth: X25519PublicKey, ) -> Result<(), Error>
Start one of this Context
’s endpoint servers. Publish status is communicated through ContextEvent
s returned from the Context::update()
method.
§Parameters
endpoint_private_key
: the ed25519 private key used to start this endpoint server’s onion-serviceendpoint_name
: the ASCII-encoded endpoint nameclient_identity
: the onion-service service-id of the client which will be connecting to this endpoint serverclient_auth
: the x25519 public-key used to encrypt the endpoint server’s onion-service descriptor
Sourcepub fn endpoint_server_handle_channel_request_received(
&mut self,
handle: HandshakeHandle,
channel_supported: bool,
) -> Result<(), Error>
pub fn endpoint_server_handle_channel_request_received( &mut self, handle: HandshakeHandle, channel_supported: bool, ) -> Result<(), Error>
Handle an endpoint client’s incoming channel request. Callers must determine whether the requested channel is supported by this Context
. The particulars of making this determination is undefined and application-specific.
§Parameters
handle
: the handle of the in-progress incoming endpoint handshakechannel_supported
: whether the requested channel is supported
Sourcepub fn endpoint_server_stop(
&mut self,
endpoint_identity: V3OnionServiceId,
) -> Result<(), Error>
pub fn endpoint_server_stop( &mut self, endpoint_identity: V3OnionServiceId, ) -> Result<(), Error>
Stop one of this Context
’s endpoint servers and ends any of its in-progress incoming endpoint handshakes.
§Parameters
endpoint_identity
: the onion-service service-id of the enpdoint server to stop
Sourcepub fn connect(
&mut self,
target_addr: TargetAddr,
circuit_token: Option<CircuitToken>,
) -> Result<OnionStream, Error>
pub fn connect( &mut self, target_addr: TargetAddr, circuit_token: Option<CircuitToken>, ) -> Result<OnionStream, Error>
A direct pass-through to the underlying TorProvider
’s TorProvider::connect()
method.
Sourcepub fn generate_circuit_token(&mut self) -> CircuitToken
pub fn generate_circuit_token(&mut self) -> CircuitToken
A direct pass-through to the underlying TorProvider
’s TorProvider::generate_token()
method.
Sourcepub fn release_circuit_token(&mut self, circuit_token: CircuitToken)
pub fn release_circuit_token(&mut self, circuit_token: CircuitToken)
A direct pass-through to the underlying TorProvider
’s TorProvider::release_token()
method.
Sourcepub fn update(&mut self) -> Result<VecDeque<ContextEvent>, Error>
pub fn update(&mut self) -> Result<VecDeque<ContextEvent>, Error>
This function updates the Context
’s underlying TorProvider
, handles new handshakes requests, and updates in-progress handshakes. This function needs to be regularly called to process the returned ContextEvent
s.
Auto Trait Implementations§
impl Freeze for Context
impl !RefUnwindSafe for Context
impl Send for Context
impl !Sync for Context
impl Unpin for Context
impl !UnwindSafe for Context
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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> 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>
, which can then be
downcast
into Box<dyn 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>
, which 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> DowncastSend for T
impl<T> DowncastSend 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<Source, Target> OctetsInto<Target> for Sourcewhere
Target: OctetsFrom<Source>,
impl<Source, Target> OctetsInto<Target> for Sourcewhere
Target: OctetsFrom<Source>,
type Error = <Target as OctetsFrom<Source>>::Error
§fn try_octets_into(
self,
) -> Result<Target, <Source as OctetsInto<Target>>::Error>
fn try_octets_into( self, ) -> Result<Target, <Source as OctetsInto<Target>>::Error>
§fn octets_into(self) -> Targetwhere
Self::Error: Into<Infallible>,
fn octets_into(self) -> Targetwhere
Self::Error: Into<Infallible>,
§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.