Skip to main content

ProxyContext

Struct ProxyContext 

Source
pub struct ProxyContext {
Show 19 fields pub start_time: Instant, pub request_body: Vec<u8>, pub model: Option<String>, pub selected_backend: Option<BackendInfo>, pub provider_name: Option<String>, pub stream_state: Option<StreamState>, pub response_body: Vec<u8>, pub is_streaming: bool, pub rewritten_path: Option<String>, pub is_stream_response: bool, pub is_conversion_request: bool, pub stream_body_parsed_offset: usize, pub normalized_path: Option<String>, pub should_convert_stream_response: bool, pub upstream_status: Option<u16>, pub upstream_content_type: Option<String>, pub stream_chunks_parsed: usize, pub pending_conversation_messages: Option<Vec<ChatMessage>>, pub pending_instructions: Option<String>,
}
Expand description

Proxy context attached to each request session.

Fields§

§start_time: Instant

Request start time for duration tracking.

§request_body: Vec<u8>

Collected request body bytes.

§model: Option<String>

Model name parsed from request.

§selected_backend: Option<BackendInfo>

Selected backend for this request.

§provider_name: Option<String>

Provider name.

§stream_state: Option<StreamState>

Stream state for SSE conversion (also used for non-streaming conversion context).

§response_body: Vec<u8>

Response body collected for conversion.

§is_streaming: bool

Whether streaming is enabled.

§rewritten_path: Option<String>

Rewritten upstream path.

§is_stream_response: bool

Whether this is a streaming response (for conversion tracking).

§is_conversion_request: bool

Whether this is a conversion request (Responses API -> Chat API).

§stream_body_parsed_offset: usize

Offset in response_body that has been parsed (to avoid re-parsing events).

§normalized_path: Option<String>

Request path after optional routing prefix stripping.

§should_convert_stream_response: bool

Whether current upstream response should be converted as SSE stream.

§upstream_status: Option<u16>

Upstream status code captured in response_filter for diagnostics.

§upstream_content_type: Option<String>

Upstream content-type captured in response_filter for diagnostics.

§stream_chunks_parsed: usize

Number of valid upstream chat stream chunks parsed.

§pending_conversation_messages: Option<Vec<ChatMessage>>

Conversation messages before upstream response (for follow-up turn storage).

§pending_instructions: Option<String>

Effective instructions used for this request after previous_response expansion.

Implementations§

Source§

impl ProxyContext

Source

pub fn new() -> Self

Create a new proxy context.

Source

pub fn init_from_request_body(&mut self)

Parse model name and stream flag from request body. Initializes StreamState for ALL conversion requests (both streaming and non-streaming). StreamState holds ResponseRequestContext for protocol-aligned response generation.

Source

pub fn set_response_request_context(&mut self, context: ResponseRequestContext)

Set the response request context from a parsed ResponseRequest. This should be called during request_body_filter processing.

Trait Implementations§

Source§

impl Debug for ProxyContext

Source§

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

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

impl Default for ProxyContext

Source§

fn default() -> Self

Returns the “default value” for a type. 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> 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> Same for T

Source§

type Output = T

Should always be Self
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