Create main.rs
This commit is contained in:
@@ -1,3 +1,44 @@
|
|||||||
fn main() {
|
mod controllers;
|
||||||
println!("Hello, world!");
|
mod routes;
|
||||||
|
mod utils;
|
||||||
|
|
||||||
|
use utils::init_database;
|
||||||
|
use anyhow::Result;
|
||||||
|
use axum::{
|
||||||
|
routing::{delete, get, post, put},
|
||||||
|
Router,
|
||||||
|
};
|
||||||
|
use routes::{admin, auth as auth_routes, machines, setup};
|
||||||
|
use tower_http::cors::CorsLayer;
|
||||||
|
|
||||||
|
#[tokio::main]
|
||||||
|
async fn main() -> Result<()> {
|
||||||
|
let pool = init_database().await?;
|
||||||
|
|
||||||
|
let app = Router::new()
|
||||||
|
.route("/setup/status", get(setup::get_setup_status))
|
||||||
|
.route("/setup/init", post(setup::init_setup))
|
||||||
|
|
||||||
|
.route("/auth/login", post(auth_routes::login))
|
||||||
|
.route("/auth/logout", post(auth_routes::logout))
|
||||||
|
|
||||||
|
.route("/admin/users", get(admin::get_users))
|
||||||
|
.route("/admin/users", post(admin::create_user_handler))
|
||||||
|
.route("/admin/users/:id", put(admin::update_user_handler))
|
||||||
|
.route("/admin/users/:id", delete(admin::delete_user_handler))
|
||||||
|
|
||||||
|
.route("/machines/register", post(machines::register_machine))
|
||||||
|
.route("/machines", get(machines::get_machines))
|
||||||
|
.route("/machines/:id", delete(machines::delete_machine))
|
||||||
|
|
||||||
|
.layer(CorsLayer::permissive())
|
||||||
|
|
||||||
|
.with_state(pool);
|
||||||
|
|
||||||
|
let listener = tokio::net::TcpListener::bind("0.0.0.0:8379").await?;
|
||||||
|
println!("Server running on http://0.0.0.0:8379");
|
||||||
|
|
||||||
|
axum::serve(listener, app).await?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user