1 use anyhow
::{bail, Error}
;
4 use proxmox
::try_block
;
5 use proxmox
::api
::RpcEnvironmentType
;
7 //use proxmox_backup::tools;
8 //use proxmox_backup::api_schema::config::*;
9 use proxmox_backup
::server
::rest
::*;
10 use proxmox_backup
::server
;
11 use proxmox_backup
::tools
::daemon
;
12 use proxmox_backup
::auth_helpers
::*;
13 use proxmox_backup
::config
;
14 use proxmox_backup
::buildcfg
;
17 proxmox_backup
::tools
::setup_safe_path_env();
19 if let Err(err
) = proxmox_backup
::tools
::runtime
::main(run()) {
20 eprintln
!("Error: {}", err
);
21 std
::process
::exit(-1);
25 async
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 server
::create_task_log_dirs()?
;
35 config
::create_configdir()?
;
37 config
::update_self_signed_cert(false)?
;
39 proxmox_backup
::rrd
::create_rrdb_dir()?
;
40 proxmox_backup
::server
::jobstate
::create_jobstate_dir()?
;
42 if let Err(err
) = generate_auth_key() {
43 bail
!("unable to generate auth key - {}", err
);
45 let _
= private_auth_key(); // load with lazy_static
47 if let Err(err
) = generate_csrf_key() {
48 bail
!("unable to generate csrf key - {}", err
);
50 let _
= csrf_secret(); // load with lazy_static
52 let mut config
= server
::ApiConfig
::new(
53 buildcfg
::JS_DIR
, &proxmox_backup
::api2
::ROUTER
, RpcEnvironmentType
::PRIVILEGED
)?
;
55 let mut commando_sock
= server
::CommandoSocket
::new(server
::our_ctrl_sock());
57 config
.enable_file_log(buildcfg
::API_ACCESS_LOG_FN
, &mut commando_sock
)?
;
59 let rest_server
= RestServer
::new(config
);
61 // http server future:
62 let server
= daemon
::create_daemon(
63 ([127,0,0,1], 82).into(),
64 move |listener
, ready
| {
65 let incoming
= proxmox_backup
::tools
::async_io
::StaticIncoming
::from(listener
);
67 .and_then(|_
| hyper
::Server
::builder(incoming
)
69 .with_graceful_shutdown(server
::shutdown_future())
74 eprintln
!("server error: {}", e
);
79 "proxmox-backup.service",
82 server
::write_pid(buildcfg
::PROXMOX_BACKUP_API_PID_FN
)?
;
83 daemon
::systemd_notify(daemon
::SystemdNotify
::Ready
)?
;
85 let init_result
: Result
<(), Error
> = try_block
!({
86 server
::register_task_control_commands(&mut commando_sock
)?
;
87 commando_sock
.spawn()?
;
88 server
::server_state_init()?
;
92 if let Err(err
) = init_result
{
93 bail
!("unable to start daemon - {}", err
);
97 log
::info
!("server shutting down, waiting for active workers to complete");
98 proxmox_backup
::server
::last_worker_future().await?
;
100 log
::info
!("done - exit server");