Skip to main content

SessionStore

Struct SessionStore 

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

Session store for persistence.

Directory creation is lazy — the sessions directory is only created on the first call to save, not at construction time.

Implementations§

Source§

impl SessionStore

Source

pub fn new(sessions_dir: impl AsRef<Path>) -> Self

Create a new session store pointing at an explicit directory.

The directory is not created immediately — it will be created lazily on the first save.

Source

pub fn from_home(home: &AstridHome) -> Self

Create a session store from an AstridHome.

Sessions will be stored in ~/.astrid/sessions/. The directory is created lazily on first save.

Source

pub fn save(&self, session: &AgentSession) -> RuntimeResult<()>

Save a session atomically.

Writes to a temporary file first, then renames. This prevents corruption if the process crashes mid-write (session auto-saves after every turn).

§Errors

Returns an error if the session cannot be serialized or written to disk.

Source

pub fn load(&self, id: &SessionId) -> RuntimeResult<Option<AgentSession>>

Load a session by ID.

§Errors

Returns an error if the session file cannot be read or deserialized.

Source

pub fn load_by_str(&self, id: &str) -> RuntimeResult<Option<AgentSession>>

Load a session by ID string.

§Errors

Returns an error if the ID is not a valid UUID or the session cannot be loaded.

Source

pub fn delete(&self, id: &SessionId) -> RuntimeResult<()>

Delete a session.

§Errors

Returns an error if the session file cannot be deleted.

Source

pub fn list(&self) -> RuntimeResult<Vec<SessionId>>

List all session IDs, sorted by modification time (most recent first).

Returns an empty list if the sessions directory does not exist yet.

§Errors

Returns an error if the sessions directory cannot be read.

Source

pub fn list_with_metadata(&self) -> RuntimeResult<Vec<SessionSummary>>

List sessions with metadata.

§Errors

Returns an error if the sessions directory cannot be read.

Source

pub fn most_recent(&self) -> RuntimeResult<Option<AgentSession>>

Get the most recent session.

§Errors

Returns an error if the sessions cannot be listed or loaded.

Source

pub fn list_for_workspace( &self, workspace: &Path, ) -> RuntimeResult<Vec<SessionSummary>>

List sessions filtered by workspace path.

Only returns sessions whose workspace_path matches the given path.

§Errors

Returns an error if sessions cannot be listed or loaded.

Source

pub fn cleanup_old(&self, max_age_days: i64) -> RuntimeResult<usize>

Clean up old sessions (older than N days).

§Errors

Returns an error if the sessions cannot be listed.

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.

Source§

impl<T> GetSetFdFlags for T

Source§

fn get_fd_flags(&self) -> Result<FdFlags, Error>
where T: AsFilelike,

Query the “status” flags for the self file descriptor.
Source§

fn new_set_fd_flags(&self, fd_flags: FdFlags) -> Result<SetFdFlags<T>, Error>
where T: AsFilelike,

Create a new SetFdFlags value for use with set_fd_flags. Read more
Source§

fn set_fd_flags(&mut self, set_fd_flags: SetFdFlags<T>) -> Result<(), Error>
where T: AsFilelike,

Set the “status” flags for the self file descriptor. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Pointee for T

Source§

type Pointer = u32

Source§

fn debug( pointer: <T as Pointee>::Pointer, f: &mut Formatter<'_>, ) -> Result<(), Error>

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