|
|
@ -20,12 +20,14 @@ extern crate derive_more;
|
|
|
|
#[macro_use]
|
|
|
|
#[macro_use]
|
|
|
|
extern crate num_derive;
|
|
|
|
extern crate num_derive;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
extern crate backtrace;
|
|
|
|
|
|
|
|
|
|
|
|
use std::{
|
|
|
|
use std::{
|
|
|
|
fs::create_dir_all,
|
|
|
|
fs::create_dir_all,
|
|
|
|
path::Path,
|
|
|
|
path::Path,
|
|
|
|
process::{exit, Command},
|
|
|
|
process::{exit, Command},
|
|
|
|
str::FromStr,
|
|
|
|
str::FromStr,
|
|
|
|
panic,
|
|
|
|
panic, thread, fmt // For panic logging
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#[macro_use]
|
|
|
|
#[macro_use]
|
|
|
@ -43,6 +45,16 @@ pub use error::{Error, MapResult};
|
|
|
|
|
|
|
|
|
|
|
|
use structopt::StructOpt;
|
|
|
|
use structopt::StructOpt;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Used for catching panics and log them to file instead of stderr
|
|
|
|
|
|
|
|
use backtrace::Backtrace;
|
|
|
|
|
|
|
|
struct Shim(Backtrace);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl fmt::Debug for Shim {
|
|
|
|
|
|
|
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
|
|
|
|
|
|
|
write!(fmt, "\n{:?}", self.0)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Debug, StructOpt)]
|
|
|
|
#[derive(Debug, StructOpt)]
|
|
|
|
#[structopt(name = "bitwarden_rs", about = "A Bitwarden API server written in Rust")]
|
|
|
|
#[structopt(name = "bitwarden_rs", about = "A Bitwarden API server written in Rust")]
|
|
|
|
struct Opt {
|
|
|
|
struct Opt {
|
|
|
@ -145,7 +157,40 @@ fn init_logging(level: log::LevelFilter) -> Result<(), fern::InitError> {
|
|
|
|
|
|
|
|
|
|
|
|
// Catch panics and log them instead of default output to StdErr
|
|
|
|
// Catch panics and log them instead of default output to StdErr
|
|
|
|
panic::set_hook(Box::new(|info| {
|
|
|
|
panic::set_hook(Box::new(|info| {
|
|
|
|
warn!("[PANIC] {}", info);
|
|
|
|
let backtrace = Backtrace::new();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let thread = thread::current();
|
|
|
|
|
|
|
|
let thread = thread.name().unwrap_or("unnamed");
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let msg = match info.payload().downcast_ref::<&'static str>() {
|
|
|
|
|
|
|
|
Some(s) => *s,
|
|
|
|
|
|
|
|
None => match info.payload().downcast_ref::<String>() {
|
|
|
|
|
|
|
|
Some(s) => &**s,
|
|
|
|
|
|
|
|
None => "Box<Any>",
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
match info.location() {
|
|
|
|
|
|
|
|
Some(location) => {
|
|
|
|
|
|
|
|
error!(
|
|
|
|
|
|
|
|
target: "panic", "thread '{}' panicked at '{}': {}:{}{:?}",
|
|
|
|
|
|
|
|
thread,
|
|
|
|
|
|
|
|
msg,
|
|
|
|
|
|
|
|
location.file(),
|
|
|
|
|
|
|
|
location.line(),
|
|
|
|
|
|
|
|
Shim(backtrace)
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
None => {
|
|
|
|
|
|
|
|
error!(
|
|
|
|
|
|
|
|
target: "panic",
|
|
|
|
|
|
|
|
"thread '{}' panicked at '{}'{:?}",
|
|
|
|
|
|
|
|
thread,
|
|
|
|
|
|
|
|
msg,
|
|
|
|
|
|
|
|
Shim(backtrace)
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
}));
|
|
|
|
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
Ok(())
|
|
|
|