2024-06-28 20:28:43 +00:00
|
|
|
use actix_web::middleware::Logger;
|
2024-06-28 20:00:20 +00:00
|
|
|
use actix_web::{web, App, HttpServer};
|
|
|
|
use openssl::ssl::{SslAcceptor, SslMethod};
|
|
|
|
|
|
|
|
use crate::app_config::AppConfig;
|
|
|
|
use crate::crypto::pki;
|
|
|
|
|
2024-06-28 20:28:43 +00:00
|
|
|
pub mod custom_error;
|
|
|
|
pub mod pki_controller;
|
2024-06-28 20:00:20 +00:00
|
|
|
pub mod server_controller;
|
|
|
|
|
|
|
|
/// Start unsecure (HTTP) server
|
|
|
|
pub async fn unsecure_server() -> anyhow::Result<()> {
|
|
|
|
log::info!(
|
2024-06-28 20:28:43 +00:00
|
|
|
"Unsecure server starting to listen on {} for {}",
|
2024-06-28 20:00:20 +00:00
|
|
|
AppConfig::get().unsecure_listen_address,
|
|
|
|
AppConfig::get().unsecure_origin()
|
|
|
|
);
|
2024-06-28 20:28:43 +00:00
|
|
|
HttpServer::new(|| {
|
|
|
|
App::new()
|
|
|
|
.wrap(Logger::default())
|
|
|
|
.route("/", web::get().to(server_controller::unsecure_home))
|
|
|
|
.route("/pki/{file}", web::get().to(pki_controller::serve_pki_file))
|
|
|
|
})
|
|
|
|
.bind(&AppConfig::get().unsecure_listen_address)?
|
|
|
|
.run()
|
|
|
|
.await?;
|
2024-06-28 20:00:20 +00:00
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Start secure (HTTPS) server
|
|
|
|
pub async fn secure_server() -> anyhow::Result<()> {
|
|
|
|
let web_ca = pki::CertData::load_web_ca()?;
|
|
|
|
let server_cert = pki::CertData::load_server()?;
|
|
|
|
|
|
|
|
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
|
|
|
|
builder.set_private_key(&server_cert.key)?;
|
|
|
|
builder.set_certificate(&server_cert.cert)?;
|
|
|
|
builder.add_extra_chain_cert(web_ca.cert)?;
|
|
|
|
|
|
|
|
log::info!(
|
|
|
|
"Secure server starting to listen on {} for {}",
|
|
|
|
AppConfig::get().listen_address,
|
|
|
|
AppConfig::get().secure_origin()
|
|
|
|
);
|
2024-06-28 20:28:43 +00:00
|
|
|
HttpServer::new(|| {
|
|
|
|
App::new()
|
|
|
|
.wrap(Logger::default())
|
|
|
|
.route("/", web::get().to(server_controller::secure_home))
|
|
|
|
})
|
|
|
|
.bind_openssl(&AppConfig::get().listen_address, builder)?
|
|
|
|
.run()
|
|
|
|
.await?;
|
2024-06-28 20:00:20 +00:00
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|