]> git.proxmox.com Git - proxmox-backup.git/blob - src/bin/proxmox-backup-api.rs
rename src/api to src/api_schema
[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::auth_helpers::*;
8 use proxmox_backup::config;
9
10 use failure::*;
11 use lazy_static::lazy_static;
12
13 use futures::future::Future;
14
15 use hyper;
16
17 fn main() {
18
19 if let Err(err) = run() {
20 eprintln!("Error: {}", err);
21 std::process::exit(-1);
22 }
23 }
24
25 fn run() -> Result<(), Error> {
26
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 let addr = ([127,0,0,1], 82).into();
47
48 lazy_static!{
49 static ref ROUTER: Router = proxmox_backup::api2::router();
50 }
51
52 let config = ApiConfig::new(
53 env!("PROXMOX_JSDIR"), &ROUTER, RpcEnvironmentType::PRIVILEDGED);
54
55 let rest_server = RestServer::new(config);
56
57 let server = hyper::Server::bind(&addr)
58 .serve(rest_server)
59 .map_err(|e| eprintln!("server error: {}", e));
60
61 // Run this server for... forever!
62 hyper::rt::run(server);
63
64 Ok(())
65 }