#[cfg(feature = "ssr")] #[tokio::main] async fn main() { use std::env; use axum::Router; use leptos::*; use leptos_axum::{generate_route_list, LeptosRoutes}; use log::info; use sqlx::postgres::PgPoolOptions; use watch::app::*; use watch::fileserv::file_and_error_handler; // Setting get_configuration(None) means we'll be using cargo-leptos's env values // For deployment these variables are: // // Alternately a file can be specified such as Some("Cargo.toml") // The file would need to be included with the executable when moved to deployment let conf = get_configuration(None).await.unwrap(); let leptos_options = conf.leptos_options; let addr = leptos_options.site_addr; let routes = generate_route_list(App); let pool = PgPoolOptions::new() .test_before_acquire(true) .max_lifetime(None) .connect_lazy(&env::var("DATABASE_URL").expect("DATABASE_URL was not set!")) .expect("Failed to create database connection pool"); // build our application with a route let app = Router::new() .leptos_routes_with_context( &leptos_options, routes, { let pool = pool.clone(); move || provide_context(pool.clone()) }, App, ) .fallback(file_and_error_handler) .with_state(leptos_options) .with_state(pool); if env::var("RUST_LOG").is_err() { env::set_var("RUST_LOG", format!("{}=debug", module_path!())); } env_logger::init(); let listener = tokio::net::TcpListener::bind(&addr).await.unwrap(); info!("listening on http://{}", &addr); axum::serve(listener, app.into_make_service()) .await .unwrap(); } #[cfg(not(feature = "ssr"))] pub fn main() { // no client-side main function // unless we want this to work with e.g., Trunk for a purely client-side app // see lib.rs for hydration function instead }