diff options
author | madmaxoft <github@xoft.cz> | 2014-04-29 17:13:08 +0200 |
---|---|---|
committer | madmaxoft <github@xoft.cz> | 2014-04-29 17:13:08 +0200 |
commit | d9f7ae6a4d0895752c1a62657c36433e92104346 (patch) | |
tree | 5f6e13c16f1ae794851514ec2532bebf7ccb0727 /src/PolarSSL++/PublicKey.h | |
parent | Merge branch 'master' into SslWrappers (diff) | |
download | cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar.gz cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar.bz2 cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar.lz cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar.xz cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.tar.zst cuberite-d9f7ae6a4d0895752c1a62657c36433e92104346.zip |
Diffstat (limited to 'src/PolarSSL++/PublicKey.h')
-rw-r--r-- | src/PolarSSL++/PublicKey.h | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/PolarSSL++/PublicKey.h b/src/PolarSSL++/PublicKey.h new file mode 100644 index 000000000..5a0a57147 --- /dev/null +++ b/src/PolarSSL++/PublicKey.h @@ -0,0 +1,48 @@ + +// PublicKey.h + +// Declares the cPublicKey class representing a RSA public key in PolarSSL + + + + + +#pragma once + +#include "CtrDrbgContext.h" +#include "polarssl/pk.h" + + + + + +class cPublicKey +{ +public: + /** Constructs the public key out of the DER-encoded pubkey data */ + cPublicKey(const AString & a_PublicKeyDER); + + ~cPublicKey(); + + /** Decrypts the data using the stored public key + Both a_EncryptedData and a_DecryptedData must be at least <KeySizeBytes> bytes large. + Returns the number of bytes decrypted, or negative number for error. */ + int Decrypt(const Byte * a_EncryptedData, size_t a_EncryptedLength, Byte * a_DecryptedData, size_t a_DecryptedMaxLength); + + /** Encrypts the data using the stored public key + Both a_EncryptedData and a_DecryptedData must be at least <KeySizeBytes> bytes large. + Returns the number of bytes decrypted, or negative number for error. */ + int Encrypt(const Byte * a_PlainData, size_t a_PlainLength, Byte * a_EncryptedData, size_t a_EncryptedMaxLength); + +protected: + /** The public key PolarSSL representation */ + pk_context m_Pk; + + /** The random generator used in encryption and decryption */ + cCtrDrbgContext m_CtrDrbg; +} ; + + + + + |