1 use std
::io
::prelude
::*;
2 use std
::{fs
::File
, env
::args
};
5 use actix_web
::{get
, web
, Responder
, middleware
, App
, HttpServer
, HttpResponse
, web
::Query
, middleware
::Logger
};
8 use listenfd
::ListenFd
;
9 use ron
::de
::from_reader
;
10 use serde
::Deserialize
;
13 use itertools
::Itertools
;
19 #[template(path = "main.html")]
20 struct MainTemplate
<'a
> {
24 #[derive(Deserialize)]
29 fn main_page(query
: Query
<Request
>) -> HttpResponse
{
31 let main_template
= MainTemplate
{ test
: &"*** test ***" };
33 let s
= main_template
.render().unwrap();
34 HttpResponse
::Ok().content_type("text/html").body(s
)
37 #[derive(Debug, Deserialize)]
42 fn get_exe_name() -> String
{
43 let first_arg
= std
::env
::args().nth(0).unwrap();
44 let sep
: &[_
] = &['
\\'
, '
/'
];
45 first_arg
[first_arg
.rfind(sep
).unwrap()+1..].to_string()
49 async
fn main() -> std
::io
::Result
<()> {
50 if process_args() { return Ok(()) }
52 println!("Starting Recipes as web server...");
54 let config
: Config
= {
55 let f
= File
::open(consts
::FILE_CONF
).unwrap_or_else(|_
| panic!("Failed to open configuration file {}", consts
::FILE_CONF
));
56 match from_reader(f
) {
58 Err(e
) => panic!("Failed to load config: {}", e
)
62 println!("Configuration: {:?}", config
);
64 // let database_connection = db::create_or_update();
66 std
::env
::set_var("RUST_LOG", "actix_web=info");
69 let mut listenfd
= ListenFd
::from_env();
74 .wrap(middleware
::Compress
::default())
75 .wrap(Logger
::default())
76 .wrap(Logger
::new("%a %{User-Agent}i"))
77 .service(web
::resource("/").to(main_page
))
78 .service(fs
::Files
::new("/static", "static").show_files_listing())
83 if let Some(l
) = listenfd
.take_tcp_listener(0).unwrap() {
84 server
.listen(l
).unwrap()
86 server
.bind(&format!("0.0.0.0:{}", config
.port
)).unwrap()
92 fn process_args() -> bool
{
95 println!(" {} [--help] [--test]", get_exe_name());
98 let args
: Vec
<String
> = args().collect();
100 if args
.iter().any(|arg
| arg
== "--help") {
103 } else if args
.iter().any(|arg
| arg
== "--test") {
104 let db_connection
= db
::Connection
::new();
105 db_connection
.create_or_update();