KeiSeiKit-1.0/_primitives/_rust/kei-scheduler/src/store.rs
Parfii-bot 0be354a920 KeiSeiKit-public — clean state
Single-commit clean baseline after security scrub of niche-tells,
project codenames, internal jargon, and contributor-email leaks.

Contents:
- 100 Rust crates (_primitives/_rust/)
- 37 agent manifests (_manifests/) + generated specs (_generated/)
- 67 user-invocable skills (skills/)
- 33 hooks (hooks/)
- Composition blocks (_blocks/)
- Documentation (docs/, README.md)
- TS adapter packages (_ts_packages/)
- Assembler (_assembler/)
- Roles (_roles/)
- Templates (_templates/)
- Forgejo CI (.forgejo/)

Author: Denis Parfionovich <info@greendragon.info>

License: see LICENSE.
2026-05-01 12:09:03 +08:00

32 lines
851 B
Rust

//! Scheduler store — thin shim over `kei_entity_store::Store`.
//!
//! Mirrors the kei-chat-store pattern: the engine owns DDL + migration
//! transactions, and this crate adds scheduler-specific SQL helpers
//! (`schedule`, `cancel`, `list_due`, `mark_run`) that live in sibling
//! modules.
use crate::schema::ALL_SCHEMAS;
use anyhow::Result;
use kei_entity_store::Store as EntityStore;
use rusqlite::Connection;
use std::path::Path;
pub struct Store {
inner: EntityStore,
}
impl Store {
pub fn open(path: &Path) -> Result<Self> {
let inner = EntityStore::open(path, ALL_SCHEMAS)?;
Ok(Self { inner })
}
pub fn open_memory() -> Result<Self> {
let inner = EntityStore::open_memory(ALL_SCHEMAS)?;
Ok(Self { inner })
}
pub fn conn(&self) -> &Connection {
self.inner.conn()
}
}