theta 0.1.0-alpha.52

An Rust Actor Framework
Documentation
use std::{
    path::{Path, PathBuf},
    sync::OnceLock,
};

use crate::persistence::persistent_actor::PersistentStorage;

/// Cached project data directory path for local filesystem storage.
static DATA_DIR: OnceLock<PathBuf> = OnceLock::new();

/// Local filesystem storage backend for actor persistence.
pub struct LocalFs;

// Implementation

impl LocalFs {
    pub fn init(path: &Path) {
        DATA_DIR
            .set(path.to_path_buf())
            .expect("Failed to set project directory");
    }

    pub fn inst() -> &'static PathBuf {
        DATA_DIR
            .get()
            .expect("ProjectDir should be initialized before accessing it")
    }

    fn path(&self, id: crate::actor::ActorId) -> std::path::PathBuf {
        LocalFs::inst().join(format!("{}", id))
    }
}

impl PersistentStorage for LocalFs {
    async fn try_read(&self, id: crate::actor::ActorId) -> Result<Vec<u8>, anyhow::Error> {
        Ok(tokio::fs::read(self.path(id)).await?)
    }

    async fn try_write(
        &self,
        id: crate::actor::ActorId,
        bytes: Vec<u8>,
    ) -> Result<(), anyhow::Error> {
        let path = self.path(id);

        if let Some(parent) = path.parent() {
            tokio::fs::create_dir_all(parent).await?;
        }

        Ok(tokio::fs::write(&path, bytes).await?)
    }
}