pub struct SessionStore { /* private fields */ }Expand description
Session store for SRBN persistence
Implementations§
Source§impl SessionStore
impl SessionStore
Sourcepub fn open_read_only(path: &Path) -> Result<Self>
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.
Sourcepub fn default_db_path() -> Result<PathBuf>
pub fn default_db_path() -> Result<PathBuf>
Get the default database path (~/.local/share/perspt/perspt.db or similar)
Sourcepub fn create_session(&self, session: &SessionRecord) -> Result<()>
pub fn create_session(&self, session: &SessionRecord) -> Result<()>
Create a new session
Sourcepub fn update_merkle_root(
&self,
session_id: &str,
merkle_root: &[u8],
) -> Result<()>
pub fn update_merkle_root( &self, session_id: &str, merkle_root: &[u8], ) -> Result<()>
Update session merkle root
Sourcepub fn record_node_state(&self, record: &NodeStateRecord) -> Result<()>
pub fn record_node_state(&self, record: &NodeStateRecord) -> Result<()>
Record node state
Sourcepub fn record_energy(&self, record: &EnergyRecord) -> Result<()>
pub fn record_energy(&self, record: &EnergyRecord) -> Result<()>
Record energy measurement
Sourcepub fn get_session(&self, session_id: &str) -> Result<Option<SessionRecord>>
pub fn get_session(&self, session_id: &str) -> Result<Option<SessionRecord>>
Get session by ID
Sourcepub fn get_session_dir(&self, session_id: &str) -> Result<PathBuf>
pub fn get_session_dir(&self, session_id: &str) -> Result<PathBuf>
Get the directory for session artifacts (~/.local/share/perspt/sessions/<id>)
Sourcepub fn create_session_dir(&self, session_id: &str) -> Result<PathBuf>
pub fn create_session_dir(&self, session_id: &str) -> Result<PathBuf>
Ensure a session directory exists and return the path
Sourcepub fn get_energy_history(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<EnergyRecord>>
pub fn get_energy_history( &self, session_id: &str, node_id: &str, ) -> Result<Vec<EnergyRecord>>
Get energy history for a node (query)
Sourcepub fn get_session_energy_history(
&self,
session_id: &str,
) -> Result<Vec<EnergyRecord>>
pub fn get_session_energy_history( &self, session_id: &str, ) -> Result<Vec<EnergyRecord>>
Get all energy history for a session (all nodes)
Sourcepub fn list_recent_sessions(&self, limit: usize) -> Result<Vec<SessionRecord>>
pub fn list_recent_sessions(&self, limit: usize) -> Result<Vec<SessionRecord>>
List recent sessions (newest first)
Sourcepub fn list_sessions_paginated(
&self,
limit: usize,
offset: usize,
) -> Result<Vec<SessionRecord>>
pub fn list_sessions_paginated( &self, limit: usize, offset: usize, ) -> Result<Vec<SessionRecord>>
List sessions with pagination (most recent first).
Sourcepub fn count_sessions(&self) -> Result<usize>
pub fn count_sessions(&self) -> Result<usize>
Count total number of sessions.
Sourcepub fn get_node_states(&self, session_id: &str) -> Result<Vec<NodeStateRecord>>
pub fn get_node_states(&self, session_id: &str) -> Result<Vec<NodeStateRecord>>
Get all node states for a session
Sourcepub fn update_session_status(
&self,
session_id: &str,
status: &str,
) -> Result<()>
pub fn update_session_status( &self, session_id: &str, status: &str, ) -> Result<()>
Update session status
Sourcepub fn record_llm_request(&self, record: &LlmRequestRecord) -> Result<()>
pub fn record_llm_request(&self, record: &LlmRequestRecord) -> Result<()>
Record an LLM request/response
Sourcepub fn get_llm_requests(
&self,
session_id: &str,
) -> Result<Vec<LlmRequestRecord>>
pub fn get_llm_requests( &self, session_id: &str, ) -> Result<Vec<LlmRequestRecord>>
Get LLM requests for a session
Sourcepub fn get_global_llm_summary(&self) -> Result<(i64, i64, i64, i64)>
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)
Sourcepub fn record_structural_digest(
&self,
record: &StructuralDigestRecord,
) -> Result<()>
pub fn record_structural_digest( &self, record: &StructuralDigestRecord, ) -> Result<()>
Record a structural digest
Sourcepub fn get_structural_digests(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<StructuralDigestRecord>>
pub fn get_structural_digests( &self, session_id: &str, node_id: &str, ) -> Result<Vec<StructuralDigestRecord>>
Get structural digests for a session and node
Sourcepub fn record_context_provenance(
&self,
record: &ContextProvenanceRecord,
) -> Result<()>
pub fn record_context_provenance( &self, record: &ContextProvenanceRecord, ) -> Result<()>
Record context provenance for a node
Sourcepub fn get_context_provenance(
&self,
session_id: &str,
node_id: &str,
) -> Result<Option<ContextProvenanceRecord>>
pub fn get_context_provenance( &self, session_id: &str, node_id: &str, ) -> Result<Option<ContextProvenanceRecord>>
Get context provenance for a session and node
Sourcepub fn record_escalation_report(
&self,
record: &EscalationReportRecord,
) -> Result<()>
pub fn record_escalation_report( &self, record: &EscalationReportRecord, ) -> Result<()>
Record an escalation report
Sourcepub fn get_escalation_reports(
&self,
session_id: &str,
) -> Result<Vec<EscalationReportRecord>>
pub fn get_escalation_reports( &self, session_id: &str, ) -> Result<Vec<EscalationReportRecord>>
Get escalation reports for a session
Sourcepub fn record_rewrite(&self, record: &RewriteRecordRow) -> Result<()>
pub fn record_rewrite(&self, record: &RewriteRecordRow) -> Result<()>
Record a local graph rewrite
Sourcepub fn get_rewrite_records(
&self,
session_id: &str,
) -> Result<Vec<RewriteRecordRow>>
pub fn get_rewrite_records( &self, session_id: &str, ) -> Result<Vec<RewriteRecordRow>>
Get rewrite records for a session
Sourcepub fn record_sheaf_validation(&self, record: &SheafValidationRow) -> Result<()>
pub fn record_sheaf_validation(&self, record: &SheafValidationRow) -> Result<()>
Record a sheaf validation result
Sourcepub fn get_sheaf_validations(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<SheafValidationRow>>
pub fn get_sheaf_validations( &self, session_id: &str, node_id: &str, ) -> Result<Vec<SheafValidationRow>>
Get sheaf validation results for a session and node
Sourcepub fn get_all_sheaf_validations(
&self,
session_id: &str,
) -> Result<Vec<SheafValidationRow>>
pub fn get_all_sheaf_validations( &self, session_id: &str, ) -> Result<Vec<SheafValidationRow>>
Get all sheaf validations for a session (all nodes).
Sourcepub fn record_provisional_branch(
&self,
record: &ProvisionalBranchRow,
) -> Result<()>
pub fn record_provisional_branch( &self, record: &ProvisionalBranchRow, ) -> Result<()>
Record a new provisional branch
Sourcepub fn update_branch_state(
&self,
branch_id: &str,
new_state: &str,
) -> Result<()>
pub fn update_branch_state( &self, branch_id: &str, new_state: &str, ) -> Result<()>
Update a provisional branch state
Sourcepub fn get_provisional_branches(
&self,
session_id: &str,
) -> Result<Vec<ProvisionalBranchRow>>
pub fn get_provisional_branches( &self, session_id: &str, ) -> Result<Vec<ProvisionalBranchRow>>
Get all provisional branches for a session
Sourcepub fn get_live_branches_for_parent(
&self,
session_id: &str,
parent_node_id: &str,
) -> Result<Vec<ProvisionalBranchRow>>
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
Sourcepub fn flush_branches_for_parent(
&self,
session_id: &str,
parent_node_id: &str,
) -> Result<Vec<String>>
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
Sourcepub fn record_branch_lineage(&self, record: &BranchLineageRow) -> Result<()>
pub fn record_branch_lineage(&self, record: &BranchLineageRow) -> Result<()>
Record a branch lineage edge
Sourcepub fn get_child_branches(&self, parent_branch_id: &str) -> Result<Vec<String>>
pub fn get_child_branches(&self, parent_branch_id: &str) -> Result<Vec<String>>
Get child branch IDs for a parent branch
Sourcepub fn record_interface_seal(&self, record: &InterfaceSealRow) -> Result<()>
pub fn record_interface_seal(&self, record: &InterfaceSealRow) -> Result<()>
Record an interface seal
Sourcepub fn get_interface_seals(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<InterfaceSealRow>>
pub fn get_interface_seals( &self, session_id: &str, node_id: &str, ) -> Result<Vec<InterfaceSealRow>>
Get all interface seals for a node
Sourcepub fn has_interface_seals(
&self,
session_id: &str,
node_id: &str,
) -> Result<bool>
pub fn has_interface_seals( &self, session_id: &str, node_id: &str, ) -> Result<bool>
Check whether a node has any interface seals
Sourcepub fn record_branch_flush(&self, record: &BranchFlushRow) -> Result<()>
pub fn record_branch_flush(&self, record: &BranchFlushRow) -> Result<()>
Record a branch flush decision
Sourcepub fn get_branch_flushes(
&self,
session_id: &str,
) -> Result<Vec<BranchFlushRow>>
pub fn get_branch_flushes( &self, session_id: &str, ) -> Result<Vec<BranchFlushRow>>
Get all branch flush records for a session
Sourcepub fn get_latest_node_states(
&self,
session_id: &str,
) -> Result<Vec<NodeStateRecord>>
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.
Sourcepub fn record_task_graph_edge(&self, record: &TaskGraphEdgeRow) -> Result<()>
pub fn record_task_graph_edge(&self, record: &TaskGraphEdgeRow) -> Result<()>
Record a task graph edge (parent→child dependency)
Sourcepub fn get_task_graph_edges(
&self,
session_id: &str,
) -> Result<Vec<TaskGraphEdgeRow>>
pub fn get_task_graph_edges( &self, session_id: &str, ) -> Result<Vec<TaskGraphEdgeRow>>
Get all task graph edges for a session
Sourcepub fn record_review_outcome(&self, record: &ReviewOutcomeRow) -> Result<()>
pub fn record_review_outcome(&self, record: &ReviewOutcomeRow) -> Result<()>
Record a review outcome (approval, rejection, edit request)
Sourcepub fn get_review_outcomes(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<ReviewOutcomeRow>>
pub fn get_review_outcomes( &self, session_id: &str, node_id: &str, ) -> Result<Vec<ReviewOutcomeRow>>
Get all review outcomes for a node
Sourcepub fn get_latest_review_outcome(
&self,
session_id: &str,
node_id: &str,
) -> Result<Option<ReviewOutcomeRow>>
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
Sourcepub fn get_all_review_outcomes(
&self,
session_id: &str,
) -> Result<Vec<ReviewOutcomeRow>>
pub fn get_all_review_outcomes( &self, session_id: &str, ) -> Result<Vec<ReviewOutcomeRow>>
Get all review outcomes for a session (across all nodes).
Sourcepub fn record_verification_result(
&self,
record: &VerificationResultRow,
) -> Result<()>
pub fn record_verification_result( &self, record: &VerificationResultRow, ) -> Result<()>
Record a verification result snapshot for a node
Sourcepub fn get_verification_result(
&self,
session_id: &str,
node_id: &str,
) -> Result<Option<VerificationResultRow>>
pub fn get_verification_result( &self, session_id: &str, node_id: &str, ) -> Result<Option<VerificationResultRow>>
Get the latest verification result for a node
Sourcepub fn get_all_verification_results(
&self,
session_id: &str,
) -> Result<Vec<VerificationResultRow>>
pub fn get_all_verification_results( &self, session_id: &str, ) -> Result<Vec<VerificationResultRow>>
Get all verification results for a session (for status display)
Sourcepub fn record_artifact_bundle(&self, record: &ArtifactBundleRow) -> Result<()>
pub fn record_artifact_bundle(&self, record: &ArtifactBundleRow) -> Result<()>
Record an artifact bundle snapshot for a node
Sourcepub fn get_artifact_bundle(
&self,
session_id: &str,
node_id: &str,
) -> Result<Option<ArtifactBundleRow>>
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
impl SessionStore
Sourcepub fn record_feature_charter(&self, row: &FeatureCharterRow) -> Result<()>
pub fn record_feature_charter(&self, row: &FeatureCharterRow) -> Result<()>
Record a feature charter for a session.
Sourcepub fn get_feature_charter(
&self,
session_id: &str,
) -> Result<Option<FeatureCharterRow>>
pub fn get_feature_charter( &self, session_id: &str, ) -> Result<Option<FeatureCharterRow>>
Get the feature charter for a session.
Sourcepub fn record_plan_revision(&self, row: &PlanRevisionRow) -> Result<()>
pub fn record_plan_revision(&self, row: &PlanRevisionRow) -> Result<()>
Record a plan revision.
Sourcepub fn get_active_plan_revision(
&self,
session_id: &str,
) -> Result<Option<PlanRevisionRow>>
pub fn get_active_plan_revision( &self, session_id: &str, ) -> Result<Option<PlanRevisionRow>>
Get the active plan revision for a session.
Sourcepub fn get_plan_revisions(
&self,
session_id: &str,
) -> Result<Vec<PlanRevisionRow>>
pub fn get_plan_revisions( &self, session_id: &str, ) -> Result<Vec<PlanRevisionRow>>
Get all plan revisions for a session, ordered by sequence.
Sourcepub fn supersede_plan_revision(&self, revision_id: &str) -> Result<()>
pub fn supersede_plan_revision(&self, revision_id: &str) -> Result<()>
Supersede a plan revision (set status to ‘superseded’).
Sourcepub fn record_repair_footprint(&self, row: &RepairFootprintRow) -> Result<()>
pub fn record_repair_footprint(&self, row: &RepairFootprintRow) -> Result<()>
Record a repair footprint.
Sourcepub fn get_repair_footprints(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<RepairFootprintRow>>
pub fn get_repair_footprints( &self, session_id: &str, node_id: &str, ) -> Result<Vec<RepairFootprintRow>>
Get repair footprints for a node, ordered by attempt.
Sourcepub fn get_all_repair_footprints(
&self,
session_id: &str,
) -> Result<Vec<RepairFootprintRow>>
pub fn get_all_repair_footprints( &self, session_id: &str, ) -> Result<Vec<RepairFootprintRow>>
Get all repair footprints for a session (all nodes).
Sourcepub fn resolve_repair_footprint(&self, footprint_id: &str) -> Result<()>
pub fn resolve_repair_footprint(&self, footprint_id: &str) -> Result<()>
Mark a repair footprint as resolved.
Sourcepub fn upsert_budget_envelope(&self, row: &BudgetEnvelopeRow) -> Result<()>
pub fn upsert_budget_envelope(&self, row: &BudgetEnvelopeRow) -> Result<()>
Record or update a budget envelope for a session.
Sourcepub fn get_budget_envelope(
&self,
session_id: &str,
) -> Result<Option<BudgetEnvelopeRow>>
pub fn get_budget_envelope( &self, session_id: &str, ) -> Result<Option<BudgetEnvelopeRow>>
Get the budget envelope for a session.
Source§impl SessionStore
impl SessionStore
Sourcepub fn record_step(&self, record: &SrbnStepRecord) -> Result<()>
pub fn record_step(&self, record: &SrbnStepRecord) -> Result<()>
Record an orchestration step transition.
Sourcepub fn get_step_timeline(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<SrbnStepRecord>>
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.
Sourcepub fn get_session_steps(&self, session_id: &str) -> Result<Vec<SrbnStepRecord>>
pub fn get_session_steps(&self, session_id: &str) -> Result<Vec<SrbnStepRecord>>
Retrieve all step records for a session, ordered by id.
Sourcepub fn record_correction_attempt(
&self,
record: &CorrectionAttemptRow,
) -> Result<()>
pub fn record_correction_attempt( &self, record: &CorrectionAttemptRow, ) -> Result<()>
Record a correction attempt within a convergence loop.
Sourcepub fn get_correction_attempts(
&self,
session_id: &str,
node_id: &str,
) -> Result<Vec<CorrectionAttemptRow>>
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.
Sourcepub fn get_session_correction_attempts(
&self,
session_id: &str,
) -> Result<Vec<CorrectionAttemptRow>>
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.