Added some convenient stuff to BigInteger Did a tiny rename (looks like not all of the SHA project was renamed but meh who cares for now)
65 lines
1.8 KiB
C++
65 lines
1.8 KiB
C++
#pragma once
|
|
#include "Primes.h"
|
|
#include "BigInteger.h"
|
|
|
|
|
|
#if defined(__MINGW32__) || defined(_WIN32)
|
|
|
|
#if defined(RSA_API)
|
|
#undef RSA_API
|
|
#define RSA_API __declspec(dllexport)
|
|
#else
|
|
#define RSA_API __declspec(dllimport)
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#ifndef RSA_API
|
|
#if __GNUC__ >= 4
|
|
#define RSA_API __attribute__ ((visibility ("default")))
|
|
#else
|
|
#define RSA_API
|
|
#endif
|
|
#endif
|
|
|
|
|
|
namespace CryptoCPP { namespace RSA {
|
|
struct PublicKey
|
|
{
|
|
Math::BigInteger * mod;
|
|
Math::BigInteger * exp;
|
|
};
|
|
typedef Math::BigInteger PrivateKey;
|
|
struct KeyPair {
|
|
PublicKey * pub;
|
|
PrivateKey * priv;
|
|
};
|
|
|
|
class RSA
|
|
{
|
|
public:
|
|
RSA_API RSA(KeyPair* pair);
|
|
|
|
RSA_API char* encrypt(char* message); // Encrypt with public key
|
|
RSA_API char* sign(char* message); // Encrypt with private key
|
|
|
|
RSA_API char* decrypt(char* cipher); // Decrypt with private key
|
|
RSA_API char* check_sign(char* cipher); // Decrypt with public key
|
|
|
|
RSA_API bool can_decrypt(); // Checks whether or not we have a private key
|
|
|
|
RSA_API char* serialize_net(); // Serializes public key
|
|
RSA_API char* serialize_all(); // Complete serialization (public + private key). NOTE: Should NEVER be transmitted over an insecure channel. This should preferably be kept to the local file system
|
|
|
|
RSA_API static RSA * deserialize(char* ser);// Deserializes a serialized RSA object. Autodetects whether or not a private key is available
|
|
|
|
protected:
|
|
KeyPair * keypair;
|
|
|
|
RSA_API static char* encrypt(char* message, Math::BigInteger * exp, Math::BigInteger * mod); // Internal encryption function. exp can be either public or private exponent
|
|
RSA_API static char* decrypt(char* message, Math::BigInteger * exp, Math::BigInteger * mod); // Internal decryption function. -||-
|
|
};
|
|
|
|
typedef char(*RandomProvider)();
|
|
KeyPair* generate_key_pair(RandomProvider provider, size_t approximate_byte_count, size_t byte_margin);
|
|
}} |