]> git.proxmox.com Git - proxmox-backup.git/blob - src/bin/proxmox-backup-api.rs
bin/proxmox-backup-api.rs: improve error handling
[proxmox-backup.git] / src / bin / proxmox-backup-api.rs
1 extern crate proxmox_backup;
2
3 //use proxmox_backup::tools;
4 use proxmox_backup::api::router::*;
5 use proxmox_backup::api::config::*;
6 use proxmox_backup::server::rest::*;
7 use proxmox_backup::auth_helpers::*;
8
9 use failure::*;
10 use lazy_static::lazy_static;
11
12 use futures::future::Future;
13
14 use hyper;
15
16 fn main() {
17
18 if let Err(err) = run() {
19 eprintln!("Error: {}", err);
20 std::process::exit(-1);
21 }
22 }
23
24 fn run() -> Result<(), Error> {
25
26 if let Err(err) = syslog::init(
27 syslog::Facility::LOG_DAEMON,
28 log::LevelFilter::Info,
29 Some("proxmox-backup-api")) {
30 bail!("unable to inititialize syslog - {}", err);
31 }
32
33 if let Err(err) = generate_auth_key() {
34 bail!("unable to generate auth key - {}", err);
35 }
36 let _ = private_auth_key(); // load with lazy_static
37
38 if let Err(err) = generate_csrf_key() {
39 bail!("unable to generate csrf key - {}", err);
40 }
41 let _ = csrf_secret(); // load with lazy_static
42
43 let addr = ([127,0,0,1], 82).into();
44
45 lazy_static!{
46 static ref ROUTER: Router = proxmox_backup::api2::router();
47 }
48
49 let config = ApiConfig::new(
50 env!("PROXMOX_JSDIR"), &ROUTER, RpcEnvironmentType::PRIVILEDGED);
51
52 let rest_server = RestServer::new(config);
53
54 let server = hyper::Server::bind(&addr)
55 .serve(rest_server)
56 .map_err(|e| eprintln!("server error: {}", e));
57
58 // Run this server for... forever!
59 hyper::rt::run(server);
60
61 Ok(())
62 }