Skip to main content

SessionStore

Struct SessionStore 

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

Session store for SRBN persistence

Implementations§

Source§

impl SessionStore

Source

pub fn new() -> Result<Self>

Create a new session store with default path

Source

pub fn open(path: &PathBuf) -> Result<Self>

Open a session store at the given path

Source

pub fn open_read_only(path: &Path) -> Result<Self>

Open a session store in read-only mode for concurrent dashboard reads.

Uses AccessMode::ReadOnly so the dashboard can read alongside the agent’s write lock. Does not call init_schema() (a write op). The database file must already exist.

Source

pub fn default_db_path() -> Result<PathBuf>

Get the default database path (~/.local/share/perspt/perspt.db or similar)

Source

pub fn create_session(&self, session: &SessionRecord) -> Result<()>

Create a new session

Source

pub fn update_merkle_root( &self, session_id: &str, merkle_root: &[u8], ) -> Result<()>

Update session merkle root

Source

pub fn record_node_state(&self, record: &NodeStateRecord) -> Result<()>

Record node state

Source

pub fn record_energy(&self, record: &EnergyRecord) -> Result<()>

Record energy measurement

Source

pub fn get_session(&self, session_id: &str) -> Result<Option<SessionRecord>>

Get session by ID

Source

pub fn get_session_dir(&self, session_id: &str) -> Result<PathBuf>

Get the directory for session artifacts (~/.local/share/perspt/sessions/<id>)

Source

pub fn create_session_dir(&self, session_id: &str) -> Result<PathBuf>

Ensure a session directory exists and return the path

Source

pub fn get_energy_history( &self, session_id: &str, node_id: &str, ) -> Result<Vec<EnergyRecord>>

Get energy history for a node (query)

Source

pub fn get_session_energy_history( &self, session_id: &str, ) -> Result<Vec<EnergyRecord>>

Get all energy history for a session (all nodes)

Source

pub fn list_recent_sessions(&self, limit: usize) -> Result<Vec<SessionRecord>>

List recent sessions (newest first)

Source

pub fn list_sessions_paginated( &self, limit: usize, offset: usize, ) -> Result<Vec<SessionRecord>>

List sessions with pagination (most recent first).

Source

pub fn count_sessions(&self) -> Result<usize>

Count total number of sessions.

Source

pub fn get_node_states(&self, session_id: &str) -> Result<Vec<NodeStateRecord>>

Get all node states for a session

Source

pub fn update_session_status( &self, session_id: &str, status: &str, ) -> Result<()>

Update session status

Source

pub fn record_llm_request(&self, record: &LlmRequestRecord) -> Result<()>

Record an LLM request/response

Source

pub fn get_llm_requests( &self, session_id: &str, ) -> Result<Vec<LlmRequestRecord>>

Get LLM requests for a session

Source

pub fn get_global_llm_summary(&self) -> Result<(i64, i64, i64, i64)>

Aggregate LLM statistics across all sessions: (count, sum_tokens_in, sum_tokens_out, sum_latency_ms)

Source

pub fn record_structural_digest( &self, record: &StructuralDigestRecord, ) -> Result<()>

Record a structural digest

Source

pub fn get_structural_digests( &self, session_id: &str, node_id: &str, ) -> Result<Vec<StructuralDigestRecord>>

Get structural digests for a session and node

Source

pub fn record_context_provenance( &self, record: &ContextProvenanceRecord, ) -> Result<()>

Record context provenance for a node

Source

pub fn get_context_provenance( &self, session_id: &str, node_id: &str, ) -> Result<Option<ContextProvenanceRecord>>

Get context provenance for a session and node

Source

pub fn record_escalation_report( &self, record: &EscalationReportRecord, ) -> Result<()>

Record an escalation report

Source

pub fn get_escalation_reports( &self, session_id: &str, ) -> Result<Vec<EscalationReportRecord>>

Get escalation reports for a session

Source

pub fn record_rewrite(&self, record: &RewriteRecordRow) -> Result<()>

Record a local graph rewrite

Source

pub fn get_rewrite_records( &self, session_id: &str, ) -> Result<Vec<RewriteRecordRow>>

Get rewrite records for a session

Source

pub fn record_sheaf_validation(&self, record: &SheafValidationRow) -> Result<()>

Record a sheaf validation result

Source

pub fn get_sheaf_validations( &self, session_id: &str, node_id: &str, ) -> Result<Vec<SheafValidationRow>>

Get sheaf validation results for a session and node

Source

pub fn get_all_sheaf_validations( &self, session_id: &str, ) -> Result<Vec<SheafValidationRow>>

Get all sheaf validations for a session (all nodes).

Source

pub fn record_provisional_branch( &self, record: &ProvisionalBranchRow, ) -> Result<()>

Record a new provisional branch

Source

pub fn update_branch_state( &self, branch_id: &str, new_state: &str, ) -> Result<()>

Update a provisional branch state

Source

pub fn get_provisional_branches( &self, session_id: &str, ) -> Result<Vec<ProvisionalBranchRow>>

Get all provisional branches for a session

Source

pub fn get_live_branches_for_parent( &self, session_id: &str, parent_node_id: &str, ) -> Result<Vec<ProvisionalBranchRow>>

Get live (active/sealed) provisional branches depending on a parent node

Source

pub fn flush_branches_for_parent( &self, session_id: &str, parent_node_id: &str, ) -> Result<Vec<String>>

Mark all live branches for a parent as flushed

Source

pub fn record_branch_lineage(&self, record: &BranchLineageRow) -> Result<()>

Record a branch lineage edge

Source

pub fn get_child_branches(&self, parent_branch_id: &str) -> Result<Vec<String>>

Get child branch IDs for a parent branch

