Skip to main content

RunFinishedEvent

Struct RunFinishedEvent 

Source
pub struct RunFinishedEvent {
    pub base: BaseEvent,
    pub thread_id: ThreadId,
    pub run_id: RunId,
    pub outcome: Option<RunFinishedOutcome>,
    pub result: Option<JsonValue>,
    pub interrupt: Option<InterruptInfo>,
}
Expand description

Event indicating that a run has finished.

This event is sent when an agent run completes, either successfully or with an interrupt requiring human input.

§Interrupt Flow

When outcome == Interrupt, the agent indicates that on the next run, a value needs to be provided via RunAgentInput.resume to continue.

§Example

use ag_ui_core::{RunFinishedEvent, RunFinishedOutcome, InterruptInfo, ThreadId, RunId};

// Success case
let success = RunFinishedEvent::new(ThreadId::random(), RunId::random())
    .with_result(serde_json::json!({"status": "done"}));

// Interrupt case
let interrupt = RunFinishedEvent::new(ThreadId::random(), RunId::random())
    .with_interrupt(
        InterruptInfo::new()
            .with_reason("human_approval")
            .with_payload(serde_json::json!({"action": "send_email"}))
    );

Fields§

§base: BaseEvent

Common event fields (timestamp, rawEvent).

§thread_id: ThreadId

The thread ID this run belongs to.

§run_id: RunId

The run ID that finished.

§outcome: Option<RunFinishedOutcome>

Outcome of the run. Optional for backward compatibility. When omitted, outcome is inferred: if interrupt is present, it’s Interrupt; otherwise Success.

§result: Option<JsonValue>

Optional result value from the run. Present when outcome is Success (or omitted with no interrupt).

§interrupt: Option<InterruptInfo>

Optional interrupt information. Present when outcome is Interrupt (or omitted with interrupt present).

Implementations§

Source§

impl RunFinishedEvent

Source

pub fn new(thread_id: impl Into<ThreadId>, run_id: impl Into<RunId>) -> Self

Creates a new RunFinishedEvent with Success outcome.

Source

pub fn with_outcome(self, outcome: RunFinishedOutcome) -> Self

Sets the outcome explicitly.

Source

pub fn with_result(self, result: JsonValue) -> Self

Sets the result for this event (implies Success outcome).

Source

pub fn with_interrupt(self, interrupt: InterruptInfo) -> Self

Sets the interrupt info (implies Interrupt outcome).

Source

pub fn with_timestamp(self, timestamp: f64) -> Self

Sets the timestamp for this event.

Source

pub fn effective_outcome(&self) -> RunFinishedOutcome

Returns the effective outcome of this event.

If outcome is explicitly set, returns that. Otherwise:

  • If interrupt is present, returns Interrupt
  • Otherwise, returns Success

Trait Implementations§

Source§

impl Clone for RunFinishedEvent

Source§

fn clone(&self) -> RunFinishedEvent

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for RunFinishedEvent

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for RunFinishedEvent

Source§

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 PartialEq for RunFinishedEvent

Source§

fn eq(&self, other: &RunFinishedEvent) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for RunFinishedEvent

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for RunFinishedEvent

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<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, 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> 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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,