mirror of
				https://github.com/dani-garcia/vaultwarden.git
				synced 2025-10-26 07:50:02 +02:00 
			
		
		
		
	Updated code so backtraces are logged also.
This commit is contained in:
		
							
								
								
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										1
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @@ -119,6 +119,7 @@ checksum = "cf1de2fe8c75bc145a2f577add951f8134889b4795d47466a54a5c846d691693" | ||||
| name = "bitwarden_rs" | ||||
| version = "1.0.0" | ||||
| dependencies = [ | ||||
|  "backtrace", | ||||
|  "chashmap", | ||||
|  "chrono", | ||||
|  "data-encoding", | ||||
|   | ||||
| @@ -118,6 +118,9 @@ idna = "0.2.0" | ||||
| # CLI argument parsing | ||||
| structopt = "0.3.11" | ||||
|  | ||||
| # Logging panics to logfile instead stderr only | ||||
| backtrace = "0.3.45" | ||||
|  | ||||
| [patch.crates-io] | ||||
| # Use newest ring | ||||
| rocket = { git = 'https://github.com/SergioBenitez/Rocket', rev = 'b95b6765e1cc8be7c1e7eaef8a9d9ad940b0ac13' } | ||||
|   | ||||
							
								
								
									
										49
									
								
								src/main.rs
									
									
									
									
									
								
							
							
						
						
									
										49
									
								
								src/main.rs
									
									
									
									
									
								
							| @@ -20,12 +20,14 @@ extern crate derive_more; | ||||
| #[macro_use] | ||||
| extern crate num_derive; | ||||
|  | ||||
| extern crate backtrace; | ||||
|  | ||||
| use std::{ | ||||
|     fs::create_dir_all, | ||||
|     path::Path, | ||||
|     process::{exit, Command}, | ||||
|     str::FromStr, | ||||
|     panic, | ||||
|     panic, thread, fmt // For panic logging | ||||
| }; | ||||
|  | ||||
| #[macro_use] | ||||
| @@ -43,6 +45,16 @@ pub use error::{Error, MapResult}; | ||||
|  | ||||
| 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)] | ||||
| #[structopt(name = "bitwarden_rs", about = "A Bitwarden API server written in Rust")] | ||||
| 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 | ||||
|     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(()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user