pub struct JsonFileStore { /* private fields */ }Expand description
JSON-file-backed state store.
Each namespace is a single JSON file at
{root}/{namespace}.json. Writes are atomic: the new state is
written to a .tmp sibling and then renamed.
The root directory is provided at construction time; callers are
expected to resolve it from the service-layer AppDir abstraction
(typically ~/.algocline/state/).
§Concurrency
Per-namespace locks (std::sync::Mutex) prevent lost updates under
concurrent alc.state.* calls within the same process. The lock
is acquired for the full load → mutate → atomic-rename cycle, so
two tokio tasks operating on the same namespace are serialised.
Rationale for std::sync::Mutex over tokio::sync::Mutex:
all I/O inside the lock uses std::fs (synchronous, no .await),
so a standard mutex is sufficient and avoids holding a tokio mutex
across potential scheduler context switches.
Multi-process safety is NOT provided. If multiple alc
processes share the same state directory (uncommon), use a backend
with native INCR (Redis) or transactions (SQLite).
Implementations§
Source§impl JsonFileStore
impl JsonFileStore
Sourcepub fn new(root: PathBuf) -> Self
pub fn new(root: PathBuf) -> Self
Construct a store rooted at an explicit path.
The directory is not created eagerly; it is created lazily
on the first set / set_nx / incr call via Self::state_path.
Trait Implementations§
Source§impl StateStore for JsonFileStore
impl StateStore for JsonFileStore
Source§fn get(&self, ns: &str, key: &str) -> Result<Option<Value>, String>
fn get(&self, ns: &str, key: &str) -> Result<Option<Value>, String>
None if the key does not exist.Source§fn set(&self, ns: &str, key: &str, value: Value) -> Result<(), String>
fn set(&self, ns: &str, key: &str, value: Value) -> Result<(), String>
Source§fn delete(&self, ns: &str, key: &str) -> Result<bool, String>
fn delete(&self, ns: &str, key: &str) -> Result<bool, String>
true if it existed.Source§fn has(&self, ns: &str, key: &str) -> Result<bool, String>
fn has(&self, ns: &str, key: &str) -> Result<bool, String>
Auto Trait Implementations§
impl !Freeze for JsonFileStore
impl RefUnwindSafe for JsonFileStore
impl Send for JsonFileStore
impl Sync for JsonFileStore
impl Unpin for JsonFileStore
impl UnsafeUnpin for JsonFileStore
impl UnwindSafe for JsonFileStore
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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 moreSource§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.