2022-05-31 15:04:33 +02:00
|
|
|
use serde_json::Deserializer;
|
2022-05-31 15:39:09 +02:00
|
|
|
|
2021-12-06 15:45:41 +01:00
|
|
|
use std::fs::File;
|
|
|
|
use std::io::BufReader;
|
|
|
|
use std::io::Write;
|
|
|
|
use std::path::Path;
|
|
|
|
|
|
|
|
use crate::{AuthController, HeedAuthStore, Result};
|
|
|
|
|
|
|
|
const KEYS_PATH: &str = "keys";
|
|
|
|
|
|
|
|
impl AuthController {
|
|
|
|
pub fn dump(src: impl AsRef<Path>, dst: impl AsRef<Path>) -> Result<()> {
|
2022-02-09 13:55:36 +01:00
|
|
|
let mut store = HeedAuthStore::new(&src)?;
|
|
|
|
|
|
|
|
// do not attempt to close the database on drop!
|
|
|
|
store.set_drop_on_close(false);
|
2021-12-06 15:45:41 +01:00
|
|
|
|
|
|
|
let keys_file_path = dst.as_ref().join(KEYS_PATH);
|
|
|
|
|
|
|
|
let keys = store.list_api_keys()?;
|
|
|
|
let mut keys_file = File::create(&keys_file_path)?;
|
|
|
|
for key in keys {
|
|
|
|
serde_json::to_writer(&mut keys_file, &key)?;
|
|
|
|
keys_file.write_all(b"\n")?;
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn load_dump(src: impl AsRef<Path>, dst: impl AsRef<Path>) -> Result<()> {
|
|
|
|
let store = HeedAuthStore::new(&dst)?;
|
|
|
|
|
|
|
|
let keys_file_path = src.as_ref().join(KEYS_PATH);
|
|
|
|
|
2022-01-13 12:23:02 +01:00
|
|
|
if !keys_file_path.exists() {
|
|
|
|
return Ok(());
|
|
|
|
}
|
|
|
|
|
2022-05-31 15:04:33 +02:00
|
|
|
let reader = BufReader::new(File::open(&keys_file_path)?);
|
|
|
|
for key in Deserializer::from_reader(reader).into_iter() {
|
|
|
|
store.put_api_key(key?)?;
|
2021-12-06 15:45:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|