use rocket::{catchers, fs::FileServer, routes, Build, Rocket}; use rocket_dyn_templates::Template; use crate::routes::{ authentication::*, catchers::*, index::*, scuttlebutt::*, settings::{admin::*, dns::*, menu::*, network::*, scuttlebutt::*}, status::{device::*, network::*, scuttlebutt::*}, }; /// Create a Rocket instance and mount PeachPub routes, fileserver and /// catchers. This gives us everything we need to run PeachPub and excludes /// settings and status routes related to networking and the device (memory, /// hard disk, CPU etc.). pub fn mount_peachpub_routes() -> Rocket { rocket::build() .mount( "/", routes![ help, home, login, login_post, logout, reboot_cmd, shutdown_cmd, power_menu, settings_menu, ], ) .mount( "/settings/admin", routes![ admin_menu, configure_admin, add_admin, add_admin_post, delete_admin_post, change_password, change_password_post, reset_password, reset_password_post, forgot_password_page, send_password_reset_post, ], ) .mount( "/settings/scuttlebutt", routes![ssb_settings_menu, configure_sbot], ) .mount( "/scuttlebutt", routes![ peers, friends, follows, followers, blocks, profile, private, follow, unfollow, block, publish, ], ) .mount("/status", routes![scuttlebutt_status]) .mount("/", FileServer::from("static")) .register("/", catchers![not_found, internal_error, forbidden]) .attach(Template::fairing()) } /// Create a Rocket instance with PeachPub routes, fileserver and catchers by /// calling `mount_peachpub_routes()` and then mount all additional routes /// required to run a complete PeachCloud build. pub fn mount_peachcloud_routes() -> Rocket { mount_peachpub_routes() .mount( "/settings/network", routes![ add_credentials, connect_wifi, configure_dns, configure_dns_post, disconnect_wifi, deploy_ap, deploy_client, forget_wifi, network_home, add_ssid, add_wifi, network_detail, wifi_list, wifi_password, wifi_set_password, wifi_usage, wifi_usage_alerts, wifi_usage_reset, ], ) .mount("/status", routes![device_status, network_status]) }