Crypto++
8.2
Free C++ class library of cryptographic schemes
|
Base class for additive stream ciphers with SymmetricCipher interface. More...
Public Types | |
typedef BASE::PolicyInterface | PolicyInterface |
Public Member Functions | |
void | GenerateBlock (byte *output, size_t size) |
Generate random array of bytes. More... | |
void | ProcessData (byte *outString, const byte *inString, size_t length) |
Apply keystream to data. More... | |
void | Resynchronize (const byte *iv, int length=-1) |
Resynchronize the cipher. More... | |
unsigned int | OptimalBlockSize () const |
Provides number of ideal bytes to process. More... | |
unsigned int | GetOptimalNextBlockSize () const |
Provides number of ideal bytes to process. More... | |
unsigned int | OptimalDataAlignment () const |
Provides number of ideal data alignment. More... | |
bool | IsSelfInverting () const |
Determines if the cipher is self inverting. More... | |
bool | IsForwardTransformation () const |
Determines if the cipher is a forward transformation. More... | |
bool | IsRandomAccess () const |
Flag indicating random access. More... | |
void | Seek (lword position) |
Seeks to a random position in the stream. More... | |
std::string | AlgorithmProvider () const |
Retrieve the provider of this algorithm. More... | |
![]() | |
virtual void | IncorporateEntropy (const byte *input, size_t length) |
Update RNG state with additional unpredictable values. More... | |
virtual bool | CanIncorporateEntropy () const |
Determines if a generator can accept additional entropy. More... | |
virtual byte | GenerateByte () |
Generate new random byte and return it. More... | |
virtual unsigned int | GenerateBit () |
Generate new random bit and return it. More... | |
virtual word32 | GenerateWord32 (word32 min=0, word32 max=0xffffffffUL) |
Generate a random 32 bit word in the range min to max, inclusive. More... | |
virtual void | GenerateIntoBufferedTransformation (BufferedTransformation &target, const std::string &channel, lword length) |
Generate random bytes into a BufferedTransformation. More... | |
virtual void | DiscardBytes (size_t n) |
Generate and discard n bytes. More... | |
template<class IT > | |
void | Shuffle (IT begin, IT end) |
Randomly shuffle the specified array. More... | |
![]() | |
Algorithm (bool checkSelfTestStatus=true) | |
Interface for all crypto algorithms. More... | |
virtual std::string | AlgorithmName () const |
Provides the name of this algorithm. More... | |
![]() | |
virtual Clonable * | Clone () const |
Copies this object. More... | |
Base class for additive stream ciphers with SymmetricCipher interface.
BASE | AbstractPolicyHolder base class |
Definition at line 299 of file strciphr.h.
|
virtual |
Generate random array of bytes.
output | the byte buffer |
size | the length of the buffer, in bytes |
All generated values are uniformly distributed over the range specified within the constraints of a particular generator.
Reimplemented from RandomNumberGenerator.
Definition at line 34 of file strciphr.cpp.
void AdditiveCipherTemplate< S >::ProcessData | ( | byte * | outString, |
const byte * | inString, | ||
size_t | length | ||
) |
Apply keystream to data.
outString | a buffer to write the transformed data |
inString | a buffer to read the data |
length | the size fo the buffers, in bytes |
This is the primary method to operate a stream cipher. For example:
size_t size = 30; byte plain[size] = "Do or do not; there is no try"; byte cipher[size]; ... ChaCha20 chacha(key, keySize); chacha.ProcessData(cipher, plain, size);
Definition at line 69 of file strciphr.cpp.
void AdditiveCipherTemplate< S >::Resynchronize | ( | const byte * | iv, |
int | length = -1 |
||
) |
Resynchronize the cipher.
iv | a byte array used to resynchronize the cipher |
length | the size of the IV array |
Definition at line 128 of file strciphr.cpp.
|
inline |
Provides number of ideal bytes to process.
Internally, the default implementation returns GetBytesPerIteration()
Definition at line 336 of file strciphr.h.
|
inline |
Provides number of ideal bytes to process.
Internally, the default implementation returns remaining unprocessed bytes
Definition at line 342 of file strciphr.h.
|
inline |
Provides number of ideal data alignment.
Definition at line 347 of file strciphr.h.
|
inline |
Determines if the cipher is self inverting.
Definition at line 351 of file strciphr.h.
|
inline |
Determines if the cipher is a forward transformation.
Definition at line 355 of file strciphr.h.
|
inline |
Flag indicating random access.
Definition at line 360 of file strciphr.h.
void AdditiveCipherTemplate< BASE >::Seek | ( | lword | position | ) |
Seeks to a random position in the stream.
position | the absolute position in the stream |
Definition at line 137 of file strciphr.cpp.
|
inlinevirtual |
Retrieve the provider of this algorithm.
The algorithm provider can be a name like "C++", "SSE", "NEON", "AESNI", "ARMv8" and "Power8". C++ is standard C++ code. Other labels, like SSE, usually indicate a specialized implementation using instructions from a higher instruction set architecture (ISA). Future labels may include external hardware like a hardware security module (HSM).
Generally speaking Wei Dai's original IA-32 ASM code falls under "SSE2". Labels like "SSSE3" and "SSE4.1" follow after Wei's code and use intrinsics instead of ASM.
Algorithms which combine different instructions or ISAs provide the dominant one. For example on x86 AES/GCM
returns "AESNI" rather than "CLMUL" or "AES+SSE4.1" or "AES+CLMUL" or "AES+SSE4.1+CLMUL".
Reimplemented from Algorithm.
Definition at line 381 of file strciphr.h.