Skip to main content

ProviderEvent

Enum ProviderEvent 

Source
#[non_exhaustive]
pub enum ProviderEvent {
Show 14 variants Start { partial: Arc<AssistantMessage>, }, TextStart { content_index: usize, partial: Arc<AssistantMessage>, }, TextDelta { content_index: usize, delta: String, partial: Arc<AssistantMessage>, }, TextEnd { content_index: usize, content: String, partial: Arc<AssistantMessage>, }, ThinkingStart { content_index: usize, partial: Arc<AssistantMessage>, }, ThinkingDelta { content_index: usize, delta: String, partial: Arc<AssistantMessage>, }, ThinkingEnd { content_index: usize, content: String, partial: Arc<AssistantMessage>, }, ToolCallStart { content_index: usize, tool_call_id: Option<String>, tool_name: Option<String>, partial: Arc<AssistantMessage>, }, ToolCallDelta { content_index: usize, delta: String, partial: Arc<AssistantMessage>, }, ToolCallEnd { content_index: usize, tool_call: ToolCall, partial: Arc<AssistantMessage>, }, Done { reason: StopReason, message: AssistantMessage, }, Error { reason: StopReason, error: AssistantMessage, }, FallbackStart { from_model: String, to_model: String, reason: FallbackReason, }, FallbackExhausted { models_tried: Vec<String>, final_error: String, },
}
Expand description

Provider trait, streaming options, and provider registry. Streaming events emitted by providers

Note: We use crate::AssistantMessage directly to avoid type alias conflicts

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Start

Stream started with partial assistant message.

Fields

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

TextStart

Text content block started.

Fields

§content_index: usize

Index of the content block in the message.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

TextDelta

Incremental text delta received.

Fields

§content_index: usize

Index of the content block in the message.

§delta: String

The text delta to append.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

TextEnd

Text content block finished.

Fields

§content_index: usize

Index of the content block in the message.

§content: String

The complete text content.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ThinkingStart

Thinking content block started.

Fields

§content_index: usize

Index of the content block in the message.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ThinkingDelta

Incremental thinking delta received.

Fields

§content_index: usize

Index of the content block in the message.

§delta: String

The thinking text delta to append.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ThinkingEnd

Thinking content block finished.

Fields

§content_index: usize

Index of the content block in the message.

§content: String

The complete thinking content.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ToolCallStart

Tool call block started.

Fields

§content_index: usize

Index of the content block in the message.

§tool_call_id: Option<String>

The tool call ID from the provider, if available at start time. Providers that only surface the ID later (in deltas/end) leave this None.

§tool_name: Option<String>

The tool name, if available at start time.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ToolCallDelta

Tool call delta received (partial JSON arguments).

Fields

§content_index: usize

Index of the content block in the message.

§delta: String

The delta string to append to tool arguments.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

ToolCallEnd

Tool call block finished.

Fields

§content_index: usize

Index of the content block in the message.

§tool_call: ToolCall

The complete tool call with resolved arguments.

§partial: Arc<AssistantMessage>

Partial assistant message state.

§

Done

Stream completed successfully.

Fields

§reason: StopReason

Why the model stopped generating.

§message: AssistantMessage

The final assistant message.

§

Error

Stream ended with an error.

Fields

§reason: StopReason

The stop reason at time of error.

§error: AssistantMessage

Error details in assistant message form.

§

FallbackStart

Model fallback occurred — primary model replaced by fallback.

Emitted by MultiProvider when it switches from one model to another in the candidate list due to errors, circuit breaker opens, etc.

Fields

§from_model: String

Model that was being attempted.

§to_model: String

Model that will be used instead.

§reason: FallbackReason

Reason for the fallback.

§

FallbackExhausted

Fallback chain exhausted — all models failed.

Emitted by MultiProvider when all candidates in the fallback chain have been exhausted without success.

Fields

§models_tried: Vec<String>

All models that were tried, in order.

§final_error: String

Final error from the last model.

Implementations§

Source§

impl ProviderEvent

Source

pub fn partial(&self) -> Option<&AssistantMessage>

Extract the partial assistant message if present

Source

pub fn is_done(&self) -> bool

Check if this is a done event

Source

pub fn is_error(&self) -> bool

Check if this is an error event

Source

pub fn is_fallback(&self) -> bool

Check if this is a fallback event

Source

pub fn is_fallback_exhausted(&self) -> bool

Check if this is a fallback exhausted event

Trait Implementations§

Source§

impl Clone for ProviderEvent

Source§

fn clone(&self) -> ProviderEvent

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

impl Debug for ProviderEvent

Source§

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

Formats the value using the given formatter. 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<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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: 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: 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
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,