![]() |
Fabcoin Core
0.16.2
P2P Digital Currency
|
ElGamal key agreement and encryption schemes base class. More...
#include <elgamal.h>
Public Member Functions | |
virtual | ~ElGamalBase () |
void | Derive (const DL_GroupParameters< Integer > &groupParams, byte *derivedKey, size_t derivedLength, const Integer &agreedElement, const Integer &ephemeralPublicKey, const NameValuePairs &derivationParams) const |
size_t | GetSymmetricKeyLength (size_t plainTextLength) const |
size_t | GetSymmetricCiphertextLength (size_t plainTextLength) const |
size_t | GetMaxSymmetricPlaintextLength (size_t cipherTextLength) const |
void | SymmetricEncrypt (RandomNumberGenerator &rng, const byte *key, const byte *plainText, size_t plainTextLength, byte *cipherText, const NameValuePairs ¶meters) const |
DecodingResult | SymmetricDecrypt (const byte *key, const byte *cipherText, size_t cipherTextLength, byte *plainText, const NameValuePairs ¶meters) const |
virtual const DL_GroupParameters_GFP & | GetGroupParameters () const =0 |
![]() | |
CRYPTOPP_STATIC_CONSTEXPR const char *CRYPTOPP_API | StaticAlgorithmName () |
virtual | ~DL_KeyAgreementAlgorithm_DH () |
Element | AgreeWithEphemeralPrivateKey (const DL_GroupParameters< Element > ¶ms, const DL_FixedBasePrecomputation< Element > &publicPrecomputation, const Integer &privateExponent) const |
Element | AgreeWithStaticPrivateKey (const DL_GroupParameters< Element > ¶ms, const Element &publicElement, bool validateOtherPublicKey, const Integer &privateExponent) const |
![]() | |
virtual | ~DL_KeyAgreementAlgorithm () |
![]() | |
virtual | ~DL_KeyDerivationAlgorithm () |
virtual bool | ParameterSupported (const char *name) const |
![]() | |
virtual | ~DL_SymmetricEncryptionAlgorithm () |
virtual bool | ParameterSupported (const char *name) const |
Additional Inherited Members | |
![]() | |
typedef Integer | Element |
![]() | |
typedef Integer | Element |
ElGamal key agreement and encryption schemes base class.
|
inlinevirtual |
Implements DL_KeyDerivationAlgorithm< Integer >.
Definition at line 29 of file elgamal.h.
|
pure virtual |
Implemented in ElGamalObjectImpl< BASE, SCHEME_OPTIONS, KEY >.
|
inlinevirtual |
Implements DL_SymmetricEncryptionAlgorithm.
Definition at line 50 of file elgamal.h.
|
inlinevirtual |
Implements DL_SymmetricEncryptionAlgorithm.
|
inlinevirtual |
Implements DL_SymmetricEncryptionAlgorithm.
|
inlinevirtual |
Implements DL_SymmetricEncryptionAlgorithm.
Definition at line 73 of file elgamal.h.
|
inlinevirtual |
Implements DL_SymmetricEncryptionAlgorithm.
Definition at line 59 of file elgamal.h.