Skip to main content

SessionIndexEntry

Struct SessionIndexEntry 

Source
pub struct SessionIndexEntry {
Show 29 fields pub id: String, pub kind: SessionKind, pub rel_path: String, pub title: String, pub title_version: u64, pub pinned: bool, pub parent_session_id: Option<String>, pub root_session_id: String, pub spawn_depth: u32, pub model: String, pub model_ref: Option<ProviderModelRef>, pub reasoning_effort: Option<ReasoningEffort>, pub gold_config_json: Option<String>, pub created_by_schedule_id: Option<String>, pub schedule_run_id: Option<String>, pub created_at: DateTime<Utc>, pub updated_at: DateTime<Utc>, pub last_activity_at: DateTime<Utc>, pub message_count: usize, pub has_attachments: bool, pub has_pending_question: bool, pub plan_mode: Option<PlanModeState>, pub bypass_permissions: bool, pub last_run_status: Option<String>, pub last_run_error: Option<String>, pub token_usage: Option<TokenBudgetUsage>, pub subagent_type: Option<String>, pub lifecycle: Option<String>, pub resident_name: Option<String>,
}

Fields§

§id: String§kind: SessionKind§rel_path: String

Path relative to bamboo_home_dir (e.g. “sessions/” or “sessions//children/”).

§title: String§title_version: u64§pinned: bool§parent_session_id: Option<String>§root_session_id: String§spawn_depth: u32§model: String§model_ref: Option<ProviderModelRef>§reasoning_effort: Option<ReasoningEffort>§gold_config_json: Option<String>

Raw session-level Gold config JSON mirrored from session.metadata["gold_config"]. Kept as a string here to avoid making infrastructure depend on bamboo-engine.

§created_by_schedule_id: Option<String>

If the session was created by a schedule, store the schedule id here for fast filtering.

§schedule_run_id: Option<String>

If the session was created by a specific schedule run, keep the run id here.

§created_at: DateTime<Utc>§updated_at: DateTime<Utc>§last_activity_at: DateTime<Utc>§message_count: usize§has_attachments: bool§has_pending_question: bool

Whether the session currently has a pending question awaiting user response. Mirrored into the index from session.has_pending_question() so the frontend can display the question dialog badge without loading session.json.

§plan_mode: Option<PlanModeState>

Active plan mode runtime state mirrored into the index from session.agent_runtime_state.plan_mode, so lightweight session-list/detail APIs can surface plan mode without loading every session.json.

§bypass_permissions: bool

Per-session “bypass permissions” toggle mirrored into the index from session.agent_runtime_state.bypass_permissions, so the session-list API can surface it without loading every session.json.

§last_run_status: Option<String>

Last known run status for this session (“pending” | “running” | “completed” | “error” | “cancelled” | “skipped”).

§last_run_error: Option<String>

Last known terminal error message, if any.

§token_usage: Option<TokenBudgetUsage>

Last token usage information (updated after each LLM call).

Stored in the global index so the frontend can display token usage without loading full session.json for every row.

§subagent_type: Option<String>

SubAgent profile id for child sessions spawned by SubAgent.create. Mirrored into the index from session.metadata["subagent_type"] so the frontend can render role badges (e.g. “general-purpose”, “plan”) on the child-session list without loading each session.json. None for root sessions and for legacy children created before this field was introduced.

§lifecycle: Option<String>

Child lifecycle: Some("resident") for a reusable resident agent (a stable session reused for successive tasks); None/absent for the default one-shot child. Mirrored from session.metadata["lifecycle"].

§resident_name: Option<String>

For a resident agent, the stable reuse key (scoped to root_session_id). Mirrored from session.metadata["resident_name"]; lets a later SubAgent.create find and reuse the resident without loading session.json.

Trait Implementations§

Source§

impl Clone for SessionIndexEntry

Source§

fn clone(&self) -> SessionIndexEntry

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 SessionIndexEntry

Source§

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

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

impl<'de> Deserialize<'de> for SessionIndexEntry

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 Serialize for SessionIndexEntry

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

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

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