c043f7a83a57f01c0d560de49a1c2ba27bea41fe
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
};
8 use listenfd
::ListenFd
;
9 use ron
::de
::from_reader
;
10 use serde
::Deserialize
;
12 use itertools
::Itertools
;
18 #[template(path = "main.html")]
19 struct MainTemplate
<'a
> {
23 #[derive(Deserialize)]
28 fn main_page(query
: Query
<Request
>) -> HttpResponse
{
30 let main_template
= MainTemplate
{ test
: &"*** test 2 ***" };
32 let s
= main_template
.render().unwrap();
33 HttpResponse
::Ok().content_type("text/html").body(s
)
36 #[derive(Debug, Deserialize)]
41 fn get_exe_name() -> String
{
42 let first_arg
= std
::env
::args().nth(0).unwrap();
43 let sep
: &[_
] = &['
\\'
, '
/'
];
44 first_arg
[first_arg
.rfind(sep
).unwrap()+1..].to_string()
48 async
fn main() -> std
::io
::Result
<()> {
49 if process_args() { return Ok(()) }
51 println!("Starting Recipes as web server...");
53 let config
: Config
= {
54 let f
= File
::open(consts
::FILE_CONF
).unwrap_or_else(|_
| panic!("Failed to open configuration file {}", consts
::FILE_CONF
));
55 match from_reader(f
) {
57 Err(e
) => panic!("Failed to load config: {}", e
)
61 println!("Configuration: {:?}", config
);
63 // let database_connection = db::create_or_update();
65 std
::env
::set_var("RUST_LOG", "actix_web=info");
67 let mut listenfd
= ListenFd
::from_env();
72 .wrap(middleware
::Compress
::default())
73 .service(web
::resource("/").to(main_page
))
74 .service(fs
::Files
::new("/static", "static").show_files_listing())
79 if let Some(l
) = listenfd
.take_tcp_listener(0).unwrap() {
80 server
.listen(l
).unwrap()
82 server
.bind(&format!("0.0.0.0:{}", config
.port
)).unwrap()
88 fn process_args() -> bool
{
91 println!(" {} [--help] [--test]", get_exe_name());
94 let args
: Vec
<String
> = args().collect();
96 if args
.iter().any(|arg
| arg
== "--help") {
99 } else if args
.iter().any(|arg
| arg
== "--test") {
100 let db_connection
= db
::Connection
::new();
101 db_connection
.create_or_update();