* Crypto utils removed from ethkey * Fix ethkey lib * Switch ethsore to new crypto * Accounts crate fixed * Secret store crate switched to new crypto * Ethcore builtin fixed * Accounts crate fixed * Ethcore crate fixed * Util network fixed * Util network-devp2p fixed * Private tx fixed * Ethcore sync fixed * Secret store fixed * Rpc fixed * Parity fixed * Ethkey cli fixed * Local store fixed * Ethcore blockchain fixed * Cargo.lock pushed; doc comment added for reversed nonce * Ethstore tests fixed * Ethstore cli fixed * Miner fixed * Snapshot tests are fixed * Single brackets removed * Machine fixed * Verification fixed * Executive state fixed * More single brackets removed * Update version of parity-crypto * Use published version 0.4.2 of parity-crypto * New test in tx_filter fixed
119 lines
3.5 KiB
Rust
119 lines
3.5 KiB
Rust
// Copyright 2015-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Ethereum.
|
|
|
|
// Parity Ethereum 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 Ethereum 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 Ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use std::fmt;
|
|
use std::io::Error as IoError;
|
|
use crypto::{self, Error as EthCryptoError};
|
|
use crypto::publickey::{Error as EthPublicKeyCryptoError, DerivationError};
|
|
|
|
/// Account-related errors.
|
|
#[derive(Debug)]
|
|
pub enum Error {
|
|
/// IO error
|
|
Io(IoError),
|
|
/// Invalid Password
|
|
InvalidPassword,
|
|
/// Account's secret is invalid.
|
|
InvalidSecret,
|
|
/// Invalid Vault Crypto meta.
|
|
InvalidCryptoMeta,
|
|
/// Invalid Account.
|
|
InvalidAccount,
|
|
/// Invalid Message.
|
|
InvalidMessage,
|
|
/// Invalid Key File
|
|
InvalidKeyFile(String),
|
|
/// Vaults are not supported.
|
|
VaultsAreNotSupported,
|
|
/// Unsupported vault
|
|
UnsupportedVault,
|
|
/// Invalid vault name
|
|
InvalidVaultName,
|
|
/// Vault not found
|
|
VaultNotFound,
|
|
/// Account creation failed.
|
|
CreationFailed,
|
|
/// `EthCrypto` error
|
|
EthCrypto(EthCryptoError),
|
|
/// `EthPublicKeyCryptoError` error
|
|
EthPublicKeyCrypto(EthPublicKeyCryptoError),
|
|
/// Derivation error
|
|
Derivation(DerivationError),
|
|
/// Custom error
|
|
Custom(String),
|
|
}
|
|
|
|
impl fmt::Display for Error {
|
|
fn fmt(&self, f: &mut fmt::Formatter) -> Result<(), fmt::Error> {
|
|
let s = match *self {
|
|
Error::Io(ref err) => err.to_string(),
|
|
Error::InvalidPassword => "Invalid password".into(),
|
|
Error::InvalidSecret => "Invalid secret".into(),
|
|
Error::InvalidCryptoMeta => "Invalid crypted metadata".into(),
|
|
Error::InvalidAccount => "Invalid account".into(),
|
|
Error::InvalidMessage => "Invalid message".into(),
|
|
Error::InvalidKeyFile(ref reason) => format!("Invalid key file: {}", reason),
|
|
Error::VaultsAreNotSupported => "Vaults are not supported".into(),
|
|
Error::UnsupportedVault => "Vault is not supported for this operation".into(),
|
|
Error::InvalidVaultName => "Invalid vault name".into(),
|
|
Error::VaultNotFound => "Vault not found".into(),
|
|
Error::CreationFailed => "Account creation failed".into(),
|
|
Error::EthCrypto(ref err) => err.to_string(),
|
|
Error::EthPublicKeyCrypto(ref err) => err.to_string(),
|
|
Error::Derivation(ref err) => format!("Derivation error: {:?}", err),
|
|
Error::Custom(ref s) => s.clone(),
|
|
};
|
|
|
|
write!(f, "{}", s)
|
|
}
|
|
}
|
|
|
|
impl From<IoError> for Error {
|
|
fn from(err: IoError) -> Self {
|
|
Error::Io(err)
|
|
}
|
|
}
|
|
|
|
impl From<EthPublicKeyCryptoError> for Error {
|
|
fn from(err: EthPublicKeyCryptoError) -> Self {
|
|
Error::EthPublicKeyCrypto(err)
|
|
}
|
|
}
|
|
|
|
impl From<EthCryptoError> for Error {
|
|
fn from(err: EthCryptoError) -> Self {
|
|
Error::EthCrypto(err)
|
|
}
|
|
}
|
|
|
|
impl From<crypto::error::ScryptError> for Error {
|
|
fn from(err: crypto::error::ScryptError) -> Self {
|
|
Error::EthCrypto(err.into())
|
|
}
|
|
}
|
|
|
|
impl From<crypto::error::SymmError> for Error {
|
|
fn from(err: crypto::error::SymmError) -> Self {
|
|
Error::EthCrypto(err.into())
|
|
}
|
|
}
|
|
|
|
impl From<DerivationError> for Error {
|
|
fn from(err: DerivationError) -> Self {
|
|
Error::Derivation(err)
|
|
}
|
|
}
|