chronis 0.5.3

Event-sourced task CLI powered by the AllSource embedded database (all-source.xyz)
Documentation
use serde::{Deserialize, Serialize};

use super::{
    error::ChronError,
    task::{Task, TaskType},
};

/// Timeline entry for a task event.
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct TimelineEntry {
    pub timestamp: String,
    pub event_type: String,
}

/// Task with its event timeline.
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct TaskDetail {
    pub task: Task,
    pub timeline: Vec<TimelineEntry>,
}

pub trait TaskRepository: Send + Sync {
    fn get_task(&self, id: &str) -> Result<Task, ChronError>;
    fn list_tasks(&self, status: Option<&str>) -> Result<Vec<Task>, ChronError>;
    fn ready_tasks(&self) -> Result<Vec<Task>, ChronError>;

    #[allow(clippy::too_many_arguments)]
    fn create_task(
        &self,
        id: &str,
        title: &str,
        priority: &str,
        blocked_by: &[String],
        task_type: TaskType,
        parent: Option<&str>,
        description: Option<&str>,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn children_of(&self, parent_id: &str) -> Result<Vec<Task>, ChronError>;

    fn claim_task(
        &self,
        id: &str,
        agent_id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn complete_task(
        &self,
        id: &str,
        reason: Option<&str>,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn approve_task(
        &self,
        id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn add_dependency(
        &self,
        task_id: &str,
        blocker_id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn remove_dependency(
        &self,
        task_id: &str,
        blocker_id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn get_task_detail(
        &self,
        id: &str,
    ) -> impl std::future::Future<Output = Result<TaskDetail, ChronError>> + Send;

    fn archive_task(
        &self,
        id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;

    fn unarchive_task(
        &self,
        id: &str,
    ) -> impl std::future::Future<Output = Result<(), ChronError>> + Send;
}