![]() |
Fabcoin Core
0.16.2
P2P Digital Currency
|
ElGamal key agreement and encryption schemes default implementation. More...
#include <elgamal.h>
Public Member Functions | |
virtual | ~ElGamalObjectImpl () |
size_t | FixedMaxPlaintextLength () const |
size_t | FixedCiphertextLength () const |
const DL_GroupParameters_GFP & | GetGroupParameters () const |
DecodingResult | FixedLengthDecrypt (RandomNumberGenerator &rng, const byte *cipherText, byte *plainText) const |
![]() | |
virtual | ~DL_ObjectImplBase () |
PrivateKey & | AccessPrivateKey () |
PublicKey & | AccessPublicKey () |
const KEY & | GetKey () const |
KEY & | AccessKey () |
![]() | |
std::string | AlgorithmName () const |
![]() | |
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 |
![]() | |
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 |
Protected Member Functions | |
const DL_KeyAgreementAlgorithm< Integer > & | GetKeyAgreementAlgorithm () const |
const DL_KeyDerivationAlgorithm< Integer > & | GetKeyDerivationAlgorithm () const |
const DL_SymmetricEncryptionAlgorithm & | GetSymmetricEncryptionAlgorithm () const |
![]() | |
BASE::KeyInterface & | AccessKeyInterface () |
const BASE::KeyInterface & | GetKeyInterface () const |
HashIdentifier | GetHashIdentifier () const |
size_t | GetDigestSize () const |
Additional Inherited Members | |
![]() | |
typedef SCHEME_OPTIONS | SchemeOptions |
typedef KEY::Element | Element |
![]() | |
typedef Integer | Element |
![]() | |
typedef Integer | Element |
![]() | |
static std::string CRYPTOPP_API | StaticAlgorithmName () |
ElGamal key agreement and encryption schemes default implementation.
|
inlinevirtual |
|
inline |
|
inline |
|
inline |
|
inlinevirtual |
Implements ElGamalBase.
Definition at line 108 of file elgamal.h.
|
inlineprotected |
|
inlineprotected |
|
inlineprotected |