use actix_files as fs;
use actix_web::{web, App, HttpServer};
use db::Database;
use dotenv;
pub mod api;
pub mod db;
pub mod pages;
pub mod serve_middleware;
use crate::db::AppData;
#[actix_web::main]
async fn main() -> std::io::Result<()> {
dotenv::dotenv().ok();
env_logger::init();
let args: Vec<String> = dorsal::collect_arguments();
let port_search: Option<String> = dorsal::get_named_argument(&args, "port");
let mut port: u16 = 8080;
if port_search.is_some() {
port = port_search.unwrap().parse::<u16>().unwrap();
}
let static_dir_flag: Option<String> = dorsal::get_named_argument(&args, "static-dir");
let db_type: Option<String> = dorsal::get_named_argument(&args, "db-type");
let db_host: Option<String> = dorsal::get_var("DB_HOST");
let db_user: Option<String> = dorsal::get_var("DB_USER");
let db_pass: Option<String> = dorsal::get_var("DB_PASS");
let db_name: Option<String> = dorsal::get_var("DB_NAME");
let db_is_other: bool = db_type
.clone()
.is_some_and(|x| (x == String::from("postgres")) | (x == String::from("mysql")));
if db_is_other && (db_user.is_none() | db_pass.is_none() | db_name.is_none()) {
panic!("Missing required database config settings!");
}
let db: Database = Database::new(dorsal::DatabaseOpts {
_type: db_type,
host: db_host,
user: if db_is_other {
db_user.unwrap()
} else {
String::new()
},
pass: if db_is_other {
db_pass.unwrap()
} else {
String::new()
},
name: if db_is_other {
db_name.unwrap()
} else {
String::new()
},
})
.await;
db.init().await;
println!("Starting server at: http://localhost:{port}");
HttpServer::new(move || {
let client = awc::Client::default();
let data = web::Data::new(AppData {
db: db.clone(),
http_client: client,
engine: conductor::ConductorEngine::new(conductor::ConductorEngineConfig {
allow_builds: false,
allow_port_config: false,
}),
port: port,
});
let cors = actix_cors::Cors::default().send_wildcard();
App::new()
.app_data(web::Data::clone(&data))
.wrap(actix_web::middleware::Logger::default())
.wrap(cors)
.wrap(serve_middleware::ServeAssets)
.service(
fs::Files::new(
"/static",
if static_dir_flag.is_some() {
static_dir_flag.as_ref().unwrap()
} else {
"./static"
},
)
.show_files_listing(),
)
.service(fs::Files::new("/api/docs", "./target/doc").show_files_listing())
.service(crate::api::auth::callback_request)
.service(crate::api::projects::create_request)
.service(crate::api::projects::insert_file_request) .service(crate::api::projects::move_file_request) .service(crate::api::projects::update_metadata_request)
.service(crate::api::projects::update_fields_request)
.service(crate::api::projects::favorite_request)
.service(crate::api::projects::update_file_request) .service(crate::api::projects::delete_file_request) .service(crate::api::projects::delete_project_request)
.service(crate::api::auth::logout)
.service(crate::api::projects::get_project_files_request) .service(crate::api::projects::read_file_request) .service(crate::pages::home::home_request)
.service(crate::pages::dashboard::dashboard_request)
.service(crate::pages::dashboard::new_project_request)
.service(crate::pages::dashboard::projects_dashboard_request)
.service(crate::pages::admin::dashboard_request)
.service(crate::pages::admin::sql_viewer_request)
.service(crate::pages::dashboard::project_file_editor_request)
.service(crate::pages::dashboard::project_settings_request)
.service(crate::pages::dashboard::project_view_request)
.service(crate::pages::dashboard::project_public_view_request)
.service(crate::api::projects::read_file_global_request)
.service(crate::api::projects::read_project_global_request)
.default_service(web::to(|req, data| async {
return crate::pages::errors::error404(req, data).await;
}))
})
.bind(("0.0.0.0", port))?
.run()
.await
}