PTLib
Version 2.14.3
|
Encryption/decryption context. More...
#include <pssl.h>
Public Types | |
enum | PadMode { NoPadding, PadPKCS, PadLoosePKCS, PadCipherStealing } |
![]() | |
enum | Comparison { LessThan = -1, EqualTo = 0, GreaterThan = 1 } |
Result of the comparison operation performed by the Compare() function. More... | |
Public Member Functions | |
PSSLCipherContext (bool encrypt) | |
~PSSLCipherContext () | |
operator evp_cipher_ctx_st * () const | |
Get internal OpenSSL cipher context structure. More... | |
bool | IsEncrypt () const |
Indicate we are encrypting data. More... | |
PString | GetAlgorithm () const |
Get selected algorithm. More... | |
bool | SetAlgorithm (const PString &name) |
Set encryption/decryption algorithm. More... | |
bool | SetKey (const PBYTEArray &key) |
Set encryption/decryption key. More... | |
bool | SetKey (const BYTE *keyPtr, PINDEX keyLen) |
bool | SetIV (const PBYTEArray &iv) |
Set encryption/decryption initial vector. More... | |
bool | SetIV (const BYTE *ivPtr, PINDEX ivLen) |
bool | SetPadding (PadMode pad) |
Set padding mode. More... | |
PadMode | GetPadding () const |
Get padding mode. More... | |
bool | Process (const PBYTEArray &in, PBYTEArray &out) |
Encrypt/Decrypt a block of data. More... | |
bool | Process (const BYTE *inPtr, PINDEX inLen, BYTE *outPtr, PINDEX &outLen, bool partial=false) |
PINDEX | GetKeyLength () const |
Get the cipher key length. More... | |
PINDEX | GetIVLength () const |
Get the cipher initial vector length. More... | |
PINDEX | GetBlockSize () const |
Get the cipher block size. More... | |
PINDEX | GetBlockedDataSize (PINDEX size) const |
Calculate the rounded up size for encrypted data. More... | |
![]() | |
unsigned | GetTraceContextIdentifier () const |
Get PTRACE context identifier. More... | |
void | SetTraceContextIdentifier (unsigned id) |
void | GetTraceContextIdentifier (PObject &obj) |
void | GetTraceContextIdentifier (PObject *obj) |
void | SetTraceContextIdentifier (const PObject &obj) |
void | SetTraceContextIdentifier (const PObject *obj) |
virtual | ~PObject () |
virtual PObject * | Clone () const |
Create a copy of the class on the heap. More... | |
template<class CLS > | |
CLS * | CloneAs () const |
As for Clone() but converts to specified type. More... | |
virtual PINDEX | HashFunction () const |
This function yields a hash value required by the PDictionary class. More... | |
virtual const char * | GetClass (unsigned ancestor=0) const |
Get the current dynamic type of the object instance. More... | |
PBoolean | IsClass (const char *cls) const |
virtual PBoolean | InternalIsDescendant (const char *clsName) const |
Determine if the dynamic type of the current instance is a descendent of the specified class. More... | |
__inline const PObject * | PTraceObjectInstance () const |
virtual Comparison | Compare (const PObject &obj) const |
Compare the two objects and return their relative rank. More... | |
virtual Comparison | CompareObjectMemoryDirect (const PObject &obj) const |
Determine the byte wise comparison of two objects. More... | |
bool | operator== (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator!= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator< (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator> (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator<= (const PObject &obj) const |
Compare the two objects. More... | |
bool | operator>= (const PObject &obj) const |
Compare the two objects. More... | |
virtual void | PrintOn (ostream &strm) const |
Output the contents of the object to the stream. More... | |
virtual void | ReadFrom (istream &strm) |
Input the contents of the object from the stream. More... | |
Protected Attributes | |
PadMode | m_padMode |
evp_cipher_ctx_st * | m_context |
![]() | |
unsigned | m_traceContextIdentifier |
Additional Inherited Members | |
![]() | |
static const char * | Class () |
Get the name of the class as a C string. More... | |
static __inline const PObject * | PTraceObjectInstance (const char *) |
static __inline const PObject * | PTraceObjectInstance (const PObject *obj) |
static Comparison | InternalCompareObjectMemoryDirect (const PObject *obj1, const PObject *obj2, PINDEX size) |
Internal function caled from CompareObjectMemoryDirect() More... | |
![]() | |
PObject () | |
Constructor for PObject, made protected so cannot ever create one on its own. More... | |
![]() |
Encryption/decryption context.
PSSLCipherContext::PSSLCipherContext | ( | bool | encrypt | ) |
PSSLCipherContext::~PSSLCipherContext | ( | ) |
PString PSSLCipherContext::GetAlgorithm | ( | ) | const |
Get selected algorithm.
PINDEX PSSLCipherContext::GetBlockedDataSize | ( | PINDEX | size | ) | const |
Calculate the rounded up size for encrypted data.
PINDEX PSSLCipherContext::GetBlockSize | ( | ) | const |
Get the cipher block size.
PINDEX PSSLCipherContext::GetIVLength | ( | ) | const |
Get the cipher initial vector length.
PINDEX PSSLCipherContext::GetKeyLength | ( | ) | const |
Get the cipher key length.
|
inline |
bool PSSLCipherContext::IsEncrypt | ( | ) | const |
Indicate we are encrypting data.
|
inline |
Get internal OpenSSL cipher context structure.
References m_context.
bool PSSLCipherContext::Process | ( | const PBYTEArray & | in, |
PBYTEArray & | out | ||
) |
Encrypt/Decrypt a block of data.
in | Data to be encrypted |
out | Encrypted data |
bool PSSLCipherContext::Process | ( | const BYTE * | inPtr, |
PINDEX | inLen, | ||
BYTE * | outPtr, | ||
PINDEX & | outLen, | ||
bool | partial = false |
||
) |
inPtr | Data to be encrypted |
inLen | Length of data to be encrypted |
outPtr | Encrypted data |
outLen | Max output space on input, then actual output data size |
partial | Partial data, more to come |
bool PSSLCipherContext::SetAlgorithm | ( | const PString & | name | ) |
Set encryption/decryption algorithm.
The
name | Name or OID for the algorithm. |
|
inline |
Set encryption/decryption initial vector.
References PContainer::GetSize(), and SetIV().
Referenced by SetIV().
bool PSSLCipherContext::SetIV | ( | const BYTE * | ivPtr, |
PINDEX | ivLen | ||
) |
|
inline |
Set encryption/decryption key.
References PContainer::GetSize(), and SetKey().
Referenced by SetKey().
bool PSSLCipherContext::SetKey | ( | const BYTE * | keyPtr, |
PINDEX | keyLen | ||
) |
bool PSSLCipherContext::SetPadding | ( | PadMode | pad | ) |
Set padding mode.
If NoPadding, then buffers supplied to Process() must be exact multiple of the block size.
|
protected |
Referenced by operator evp_cipher_ctx_st *().
|
protected |
Referenced by GetPadding().