Source

pub fn record_interface_seal(&self, record: &InterfaceSealRow) -> Result<()>

Record an interface seal

Source

pub fn get_interface_seals( &self, session_id: &str, node_id: &str, ) -> Result<Vec<InterfaceSealRow>>

Get all interface seals for a node

Source

pub fn has_interface_seals( &self, session_id: &str, node_id: &str, ) -> Result<bool>

Check whether a node has any interface seals

Source

pub fn record_branch_flush(&self, record: &BranchFlushRow) -> Result<()>

Record a branch flush decision

Source

pub fn get_branch_flushes( &self, session_id: &str, ) -> Result<Vec<BranchFlushRow>>

Get all branch flush records for a session

Source

pub fn get_latest_node_states( &self, session_id: &str, ) -> Result<Vec<NodeStateRecord>>

Get the latest node state snapshot per node for a session (for resume reconstruction).

Returns at most one record per node_id, picking the most recently created row.

Source

pub fn record_task_graph_edge(&self, record: &TaskGraphEdgeRow) -> Result<()>

Record a task graph edge (parent→child dependency)

Source

pub fn get_task_graph_edges( &self, session_id: &str, ) -> Result<Vec<TaskGraphEdgeRow>>

Get all task graph edges for a session

Source

pub fn record_review_outcome(&self, record: &ReviewOutcomeRow) -> Result<()>

Record a review outcome (approval, rejection, edit request)

Source

pub fn get_review_outcomes( &self, session_id: &str, node_id: &str, ) -> Result<Vec<ReviewOutcomeRow>>

Get all review outcomes for a node

Source

pub fn get_latest_review_outcome( &self, session_id: &str, node_id: &str, ) -> Result<Option<ReviewOutcomeRow>>

Get the most recent review outcome for a node

Source

pub fn get_all_review_outcomes( &self, session_id: &str, ) -> Result<Vec<ReviewOutcomeRow>>

Get all review outcomes for a session (across all nodes).

Source

pub fn record_verification_result( &self, record: &VerificationResultRow, ) -> Result<()>

Record a verification result snapshot for a node

Source

pub fn get_verification_result( &self, session_id: &str, node_id: &str, ) -> Result<Option<VerificationResultRow>>

Get the latest verification result for a node

Source

pub fn get_all_verification_results( &self, session_id: &str, ) -> Result<Vec<VerificationResultRow>>

Get all verification results for a session (for status display)

Source

pub fn record_artifact_bundle(&self, record: &ArtifactBundleRow) -> Result<()>

Record an artifact bundle snapshot for a node

Source

pub fn get_artifact_bundle( &self, session_id: &str, node_id: &str, ) -> Result<Option<ArtifactBundleRow>>

Get the latest artifact bundle for a node

Source§

impl SessionStore

Source

pub fn record_feature_charter(&self, row: &FeatureCharterRow) -> Result<()>

Record a feature charter for a session.

Source

pub fn get_feature_charter( &self, session_id: &str, ) -> Result<Option<FeatureCharterRow>>

Get the feature charter for a session.

Source

pub fn record_plan_revision(&self, row: &PlanRevisionRow) -> Result<()>

Record a plan revision.

Source

pub fn get_active_plan_revision( &self, session_id: &str, ) -> Result<Option<PlanRevisionRow>>

Get the active plan revision for a session.

Source

pub fn get_plan_revisions( &self, session_id: &str, ) -> Result<Vec<PlanRevisionRow>>

Get all plan revisions for a session, ordered by sequence.

Source

pub fn supersede_plan_revision(&self, revision_id: &str) -> Result<()>

Supersede a plan revision (set status to ‘superseded’).

Source

pub fn record_repair_footprint(&self, row: &RepairFootprintRow) -> Result<()>

Record a repair footprint.

Source

pub fn get_repair_footprints( &self, session_id: &str, node_id: &str, ) -> Result<Vec<RepairFootprintRow>>

Get repair footprints for a node, ordered by attempt.

Source

pub fn get_all_repair_footprints( &self, session_id: &str, ) -> Result<Vec<RepairFootprintRow>>

Get all repair footprints for a session (all nodes).

Source

pub fn resolve_repair_footprint(&self, footprint_id: &str) -> Result<()>

Mark a repair footprint as resolved.

Source

pub fn upsert_budget_envelope(&self, row: &BudgetEnvelopeRow) -> Result<()>

Record or update a budget envelope for a session.

Source

pub fn get_budget_envelope( &self, session_id: &str, ) -> Result<Option<BudgetEnvelopeRow>>

Get the budget envelope for a session.

Source§

impl SessionStore

Source

pub fn record_step(&self, record: &SrbnStepRecord) -> Result<()>

Record an orchestration step transition.

Source

pub fn get_step_timeline( &self, session_id: &str, node_id: &str, ) -> Result<Vec<SrbnStepRecord>>

Retrieve the step timeline for a given node in chronological order.

Source

pub fn get_session_steps(&self, session_id: &str) -> Result<Vec<SrbnStepRecord>>

Retrieve all step records for a session, ordered by id.

Source

pub fn record_correction_attempt( &self, record: &CorrectionAttemptRow, ) -> Result<()>

Record a correction attempt within a convergence loop.

Source

pub fn get_correction_attempts( &self, session_id: &str, node_id: &str, ) -> Result<Vec<CorrectionAttemptRow>>

Retrieve all correction attempts for a node, ordered by attempt number.

Source

pub fn get_session_correction_attempts( &self, session_id: &str, ) -> Result<Vec<CorrectionAttemptRow>>

Retrieve all correction attempts for a session, ordered by node then attempt.

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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.

§

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

§

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
§

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, 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.
§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,