bin/proxmox-backup-proxy.rs: improve error handling

This commit is contained in:
Dietmar Maurer 2019-02-11 14:43:26 +01:00
parent ace9e3531a
commit 4223d9f800
1 changed files with 24 additions and 10 deletions

View File

@ -1,6 +1,7 @@
#[macro_use] #[macro_use]
extern crate proxmox_backup; extern crate proxmox_backup;
use proxmox_backup::tools;
use proxmox_backup::api::router::*; use proxmox_backup::api::router::*;
use proxmox_backup::api::config::*; use proxmox_backup::api::config::*;
use proxmox_backup::server::rest::*; use proxmox_backup::server::rest::*;
@ -16,12 +17,19 @@ use hyper;
fn main() { fn main() {
if let Err(err) = run() {
eprintln!("Error: {}", err);
std::process::exit(-1);
}
}
fn run() -> Result<(), Error> {
if let Err(err) = syslog::init( if let Err(err) = syslog::init(
syslog::Facility::LOG_DAEMON, syslog::Facility::LOG_DAEMON,
log::LevelFilter::Info, log::LevelFilter::Info,
Some("proxmox-backup-proxy")) { Some("proxmox-backup-proxy")) {
eprintln!("unable to inititialize syslog: {}", err); bail!("unable to inititialize syslog - {}", err);
std::process::exit(-1);
} }
let _ = public_auth_key(); // load with lazy_static let _ = public_auth_key(); // load with lazy_static
@ -47,15 +55,20 @@ fn main() {
let rest_server = RestServer::new(config); let rest_server = RestServer::new(config);
let identity = let cert_path = configdir!("/proxy.pfx");
native_tls::Identity::from_pkcs12( let raw_cert = match tools::file_get_contents(cert_path) {
&std::fs::read(configdir!("/proxy.pfx")).unwrap(), Ok(data) => data,
"", Err(err) => bail!("unable to read certificate {} - {}", cert_path, err),
).unwrap(); };
let identity = match native_tls::Identity::from_pkcs12(&raw_cert, "") {
Ok(data) => data,
Err(err) => bail!("unabled to decode pkcs12 identity {} - {}", cert_path, err),
};
let addr = ([0,0,0,0,0,0,0,0], 8007).into(); let addr = ([0,0,0,0,0,0,0,0], 8007).into();
let listener = tokio::net::TcpListener::bind(&addr).unwrap(); let listener = tokio::net::TcpListener::bind(&addr)?;
let acceptor = native_tls::TlsAcceptor::new(identity).unwrap(); let acceptor = native_tls::TlsAcceptor::new(identity)?;
let acceptor = std::sync::Arc::new(tokio_tls::TlsAcceptor::from(acceptor)); let acceptor = std::sync::Arc::new(tokio_tls::TlsAcceptor::from(acceptor));
let connections = listener let connections = listener
.incoming() .incoming()
@ -77,7 +90,8 @@ fn main() {
.serve(rest_server) .serve(rest_server)
.map_err(|e| eprintln!("server error: {}", e)); .map_err(|e| eprintln!("server error: {}", e));
// Run this server for... forever! // Run this server for... forever!
hyper::rt::run(server); hyper::rt::run(server);
Ok(())
} }