mod handlers; use axum::{Router, http::Method}; use std::net::SocketAddr; use tower_http::cors::{Any, CorsLayer}; use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt}; use contracts::profession_shared::shared_routes; #[tokio::main] async fn main() { tracing_subscriber::registry() .with(tracing_subscriber::EnvFilter::new( std::env::var("RUST_LOG").unwrap_or_else(|_| "info".into()), )) .with(tracing_subscriber::fmt::layer()) .init(); let database_url = std::env::var("DATABASE_URL").expect("DATABASE_URL must be set"); let pool = sqlx::postgres::PgPoolOptions::new() .max_connections(5) .connect(&database_url) .await .expect("Failed to connect to postgres"); let cors = CorsLayer::new() .allow_methods([Method::GET, Method::POST, Method::PATCH, Method::DELETE, Method::OPTIONS]) .allow_origin(Any) .allow_headers(Any); let app = Router::new() .route("/health", axum::routing::get(|| async { "Photographers Service OK" })) .nest("/api/photographers", handlers::router()) .layer(cors) .with_state(pool); let port: u16 = std::env::var("PORT") .unwrap_or_else(|_| "8085".to_string()) .parse() .expect("PORT must be a number"); let addr = SocketAddr::from(([0, 0, 0, 0], port)); tracing::info!("Photographers service listening on {}", addr); let listener = tokio::net::TcpListener::bind(&addr).await.unwrap(); axum::serve(listener, app).await.unwrap(); }