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