0
0
Fork 0
mirror of https://github.com/dani-garcia/vaultwarden synced 2025-01-07 13:24:55 +01:00

Merge pull request #660 from BlackDex/sqlite-backup-fix

Fixed a bug with the sqlite backup feature.
This commit is contained in:
Daniel García 2019-10-11 15:07:21 +02:00 committed by GitHub
commit f482585d7c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -52,12 +52,16 @@ pub fn get_connection() -> Result<Connection, ConnectionError> {
/// Creates a back-up of the database using sqlite3 /// Creates a back-up of the database using sqlite3
pub fn backup_database() -> Result<(), Error> { pub fn backup_database() -> Result<(), Error> {
use std::path::Path;
let db_url = CONFIG.database_url();
let db_path = Path::new(&db_url).parent().unwrap();
let now: DateTime<Utc> = Utc::now(); let now: DateTime<Utc> = Utc::now();
let file_date = now.format("%Y%m%d").to_string(); let file_date = now.format("%Y%m%d").to_string();
let backup_command: String = format!("{}{}{}", ".backup 'db_", file_date, ".sqlite3'"); let backup_command: String = format!("{}{}{}", ".backup 'db_", file_date, ".sqlite3'");
Command::new("sqlite3") Command::new("sqlite3")
.current_dir("./data") .current_dir(db_path)
.args(&["db.sqlite3", &backup_command]) .args(&["db.sqlite3", &backup_command])
.output() .output()
.expect("Can't open database, sqlite3 is not available, make sure it's installed and available on the PATH"); .expect("Can't open database, sqlite3 is not available, make sure it's installed and available on the PATH");