storage/server/src/main.rs
2025-04-15 13:05:03 -05:00

93 lines
No EOL
2.6 KiB
Rust

use std::sync::Arc;
use log::{debug, error, info, trace, warn};
use rocket::{catch, launch, routes, Request, State};
use rocket::data::ByteUnit;
use rocket::fs::{relative, FileServer};
use rocket::futures::AsyncWriteExt;
use rocket_dyn_templates::handlebars::{handlebars_helper, Context, Handlebars, Helper, HelperResult, Output, RenderContext};
use rocket_dyn_templates::Template;
use sqlx::{migrate, Pool, Postgres};
use sqlx::postgres::PgPoolOptions;
use sqlx::types::Json;
use tokio::sync::Mutex;
use crate::managers::libraries::LibraryManager;
use crate::managers::repos::RepoManager;
use crate::objs::library::Library;
use crate::util::{setup_logger, JsonErrorResponse, ResponseError};
use routes::api;
use crate::routes::ui;
mod routes;
mod util;
mod storage;
mod library;
mod user;
mod models;
mod managers;
mod objs;
mod helpers;
pub type DB = Pool<Postgres>;
const MAX_UPLOAD_SIZE: ByteUnit = ByteUnit::Mebibyte(100_000);
#[launch]
async fn rocket() -> _ {
setup_logger();
dotenvy::dotenv().ok();
trace!("trace");
debug!("debug");
info!("info");
warn!("warn");
error!("error");
let pool = PgPoolOptions::new()
.max_connections(5)
.connect(std::env::var("DATABASE_URL").unwrap().as_str())
.await
.unwrap();
migrate!("./migrations")
.run(&pool)
.await.unwrap();
let repo_manager = {
let mut manager = RepoManager::new(pool.clone());
manager.fetch_repos().await.unwrap();
manager
};
let libraries_manager = {
let mut manager = LibraryManager::new(pool.clone(), repo_manager.clone());
Arc::new(Mutex::new(manager))
};
rocket::build()
.manage(pool)
.manage(repo_manager)
.manage(libraries_manager)
.mount("/static", FileServer::from(relative!("static")))
.mount("/api/library", routes![
api::library::move_file, api::library::upload_file, api::library::download_file, api::library::list_files, api::library::get_file, api::library::delete_file,
])
.mount("/", routes![
ui::user::index, ui::user::list_library_files, ui::user::get_library_file
])
.attach(Template::custom(|engines| {
let hb = &mut engines.handlebars;
hb.register_helper("bytes", Box::new(helpers::bytes));
hb.register_helper("debug", Box::new(helpers::debug));
}))
}
#[catch(404)]
fn not_found(req: &Request) -> ResponseError {
ResponseError::NotFound(
JsonErrorResponse {
code: "ROUTE_NOT_FOUND".to_string(),
message: "Route not found".to_string(),
}
)
}