summaryrefslogtreecommitdiffstats
path: root/src/PolarSSL++/PublicKey.h
diff options
context:
space:
mode:
authormadmaxoft <github@xoft.cz>2014-04-29 17:13:08 +0200
committermadmaxoft <github@xoft.cz>2014-04-29 17:13:08 +0200
commitd9f7ae6a4d0895752c1a62657c36433e92104346 (patch)
tree5f6e13c16f1ae794851514ec2532bebf7ccb0727 /src/PolarSSL++/PublicKey.h
parentMerge branch 'master' into SslWrappers (diff)
downloadcuberite-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 '')
-rw-r--r--src/PolarSSL++/PublicKey.h48
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;
+} ;
+
+
+
+
+