]>
git.proxmox.com Git - proxmox-backup.git/blob - src/bin/proxmox-backup-api.rs
1 extern crate proxmox_backup
;
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
::*;
10 use lazy_static
::lazy_static
;
12 use futures
::future
::Future
;
18 if let Err(err
) = run() {
19 eprintln
!("Error: {}", err
);
20 std
::process
::exit(-1);
24 fn run() -> Result
<(), Error
> {
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
);
33 if let Err(err
) = generate_auth_key() {
34 bail
!("unable to generate auth key - {}", err
);
36 let _
= private_auth_key(); // load with lazy_static
38 if let Err(err
) = generate_csrf_key() {
39 bail
!("unable to generate csrf key - {}", err
);
41 let _
= csrf_secret(); // load with lazy_static
43 let addr
= ([127,0,0,1], 82).into();
46 static ref ROUTER
: Router
= proxmox_backup
::api2
::router();
49 let config
= ApiConfig
::new(
50 env
!("PROXMOX_JSDIR"), &ROUTER
, RpcEnvironmentType
::PRIVILEDGED
);
52 let rest_server
= RestServer
::new(config
);
54 let server
= hyper
::Server
::bind(&addr
)
56 .map_err(|e
| eprintln
!("server error: {}", e
));
58 // Run this server for... forever!
59 hyper
::rt
::run(server
);