i2pd/core/crypto/Signature.cpp

39 lines
1 KiB
C++
Raw Normal View History

2015-04-09 16:03:21 +02:00
#include <memory>
2015-04-08 19:21:49 +02:00
#include <cryptopp/integer.h>
#include <cryptopp/eccrypto.h>
2015-07-30 15:34:56 +02:00
#include "util/Log.h"
2015-04-08 19:21:49 +02:00
#include "Signature.h"
namespace i2p {
namespace crypto {
DSASigner::DSASigner(const uint8_t * signingPrivateKey)
{
m_PrivateKey.Initialize(
dsap, dsaq, dsag,
CryptoPP::Integer(signingPrivateKey, DSA_PRIVATE_KEY_LENGTH)
);
2015-04-08 19:21:49 +02:00
}
void DSASigner::Sign(CryptoPP::RandomNumberGenerator& rnd, const uint8_t * buf,
int len, uint8_t * signature) const
{
CryptoPP::DSA::Signer signer(m_PrivateKey);
signer.SignMessage(rnd, buf, len, signature);
2015-04-08 19:21:49 +02:00
}
void CreateDSARandomKeys(CryptoPP::RandomNumberGenerator& rnd,
uint8_t* signingPrivateKey, uint8_t* signingPublicKey)
{
CryptoPP::DSA::PrivateKey privateKey;
CryptoPP::DSA::PublicKey publicKey;
privateKey.Initialize(rnd, dsap, dsaq, dsag);
privateKey.MakePublicKey(publicKey);
privateKey.GetPrivateExponent().Encode(signingPrivateKey, DSA_PRIVATE_KEY_LENGTH);
publicKey.GetPublicElement().Encode(signingPublicKey, DSA_PUBLIC_KEY_LENGTH);
}
2015-04-08 19:21:49 +02:00
} // crypto
} // i2p