6b074e8fb2
* bump rust-crypto * initial version of account provider utilizing secret store * update lazy_static to latest version * AccountProvider accounts method * new AccountProvider tests in progress * basic tests for new AccountProvider * ethcore compiles with new account provider and secret store * ethcore-rpc build now compiling with new AccountProvider * most rpc tests passing with new accounts_provider * fixed basic_authority tests * fixed eth_transaction_count rpc test * fixed mocked/eth.rs tests * fixed personal tests * fixed personal signer rpc tests * removed warnings * parity compiling fine with new sstore * fixed import direction * do not unlock temporarily when we have the password * removed TODO in account import * display warning on auto account import failure * fixed compiling of ethstore on windows * ethstore as a part of parity repo * added ethkey
59 lines
1.2 KiB
Rust
59 lines
1.2 KiB
Rust
use std::path::PathBuf;
|
|
use std::{env, fs};
|
|
use rand::{Rng, OsRng};
|
|
use ethstore::dir::{KeyDirectory, DiskDirectory};
|
|
use ethstore::ethkey::Address;
|
|
use ethstore::{Error, SafeAccount};
|
|
|
|
pub fn random_dir() -> PathBuf {
|
|
let mut rng = OsRng::new().unwrap();
|
|
let mut dir = env::temp_dir();
|
|
dir.push(format!("{:x}-{:x}", rng.next_u64(), rng.next_u64()));
|
|
dir
|
|
}
|
|
|
|
pub struct TransientDir {
|
|
dir: DiskDirectory,
|
|
path: PathBuf,
|
|
}
|
|
|
|
impl TransientDir {
|
|
pub fn create() -> Result<Self, Error> {
|
|
let path = random_dir();
|
|
let result = TransientDir {
|
|
dir: try!(DiskDirectory::create(&path)),
|
|
path: path,
|
|
};
|
|
|
|
Ok(result)
|
|
}
|
|
|
|
pub fn open() -> Self {
|
|
let path = random_dir();
|
|
TransientDir {
|
|
dir: DiskDirectory::at(&path),
|
|
path: path,
|
|
}
|
|
}
|
|
}
|
|
|
|
impl Drop for TransientDir {
|
|
fn drop(&mut self) {
|
|
fs::remove_dir_all(&self.path).expect("Expected to remove temp dir");
|
|
}
|
|
}
|
|
|
|
impl KeyDirectory for TransientDir {
|
|
fn load(&self) -> Result<Vec<SafeAccount>, Error> {
|
|
self.dir.load()
|
|
}
|
|
|
|
fn insert(&self, account: SafeAccount) -> Result<(), Error> {
|
|
self.dir.insert(account)
|
|
}
|
|
|
|
fn remove(&self, address: &Address) -> Result<(), Error> {
|
|
self.dir.remove(address)
|
|
}
|
|
}
|