2017-01-25 18:51:41 +01:00
|
|
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
2016-06-20 10:06:49 +02:00
|
|
|
// This file is part of Parity.
|
|
|
|
|
|
|
|
// Parity is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
|
|
|
// Parity is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
use std::hash::{Hash, Hasher};
|
2017-02-03 13:56:48 +01:00
|
|
|
use std::path::PathBuf;
|
2016-10-15 14:44:08 +02:00
|
|
|
use ethkey::{Address, Message, Signature, Secret, Public};
|
2016-06-20 00:10:34 +02:00
|
|
|
use Error;
|
2016-12-09 23:01:43 +01:00
|
|
|
use json::Uuid;
|
2017-02-15 16:56:15 +01:00
|
|
|
use util::H256;
|
2016-06-20 00:10:34 +02:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
/// Key directory reference
|
|
|
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
|
|
|
|
pub enum SecretVaultRef {
|
|
|
|
/// Reference to key in root directory
|
|
|
|
Root,
|
|
|
|
/// Referenc to key in specific vault
|
|
|
|
Vault(String),
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Stored account reference
|
|
|
|
#[derive(Debug, Clone, PartialEq, Eq, PartialOrd, Ord)]
|
|
|
|
pub struct StoreAccountRef {
|
|
|
|
/// Vault reference
|
|
|
|
pub vault: SecretVaultRef,
|
|
|
|
/// Account address
|
|
|
|
pub address: Address,
|
|
|
|
}
|
|
|
|
|
2016-11-30 15:08:38 +01:00
|
|
|
pub trait SimpleSecretStore: Send + Sync {
|
2017-01-30 11:44:09 +01:00
|
|
|
fn insert_account(&self, vault: SecretVaultRef, secret: Secret, password: &str) -> Result<StoreAccountRef, Error>;
|
2017-02-15 16:56:15 +01:00
|
|
|
fn insert_derived(&self, vault: SecretVaultRef, account_ref: &StoreAccountRef, password: &str, derivation: Derivation) -> Result<StoreAccountRef, Error>;
|
2017-01-30 11:44:09 +01:00
|
|
|
fn change_password(&self, account: &StoreAccountRef, old_password: &str, new_password: &str) -> Result<(), Error>;
|
|
|
|
fn remove_account(&self, account: &StoreAccountRef, password: &str) -> Result<(), Error>;
|
2017-02-15 16:56:15 +01:00
|
|
|
fn generate_derived(&self, account_ref: &StoreAccountRef, password: &str, derivation: Derivation) -> Result<Address, Error>;
|
2017-01-30 11:44:09 +01:00
|
|
|
fn sign(&self, account: &StoreAccountRef, password: &str, message: &Message) -> Result<Signature, Error>;
|
2017-02-15 16:56:15 +01:00
|
|
|
fn sign_derived(&self, account_ref: &StoreAccountRef, password: &str, derivation: Derivation, message: &Message) -> Result<Signature, Error>;
|
2017-01-30 11:44:09 +01:00
|
|
|
fn decrypt(&self, account: &StoreAccountRef, password: &str, shared_mac: &[u8], message: &[u8]) -> Result<Vec<u8>, Error>;
|
2016-06-20 00:10:34 +02:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
fn accounts(&self) -> Result<Vec<StoreAccountRef>, Error>;
|
2017-02-05 16:17:56 +01:00
|
|
|
/// Get reference to some account with given address.
|
|
|
|
/// This method could be removed if we will guarantee that there is max(1) account for given address.
|
|
|
|
fn account_ref(&self, address: &Address) -> Result<StoreAccountRef, Error>;
|
2016-07-24 17:38:21 +02:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
/// Create new vault with given password
|
|
|
|
fn create_vault(&self, name: &str, password: &str) -> Result<(), Error>;
|
|
|
|
/// Open vault with given password
|
|
|
|
fn open_vault(&self, name: &str, password: &str) -> Result<(), Error>;
|
|
|
|
/// Close vault
|
|
|
|
fn close_vault(&self, name: &str) -> Result<(), Error>;
|
2017-02-05 16:17:56 +01:00
|
|
|
/// List all vaults
|
|
|
|
fn list_vaults(&self) -> Result<Vec<String>, Error>;
|
|
|
|
/// List all currently opened vaults
|
|
|
|
fn list_opened_vaults(&self) -> Result<Vec<String>, Error>;
|
2017-01-30 11:44:09 +01:00
|
|
|
/// Change vault password
|
2017-02-05 16:17:56 +01:00
|
|
|
fn change_vault_password(&self, name: &str, new_password: &str) -> Result<(), Error>;
|
|
|
|
/// Cnage account' vault
|
|
|
|
fn change_account_vault(&self, vault: SecretVaultRef, account: StoreAccountRef) -> Result<StoreAccountRef, Error>;
|
2017-02-08 13:53:39 +01:00
|
|
|
/// Get vault metadata string.
|
|
|
|
fn get_vault_meta(&self, name: &str) -> Result<String, Error>;
|
|
|
|
/// Set vault metadata string.
|
|
|
|
fn set_vault_meta(&self, name: &str, meta: &str) -> Result<(), Error>;
|
2016-11-30 15:08:38 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
pub trait SecretStore: SimpleSecretStore {
|
2017-01-30 11:44:09 +01:00
|
|
|
fn import_presale(&self, vault: SecretVaultRef, json: &[u8], password: &str) -> Result<StoreAccountRef, Error>;
|
|
|
|
fn import_wallet(&self, vault: SecretVaultRef, json: &[u8], password: &str) -> Result<StoreAccountRef, Error>;
|
|
|
|
fn copy_account(&self, new_store: &SimpleSecretStore, new_vault: SecretVaultRef, account: &StoreAccountRef, password: &str, new_password: &str) -> Result<(), Error>;
|
|
|
|
fn test_password(&self, account: &StoreAccountRef, password: &str) -> Result<bool, Error>;
|
2016-11-30 15:08:38 +01:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
fn public(&self, account: &StoreAccountRef, password: &str) -> Result<Public, Error>;
|
2016-11-30 15:08:38 +01:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
fn uuid(&self, account: &StoreAccountRef) -> Result<Uuid, Error>;
|
|
|
|
fn name(&self, account: &StoreAccountRef) -> Result<String, Error>;
|
|
|
|
fn meta(&self, account: &StoreAccountRef) -> Result<String, Error>;
|
2016-07-24 17:38:21 +02:00
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
fn set_name(&self, account: &StoreAccountRef, name: String) -> Result<(), Error>;
|
|
|
|
fn set_meta(&self, account: &StoreAccountRef, meta: String) -> Result<(), Error>;
|
2016-08-11 18:31:28 +02:00
|
|
|
|
2017-02-03 13:56:48 +01:00
|
|
|
fn local_path(&self) -> PathBuf;
|
2016-08-11 18:31:28 +02:00
|
|
|
fn list_geth_accounts(&self, testnet: bool) -> Vec<Address>;
|
2017-01-30 11:44:09 +01:00
|
|
|
fn import_geth_accounts(&self, vault: SecretVaultRef, desired: Vec<Address>, testnet: bool) -> Result<Vec<StoreAccountRef>, Error>;
|
2016-06-20 00:10:34 +02:00
|
|
|
}
|
|
|
|
|
2017-01-30 11:44:09 +01:00
|
|
|
impl StoreAccountRef {
|
|
|
|
/// Create reference to root account with given address
|
|
|
|
pub fn root(address: Address) -> Self {
|
|
|
|
StoreAccountRef::new(SecretVaultRef::Root, address)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Create reference to vault account with given address
|
|
|
|
pub fn vault(vault_name: &str, address: Address) -> Self {
|
|
|
|
StoreAccountRef::new(SecretVaultRef::Vault(vault_name.to_owned()), address)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Create new account reference
|
|
|
|
pub fn new(vault_ref: SecretVaultRef, address: Address) -> Self {
|
|
|
|
StoreAccountRef {
|
|
|
|
vault: vault_ref,
|
|
|
|
address: address,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Hash for StoreAccountRef {
|
|
|
|
fn hash<H: Hasher>(&self, state: &mut H) {
|
|
|
|
self.address.hash(state);
|
|
|
|
}
|
|
|
|
}
|
2017-02-15 16:56:15 +01:00
|
|
|
|
|
|
|
/// Node in hierarchical derivation.
|
|
|
|
pub struct IndexDerivation {
|
|
|
|
/// Node is soft (allows proof of parent from parent node).
|
|
|
|
pub soft: bool,
|
|
|
|
/// Index sequence of the node.
|
|
|
|
pub index: u32,
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Derivation scheme for keys
|
|
|
|
pub enum Derivation {
|
|
|
|
/// Hierarchical derivation
|
|
|
|
Hierarchical(Vec<IndexDerivation>),
|
|
|
|
/// Hash derivation, soft.
|
|
|
|
SoftHash(H256),
|
|
|
|
/// Hash derivation, hard.
|
|
|
|
HardHash(H256),
|
|
|
|
}
|