use axum::extract::Multipart; use tokio::{fs::File, io::AsyncWriteExt}; use tokio_util::io::ReaderStream; use crate::{database, routing, PACKAGE_PATH}; use super::package::{Package, Publisher, Version}; pub async fn create_package(package: routing::Package) -> Option { let publisher = Publisher::new(package.publisher); let version = package .version .split('.') .filter_map(|splitted| splitted.parse::().ok()) .collect::>(); let version = Version::new(*version.get(0)?, *version.get(1)?, *version.get(2)?); let package = Package::new(package.name, publisher, version); match database::create_package(package).await { Ok(package_unchecked) => package_unchecked, Err(err_val) => { eprintln!("Error: Create Package | {}", err_val); None } } } pub async fn read_package(package_name: String) -> Option { match database::read_package(package_name).await { Ok(package_unchecked) => package_unchecked, Err(err_val) => { eprintln!("Error: Read Package | {}", err_val); None } } } pub async fn update_package(package_name: String, mut package: Package) -> Option { for dependency in package.get_dependencies() { if let Err(err_val) = database::read_package(dependency.to_string()).await { eprintln!("Error: Dependency | {}", err_val); } } package.set_last_update_date_time(); match database::update_package(package_name, package).await { Ok(package_unchecked) => package_unchecked, Err(err_val) => { eprintln!("Error: Update Package | {}", err_val); None } } } pub async fn delete_package(package_name: String) -> Option { match database::delete_package(package_name).await { Ok(package_unchecked) => package_unchecked, Err(err_val) => { eprintln!("Error: Delete Package | {}", err_val); None } } } pub async fn download_package(package_name: String) -> Option> { let package = crate::package::utils::read_package(package_name).await?; let package_file_stream = package.serve().await.ok()?; Some(package_file_stream) } pub async fn upload_package(mut package_file: Multipart) -> Option { let package_file_part = package_file.next_field().await.ok()??; let package_file_name = package_file_part.name()?.to_string(); let file_location = format!("{}/{}", PACKAGE_PATH, package_file_name); let package_file_data = package_file_part.bytes().await.ok()?; let mut package = crate::package::utils::read_package(package_file_name).await?; let mut file_descriptor = File::create(&file_location).await.ok()?; file_descriptor.write_all(&package_file_data).await.ok()?; package.set_location(&file_location.to_string()); package.set_hash().await.ok()?; let package = crate::package::utils::update_package(package.get_name(), package).await?; Some(package) } pub async fn read_all_packages() -> Option> { match database::read_all_packages().await { Ok(package_unchecked) => { if package_unchecked.is_empty() { None } else { Some(package_unchecked) } } Err(err_val) => { eprintln!("Error: Read All Package | {}", err_val); None } } }