Browse Source

rename nonce generator

cl-refactor
subtly 10 years ago
parent
commit
482a1241f7
  1. 18
      libdevcrypto/Common.cpp
  2. 16
      libdevcrypto/Common.h
  3. 2
      libdevcrypto/EC.cpp

18
libdevcrypto/Common.cpp

@ -28,6 +28,7 @@
#include "Common.h" #include "Common.h"
using namespace std; using namespace std;
using namespace dev; using namespace dev;
using namespace crypto;
//#define ETH_ADDRESS_DEBUG 1 //#define ETH_ADDRESS_DEBUG 1
@ -38,8 +39,8 @@ Address dev::toAddress(Secret _secret)
KeyPair KeyPair::create() KeyPair KeyPair::create()
{ {
static std::mt19937_64 s_eng(time(0)); static mt19937_64 s_eng(time(0));
std::uniform_int_distribution<uint16_t> d(0, 255); uniform_int_distribution<uint16_t> d(0, 255);
for (int i = 0; i < 100; ++i) for (int i = 0; i < 100; ++i)
{ {
@ -57,8 +58,8 @@ KeyPair KeyPair::create()
KeyPair::KeyPair(h256 _sec): KeyPair::KeyPair(h256 _sec):
m_secret(_sec) m_secret(_sec)
{ {
crypto::toPublic(m_secret, m_public); toPublic(m_secret, m_public);
if (crypto::verifySecret(m_secret, m_public)) if (verifySecret(m_secret, m_public))
m_address = right160(dev::sha3(m_public.ref())); m_address = right160(dev::sha3(m_public.ref()));
#if ETH_ADDRESS_DEBUG #if ETH_ADDRESS_DEBUG
@ -106,7 +107,7 @@ bool dev::verify(Public _p, Signature _s, h256 _hash)
return crypto::verify(_p, _s, bytesConstRef(_hash.data(), 32), true); return crypto::verify(_p, _s, bytesConstRef(_hash.data(), 32), true);
} }
h256 Sec::getNonce(bool _commit) h256 Nonce::get(bool _commit)
{ {
// todo: atomic efface bit, periodic save, kdf, rr, rng // todo: atomic efface bit, periodic save, kdf, rr, rng
static h256 seed; static h256 seed;
@ -116,8 +117,7 @@ h256 Sec::getNonce(bool _commit)
{ {
if (!seed) if (!seed)
{ {
static Sec sec; static Nonce nonce;
bytes b = contents(seedFile); bytes b = contents(seedFile);
if (b.size() == 32) if (b.size() == 32)
memcpy(seed.data(), b.data(), 32); memcpy(seed.data(), b.data(), 32);
@ -139,7 +139,7 @@ h256 Sec::getNonce(bool _commit)
return seed; return seed;
} }
Sec::~Sec() Nonce::~Nonce()
{ {
Sec::getNonce(true); Nonce::get(true);
} }

16
libdevcrypto/Common.h

@ -110,13 +110,19 @@ private:
Public m_public; Public m_public;
Address m_address; Address m_address;
}; };
struct Sec namespace crypto
{
/**
* @brief Generator for nonce material
*/
struct Nonce
{ {
static h256 getNonce(bool _commit = false); static h256 get(bool _commit = false);
private: private:
Sec() {} Nonce() {}
~Sec(); ~Nonce();
}; };
}
} }

2
libdevcrypto/EC.cpp

@ -56,7 +56,7 @@ void crypto::toPublic(Secret const& _s, Public& o_public)
h256 crypto::kdf(Secret const& _priv, h256 const& _hash) h256 crypto::kdf(Secret const& _priv, h256 const& _hash)
{ {
h256 s; h256 s;
sha3mac(Sec::getNonce().ref(), _priv.ref(), s.ref()); sha3mac(Nonce::get().ref(), _priv.ref(), s.ref());
assert(s); assert(s);
return sha3((_hash ^ s).asBytes()); return sha3((_hash ^ s).asBytes());
} }

Loading…
Cancel
Save