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