// Needed for building in Docker container // See https://github.com/clux/muslrust?tab=readme-ov-file#diesel-and-pq-builds // See https://github.com/sgrif/pq-sys/issues/25 #[cfg(target = "x86_64-unknown-linux-musl")] extern crate openssl; #[cfg(target = "x86_64-unknown-linux-musl")] #[macro_use] extern crate diesel; #[cfg(feature = "ssr")] extern crate diesel_migrations; #[cfg(feature = "ssr")] #[tokio::main] async fn main() { use axum::Router; use leptos::*; use leptos_axum::{generate_route_list, LeptosRoutes}; use libretunes::app::*; use libretunes::fileserv::file_and_error_handler; use dotenv::dotenv; dotenv().ok(); // Bring the database up to date libretunes::database::migrate(); let redis_url = std::env::var("REDIS_URL").expect("REDIS_URL must be set"); let conf = get_configuration(None).await.unwrap(); let leptos_options = conf.leptos_options; let addr = leptos_options.site_addr; // Generate the list of routes in your Leptos App let routes = generate_route_list(App); let app = Router::new() .leptos_routes(&leptos_options, routes, App) .fallback(file_and_error_handler) .with_state(leptos_options); println!("listening on http://{}", &addr); axum::Server::bind(&addr) .serve(app.into_make_service()) .await .unwrap(); } #[cfg(not(any(feature = "ssr", feature = "csr")))] pub fn main() { // no client-side main function // unless we want this to work with e.g., Trunk for pure client-side testing // see lib.rs for hydration function instead // see optional feature `csr` instead } #[cfg(all(not(feature = "ssr"), feature = "csr"))] pub fn main() { // a client-side main function is required for using `trunk serve` // prefer using `cargo leptos serve` instead // to run: `trunk serve --open --features csr` use leptos::*; use libretunes::app::*; use wasm_bindgen::prelude::wasm_bindgen; console_error_panic_hook::set_once(); leptos::mount_to_body(App); }