#![allow(rustdoc::bare_urls)]
#![doc = include_str!("../README.md")]
#[macro_use]
extern crate actix_web;
use std::io;
use actix_web::{App, HttpServer, middleware, web};
use openssl::ssl::{SslAcceptor, SslFiletype, SslMethod};
use rand::prelude::SliceRandom;
mod constant;
mod routes;
mod squire;
mod templates;
pub async fn start() -> io::Result<()> {
let cargo = constant::build_info();
let config = squire::startup::get_config();
squire::startup::init_logger(config.debug, &cargo.crate_name);
println!("{}[v{}] - {}", &cargo.pkg_name, &cargo.pkg_version, &cargo.description);
let arts = [squire::ascii_art::DOG, squire::ascii_art::DOLPHIN, squire::ascii_art::HORSE];
println!("{}", arts.choose(&mut rand::thread_rng()).unwrap());
if config.secure_session {
log::warn!(
"Secure session is turned on! This means that the server can ONLY be hosted via HTTPS or localhost"
);
}
let jinja_env = templates::environment();
let config_clone = config.clone();
let jinja_clone = jinja_env.clone();
let host = format!("{}:{}", config.video_host, config.video_port);
log::info!("{} [workers:{}] running on http://{} (Press CTRL+C to quit)",
&cargo.pkg_name, &config.workers, &host);
let application = move || {
App::new() .app_data(web::Data::new(config_clone.clone()))
.app_data(web::Data::new(jinja_clone.clone()))
.wrap(squire::middleware::get_cors(config_clone.websites.clone()))
.wrap(middleware::Logger::default()) .service(routes::basics::health) .service(routes::basics::root)
.service(routes::auth::login)
.service(routes::auth::logout)
.service(routes::auth::home)
.service(routes::auth::error)
.service(routes::video::track)
.service(routes::video::stream)
.service(routes::video::streaming_endpoint)
};
let server = HttpServer::new(application)
.workers(config.workers as usize)
.max_connections(config.max_connections as usize);
if config.cert_file.exists() && config.key_file.exists() {
log::info!("Binding SSL certificate to serve over HTTPS");
let mut builder = SslAcceptor::mozilla_intermediate(SslMethod::tls()).unwrap();
builder.set_private_key_file(&config.key_file, SslFiletype::PEM).unwrap();
builder.set_certificate_chain_file(&config.cert_file).unwrap();
server.bind_openssl(host, builder)?
.run()
.await
} else {
server.bind(host)?
.run()
.await
}
}