CryptoCPP/RSA/RSA.h
GabrielTofvesson b7e8a1d439 Updated readme
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)
2018-03-05 07:59:53 +01:00

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);
}}