use crate::{ entities::{ trash::{RepeatedTrash, TrashIdentifier}, }, errors::WorkspaceError, services::TrashCan, }; use flowy_dispatch::prelude::{data_result, Data, DataResult, Unit}; use std::{sync::Arc}; #[tracing::instrument(skip(controller), err)] pub(crate) async fn read_trash_handler(controller: Unit>) -> DataResult { let repeated_trash = controller.read_trash()?; data_result(repeated_trash) } #[tracing::instrument(skip(identifier, controller), err)] pub(crate) async fn putback_trash_handler( identifier: Data, controller: Unit>, ) -> Result<(), WorkspaceError> { let _ = controller.putback(&identifier.id).await?; Ok(()) } #[tracing::instrument(skip(identifier, controller), err)] pub(crate) async fn delete_trash_handler( identifier: Data, controller: Unit>, ) -> Result<(), WorkspaceError> { let _ = controller.delete(&identifier.id).await?; Ok(()) } #[tracing::instrument(skip(controller), err)] pub(crate) async fn restore_all_handler(controller: Unit>) -> Result<(), WorkspaceError> { let _ = controller.restore_all()?; Ok(()) } #[tracing::instrument(skip(controller), err)] pub(crate) async fn delete_all_handler(controller: Unit>) -> Result<(), WorkspaceError> { let _ = controller.delete_all()?; Ok(()) }