Files
spacedrive/core/src/api/libraries.rs
Oscar Beaumont a3292e2134 [ENG-1036] Fix library rename (#1300)
* Fix Library Rename + `RwLock` on `LibraryConfig`

* Input width fix

* cleanup

---------

Co-authored-by: ameer2468 <33054370+ameer2468@users.noreply.github.com>
2023-09-06 01:01:18 +00:00

150 lines
3.7 KiB
Rust

use crate::{
library::{LibraryConfig, LibraryName},
util::MaybeUndefined,
volume::get_volumes,
};
use chrono::Utc;
use rspc::alpha::AlphaRouter;
use sd_p2p::spacetunnel::RemoteIdentity;
use sd_prisma::prisma::statistics;
use serde::{Deserialize, Serialize};
use specta::Type;
use tracing::debug;
use uuid::Uuid;
use super::{
utils::{get_size, library},
Ctx, R,
};
// TODO(@Oscar): Replace with `specta::json`
#[derive(Serialize, Type)]
pub struct LibraryConfigWrapped {
pub uuid: Uuid,
pub instance_id: Uuid,
pub instance_public_key: RemoteIdentity,
pub config: LibraryConfig,
}
pub(crate) fn mount() -> AlphaRouter<Ctx> {
R.router()
.procedure("list", {
R.query(|node, _: ()| async move {
node.libraries
.get_all()
.await
.into_iter()
.map(|lib| LibraryConfigWrapped {
uuid: lib.id,
instance_id: lib.instance_uuid,
instance_public_key: lib.identity.to_remote_identity(),
config: lib.config(),
})
.collect::<Vec<_>>()
})
})
.procedure("statistics", {
R.with2(library())
.query(|(node, library), _: ()| async move {
// TODO: get from database if library is offline
// let _statistics = library
// .db
// .statistics()
// .find_unique(statistics::id::equals(library.node_local_id))
// .exec()
// .await?;
let volumes = get_volumes().await;
// save_volume(&library).await?;
let mut total_capacity: u64 = 0;
let mut available_capacity: u64 = 0;
for volume in volumes {
total_capacity += volume.total_capacity;
available_capacity += volume.available_capacity;
}
let library_db_size = get_size(
node.config
.data_directory()
.join("libraries")
.join(&format!("{}.db", library.id)),
)
.await
.unwrap_or(0);
let thumbnail_folder_size =
get_size(node.config.data_directory().join("thumbnails"))
.await
.unwrap_or(0);
use statistics::*;
let params = vec![
id::set(1), // Each library is a database so only one of these ever exists
date_captured::set(Utc::now().into()),
total_object_count::set(0),
library_db_size::set(library_db_size.to_string()),
total_bytes_used::set(0.to_string()),
total_bytes_capacity::set(total_capacity.to_string()),
total_unique_bytes::set(0.to_string()),
total_bytes_free::set(available_capacity.to_string()),
preview_media_bytes::set(thumbnail_folder_size.to_string()),
];
Ok(library
.db
.statistics()
.upsert(
statistics::id::equals(1), // Each library is a database so only one of these ever exists
statistics::create(params.clone()),
params,
)
.exec()
.await?)
})
})
.procedure("create", {
#[derive(Deserialize, Type)]
pub struct CreateLibraryArgs {
name: LibraryName,
}
R.mutation(|node, args: CreateLibraryArgs| async move {
debug!("Creating library");
let library = node.libraries.create(args.name, None, &node).await?;
debug!("Created library {}", library.id);
Ok(LibraryConfigWrapped {
uuid: library.id,
instance_id: library.instance_uuid,
instance_public_key: library.identity.to_remote_identity(),
config: library.config(),
})
})
})
.procedure("edit", {
#[derive(Type, Deserialize)]
pub struct EditLibraryArgs {
pub id: Uuid,
pub name: Option<LibraryName>,
pub description: MaybeUndefined<String>,
}
R.mutation(|node, args: EditLibraryArgs| async move {
Ok(node
.libraries
.edit(args.id, args.name, args.description)
.await?)
})
})
.procedure(
"delete",
R.mutation(|node, id: Uuid| async move {
node.libraries.delete(&id).await.map_err(Into::into)
}),
)
}