09965c1b22226fb2884ba16732cfeff00b48a5d0
1 extern crate actix_web
;
5 use listenfd
::ListenFd
;
7 use actix_web
::{web
, middleware
, App
, HttpServer
, HttpResponse
, Responder
, Result
, web
::Query
};
10 use ron
::de
::from_reader
;
11 use serde
::Deserialize
;
12 use std
::{fs
::File
, env
::args
};
14 use itertools
::Itertools
;
20 #[template(path = "main.html")]
21 struct MainTemplate
<'a
> {
25 #[derive(Deserialize)]
30 static DEFAULT_MESSAGE
: &str = "Marc, roule un pet'!";
31 static KEY
: &str = "secret";
33 fn main_page(query
: Query
<Request
>) -> Result
<HttpResponse
> {
37 match crypto
::decrypt(KEY
, b
) {
39 None
=> String
::from(DEFAULT_MESSAGE
)
41 None
=> String
::from(DEFAULT_MESSAGE
)
44 let hello
= MainTemplate
{ sentence
: &m
};
46 let s
= hello
.render().unwrap();
47 Ok(HttpResponse
::Ok().content_type("text/html").body(s
))
50 #[derive(Debug, Deserialize)]
55 fn get_exe_name() -> String
{
56 let first_arg
= std
::env
::args().nth(0).unwrap();
58 let sep
: &[_
] = &['
\\'
, '
/'
];
59 first_arg
[first_arg
.rfind(sep
).unwrap()+1..].to_string()
64 println!(" {} [--help] [--encrypt <message>]", get_exe_name());
67 fn main() -> std
::io
::Result
<()> {
68 let args
: Vec
<String
> = args().collect();
70 if args
.iter().any(|arg
| arg
== "--help") {
73 } else if let Some((position_arg_encrypt
, _
)) = args
.iter().find_position(|arg
| arg
== &"--encrypt") {
74 match args
.iter().nth(position_arg_encrypt
+ 1) {
75 Some(mess_to_encrypt
) => {
76 let encrypted_mess
= mess_to_encrypt
;
77 //let encrypted_mess = crypto::encrypt(key: &str, plain_text: &str);
78 println!("Encrypted message: {}", encrypted_mess
);
86 println!("Starting RUP as web server...");
88 let config
: Config
= {
89 let f
= File
::open(consts
::FILE_CONF
).expect(&format!("Failed to open configuration file {}", consts
::FILE_CONF
));
90 match from_reader(f
) {
92 Err(e
) => panic!("Failed to load config: {}", e
)
96 let key
= File
::open(consts
::FILE_KEY
).expect(&format!("Failed to open key file: {}", consts
::FILE_KEY
));
98 println!("Configuration: {:?}", config
);
100 let mut listenfd
= ListenFd
::from_env();
105 .wrap(middleware
::Compress
::default())
106 .wrap(middleware
::Logger
::default())
107 .service(web
::resource("/").to(main_page
))
108 .service(fs
::Files
::new("/static", "static").show_files_listing())
113 if let Some(l
) = listenfd
.take_tcp_listener(0).unwrap() {
114 server
.listen(l
).unwrap()
116 server
.bind(&format!("0.0.0.0:{}", config
.port
)).unwrap()