|
|
|
#ifndef EDDSA25519_H__
|
|
|
|
#define EDDSA25519_H__
|
|
|
|
|
|
|
|
#include "SignatureBase.h"
|
|
|
|
|
|
|
|
namespace i2p {
|
|
|
|
namespace crypto {
|
|
|
|
|
|
|
|
// EdDSA
|
|
|
|
const size_t EDDSA25519_PUBLIC_KEY_LENGTH = 32;
|
|
|
|
const size_t EDDSA25519_SIGNATURE_LENGTH = 64;
|
|
|
|
const size_t EDDSA25519_PRIVATE_KEY_LENGTH = 32;
|
|
|
|
|
|
|
|
class EDDSA25519Verifier : public Verifier {
|
|
|
|
public:
|
|
|
|
|
|
|
|
EDDSA25519Verifier(const uint8_t* signingKey);
|
|
|
|
bool Verify(const uint8_t* buf, size_t len, const uint8_t* signature) const;
|
|
|
|
|
|
|
|
size_t GetPublicKeyLen() const;
|
|
|
|
size_t GetSignatureLen() const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
uint8_t m_PublicKey[EDDSA25519_PUBLIC_KEY_LENGTH];
|
|
|
|
};
|
|
|
|
|
|
|
|
class EDDSA25519Signer : public Signer {
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct from a key pair.
|
|
|
|
*/
|
|
|
|
EDDSA25519Signer(const uint8_t* signingPrivateKey, const uint8_t* signingPublicKey);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Construct from a private key.
|
|
|
|
* The corresponding public key will be computed from it.
|
|
|
|
*/
|
|
|
|
EDDSA25519Signer(const uint8_t* signingPrivateKey);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @todo do not pass random number generator, EdDSA does not require a random
|
|
|
|
* source
|
|
|
|
*/
|
|
|
|
void Sign(CryptoPP::RandomNumberGenerator&, const uint8_t* buf, int len, uint8_t* signature) const;
|
|
|
|
|
|
|
|
uint8_t m_PrivateKey[EDDSA25519_PRIVATE_KEY_LENGTH];
|
|
|
|
uint8_t m_PublicKey[EDDSA25519_PUBLIC_KEY_LENGTH];
|
|
|
|
};
|
|
|
|
|
|
|
|
void CreateEDDSARandomKeys(CryptoPP::RandomNumberGenerator& rnd, uint8_t* privateKey,
|
|
|
|
uint8_t* publicKey);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // EDDSA25519_H__
|