]>
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_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
;
12 use lazy_static
::lazy_static
;
14 use futures
::future
::Future
;
20 if let Err(err
) = run() {
21 eprintln
!("Error: {}", err
);
22 std
::process
::exit(-1);
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
);
34 config
::create_configdir()?
;
36 if let Err(err
) = generate_auth_key() {
37 bail
!("unable to generate auth key - {}", err
);
39 let _
= private_auth_key(); // load with lazy_static
41 if let Err(err
) = generate_csrf_key() {
42 bail
!("unable to generate csrf key - {}", err
);
44 let _
= csrf_secret(); // load with lazy_static
47 static ref ROUTER
: Router
= proxmox_backup
::api2
::router();
50 let config
= ApiConfig
::new(
51 env
!("PROXMOX_JSDIR"), &ROUTER
, RpcEnvironmentType
::PRIVILEGED
);
53 let rest_server
= RestServer
::new(config
);
55 // http server future:
56 let server
= daemon
::create_daemon(
57 ([127,0,0,1], 82).into(),
59 Ok(hyper
::Server
::builder(listener
.incoming())
61 .map_err(|e
| eprintln
!("server error: {}", e
))
66 hyper
::rt
::run(server
);