summaryrefslogtreecommitdiff
path: root/src/main.rs
blob: ebce57e0e64d22550213b536fa40b6f4aefa205f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
use std::net::SocketAddr;
use axum::{Router, response::Response, http::{Request, StatusCode}, middleware::{Next, self}, extract::ConnectInfo, RequestExt, body::HttpBody, Extension};
use tower_cookies::CookieManagerLayer;
use tracing::metadata::LevelFilter;
use tracing_subscriber::{prelude::__tracing_subscriber_SubscriberExt, util::SubscriberInitExt, Layer, filter::filter_fn};
use types::response::ResponseCode;

use crate::{api::{pages, auth, users, posts}, types::extract::RouterURI};

mod api;
mod database;
mod types;
mod console;

async fn serve<B>(req: Request<B>, next: Next<B>) -> Response {
    let file = ResponseCode::Success.file(&req.uri().to_string()).await;
    if file.status() != StatusCode::OK {
        return next.run(req).await;
    }
    file
}

async fn log<B>(mut req: Request<B>, next: Next<B>) -> Response where 
    B: Send + Sync + 'static + HttpBody,
{

    let Ok(ConnectInfo(info)) = req.extract_parts::<ConnectInfo<SocketAddr>>().await else {
        return next.run(req).await
    };

    console::log(info.ip().clone(), req.method().clone(), req.uri().clone(), None, None).await;

    return next.run(req).await
}

async fn not_found() -> Response {
    ResponseCode::NotFound.file("/404.html").await
}

#[tokio::main]
async fn main() {

    database::init().unwrap();

    let fmt_layer = tracing_subscriber::fmt::layer();
    tracing_subscriber::registry() 
        .with(
            fmt_layer.with_filter(LevelFilter::TRACE).with_filter(filter_fn(|metadata| {
                metadata.target().starts_with("xssbook")
            }))
        )
        .init();

    let app = Router::new()
    .fallback(not_found)
    .nest("/", pages::router())
    .layer(middleware::from_fn(log))
    .layer(middleware::from_fn(serve))
    .nest("/api/auth", auth::router()
        .layer(Extension(RouterURI("/api/auth")))
    ).nest("/api/users", users::router()
        .layer(Extension(RouterURI("/api/users")))
    ).nest("/api/posts", posts::router()
        .layer(Extension(RouterURI("/api/posts")))
    ).layer(CookieManagerLayer::new());

    let addr = "[::]:8080".parse::<std::net::SocketAddr>().unwrap();
    tracing::info!("listening on {}", addr);
    
    axum::Server::bind(&addr)
        .serve(app.into_make_service_with_connect_info::<SocketAddr>())
        .await
        .unwrap();
    
}