Skip to main content

ActrRef

Struct ActrRef 

Source
pub struct ActrRef { /* private fields */ }
Expand description

ActrRef - Lightweight reference to a running Actor

This is the primary handle returned by ActrNode::start().

Implementations§

Source§

impl ActrRef

Source

pub fn actor_id(&self) -> &ActrId

Get Actor ID

Source

pub async fn call<R: RpcRequest>(&self, request: R) -> ActorResult<R::Response>

Call the local workload with a typed RPC request.

Convenience wrapper around app_context().call(&Dest::Local, request). Use this from app-side code to invoke the local guest workload.

Source

pub async fn call_remote<R: RpcRequest>( &self, target: ActrId, request: R, ) -> ActorResult<R::Response>

Call a remote actor directly with a typed RPC request.

Convenience wrapper around app_context().call(&Dest::Actor(target), request). Use this when the client has no local guest workload and calls the remote actor directly.

Source

pub async fn discover_route_candidates( &self, target_type: &ActrType, count: usize, ) -> ActorResult<Vec<ActrId>>

Discover route candidates for the given actor type.

Returns up to count actor IDs registered under target_type. Convenience wrapper for app-side discovery without holding a RuntimeContext.

Note: The signaling protocol currently returns one candidate per request. This method will make up to count requests to collect multiple unique candidates.

Source

pub async fn app_context(&self) -> RuntimeContext

Create an application-side runtime context bound to this running actor.

Source

pub fn shutdown(&self)

Trigger Actor shutdown

This signals the Actor to stop, but does not wait for completion. Use wait_for_shutdown() to wait for cleanup to finish.

Source

pub async fn wait_for_shutdown(&self)

Wait for Actor to fully shutdown

This waits for the shutdown signal to be triggered. All background tasks will be aborted when the last ActrRef is dropped.

Source

pub fn is_shutting_down(&self) -> bool

Check if Actor is shutting down

Source

pub async fn wait_for_ctrl_c_and_shutdown(self) -> ActorResult<()>

This consumes the ActrRef and waits for signal (Ctrl+C / SIGTERM), then triggers shutdown.

§Example
let actr = node.start().await?;
actr.wait_for_ctrl_c_and_shutdown().await?;

Trait Implementations§

Source§

impl Clone for ActrRef

Source§

fn clone(&self) -> Self

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

Source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

Source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

Source§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> MaybeSendSync for T
where T: Send + Sync + ?Sized,

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more