// Copyright 2015-2017 Parity Technologies (UK) Ltd. // 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 . use std::fmt; use std::ops::Deref; use std::str::FromStr; use secp256k1::key; use bigint::hash::H256; use {Error}; #[derive(Clone, PartialEq, Eq)] pub struct Secret { inner: H256, } impl fmt::Debug for Secret { fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result { write!(fmt, "Secret: 0x{:x}{:x}..{:x}{:x}", self.inner[0], self.inner[1], self.inner[30], self.inner[31]) } } impl Secret { fn from_slice_unchecked(key: &[u8]) -> Self { assert_eq!(32, key.len(), "Caller should provide 32-byte length slice"); let mut h = H256::default(); h.copy_from_slice(&key[0..32]); Secret { inner: h } } pub fn from_slice(key: &[u8]) -> Result { let secret = key::SecretKey::from_slice(&super::SECP256K1, key)?; Ok(secret.into()) } } impl FromStr for Secret { type Err = Error; fn from_str(s: &str) -> Result { let hash = H256::from_str(s).map_err(|e| Error::Custom(format!("{:?}", e)))?; Self::from_slice(&hash) } } impl From for Secret { fn from(key: key::SecretKey) -> Self { Self::from_slice_unchecked(&key[0..32]) } } impl Deref for Secret { type Target = H256; fn deref(&self) -> &Self::Target { &self.inner } }