Struct holochain::conductor::state::AppInterfaceId
source · pub struct AppInterfaceId { /* private fields */ }
Expand description
A unique identifier used to refer to an App Interface internally.
Implementations§
source§impl AppInterfaceId
impl AppInterfaceId
sourcepub fn new(port: u16) -> Self
pub fn new(port: u16) -> Self
Create an id from the port
Examples found in repository?
More examples
src/conductor/conductor.rs (line 452)
447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496
pub async fn add_app_interface(
self: Arc<Self>,
port: either::Either<u16, AppInterfaceId>,
) -> ConductorResult<u16> {
let interface_id = match port {
either::Either::Left(port) => AppInterfaceId::new(port),
either::Either::Right(id) => id,
};
let port = interface_id.port();
tracing::debug!("Attaching interface {}", port);
let app_api = RealAppInterfaceApi::new(self.clone());
// This receiver is thrown away because we can produce infinite new
// receivers from the Sender
let (signal_tx, _r) = tokio::sync::broadcast::channel(SIGNAL_BUFFER_SIZE);
let stop_rx = self.task_manager.share_ref(|tm| {
tm.as_ref()
.expect("Task manager not initialized")
.task_stop_broadcaster()
.subscribe()
});
let (port, task) = spawn_app_interface_task(port, app_api, signal_tx.clone(), stop_rx)
.await
.map_err(Box::new)?;
// TODO: RELIABILITY: Handle this task by restarting it if it fails and log the error
self.manage_task(ManagedTaskAdd::ignore(
task,
&format!("app interface, port {}", port),
))
.await?;
let interface = AppInterfaceRuntime::Websocket { signal_tx };
self.app_interfaces.share_mut(|app_interfaces| {
if app_interfaces.contains_key(&interface_id) {
return Err(ConductorError::AppInterfaceIdCollision(
interface_id.clone(),
));
}
app_interfaces.insert(interface_id.clone(), interface);
Ok(())
})?;
let config = AppInterfaceConfig::websocket(port);
self.update_state(|mut state| {
state.app_interfaces.insert(interface_id, config);
Ok(state)
})
.await?;
tracing::debug!("App interface added at port: {}", port);
Ok(port)
}
sourcepub fn port(&self) -> u16
pub fn port(&self) -> u16
Get the port intended for this interface
Examples found in repository?
src/conductor/conductor.rs (line 455)
447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496
pub async fn add_app_interface(
self: Arc<Self>,
port: either::Either<u16, AppInterfaceId>,
) -> ConductorResult<u16> {
let interface_id = match port {
either::Either::Left(port) => AppInterfaceId::new(port),
either::Either::Right(id) => id,
};
let port = interface_id.port();
tracing::debug!("Attaching interface {}", port);
let app_api = RealAppInterfaceApi::new(self.clone());
// This receiver is thrown away because we can produce infinite new
// receivers from the Sender
let (signal_tx, _r) = tokio::sync::broadcast::channel(SIGNAL_BUFFER_SIZE);
let stop_rx = self.task_manager.share_ref(|tm| {
tm.as_ref()
.expect("Task manager not initialized")
.task_stop_broadcaster()
.subscribe()
});
let (port, task) = spawn_app_interface_task(port, app_api, signal_tx.clone(), stop_rx)
.await
.map_err(Box::new)?;
// TODO: RELIABILITY: Handle this task by restarting it if it fails and log the error
self.manage_task(ManagedTaskAdd::ignore(
task,
&format!("app interface, port {}", port),
))
.await?;
let interface = AppInterfaceRuntime::Websocket { signal_tx };
self.app_interfaces.share_mut(|app_interfaces| {
if app_interfaces.contains_key(&interface_id) {
return Err(ConductorError::AppInterfaceIdCollision(
interface_id.clone(),
));
}
app_interfaces.insert(interface_id.clone(), interface);
Ok(())
})?;
let config = AppInterfaceConfig::websocket(port);
self.update_state(|mut state| {
state.app_interfaces.insert(interface_id, config);
Ok(state)
})
.await?;
tracing::debug!("App interface added at port: {}", port);
Ok(port)
}
Trait Implementations§
source§impl Clone for AppInterfaceId
impl Clone for AppInterfaceId
source§fn clone(&self) -> AppInterfaceId
fn clone(&self) -> AppInterfaceId
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for AppInterfaceId
impl Debug for AppInterfaceId
source§impl Default for AppInterfaceId
impl Default for AppInterfaceId
source§impl<'de> Deserialize<'de> for AppInterfaceId
impl<'de> Deserialize<'de> for AppInterfaceId
source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl Hash for AppInterfaceId
impl Hash for AppInterfaceId
source§impl PartialEq<AppInterfaceId> for AppInterfaceId
impl PartialEq<AppInterfaceId> for AppInterfaceId
source§fn eq(&self, other: &AppInterfaceId) -> bool
fn eq(&self, other: &AppInterfaceId) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.source§impl Serialize for AppInterfaceId
impl Serialize for AppInterfaceId
impl Eq for AppInterfaceId
impl StructuralEq for AppInterfaceId
impl StructuralPartialEq for AppInterfaceId
Auto Trait Implementations§
impl RefUnwindSafe for AppInterfaceId
impl Send for AppInterfaceId
impl Sync for AppInterfaceId
impl Unpin for AppInterfaceId
impl UnwindSafe for AppInterfaceId
Blanket Implementations§
§impl<T> Any for Twhere
T: Any + ?Sized,
impl<T> Any for Twhere
T: Any + ?Sized,
§fn type_id_compat(&self) -> TypeId
fn type_id_compat(&self) -> TypeId
TODO: once 1.33.0 is the minimum supported compiler version, remove
Any::type_id_compat and use StdAny::type_id instead.
https://github.com/rust-lang/rust/issues/27745
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata
) -> <T as Pointee>::Metadata
fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata
) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
§impl<F, W, T, D> Deserialize<With<T, W>, D> for Fwhere
W: DeserializeWith<F, T, D>,
D: Fallible + ?Sized,
F: ?Sized,
impl<F, W, T, D> Deserialize<With<T, W>, D> for Fwhere
W: DeserializeWith<F, T, D>,
D: Fallible + ?Sized,
F: ?Sized,
§fn deserialize(
&self,
deserializer: &mut D
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize(
&self,
deserializer: &mut D
) -> Result<With<T, W>, <D as Fallible>::Error>
Deserializes using the given deserializer
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§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> ⓘ
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> 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> ⓘ
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.§impl<T> Upcastable for Twhere
T: 'static + Any + Send + Sync,
impl<T> Upcastable for Twhere
T: 'static + Any + Send + Sync,
§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref