25#ifndef CRYPTOPP_POLY1305_H
26#define CRYPTOPP_POLY1305_H
34NAMESPACE_BEGIN(CryptoPP)
45 CRYPTOPP_COMPILE_ASSERT(T::DEFAULT_KEYLENGTH == 16);
46 CRYPTOPP_COMPILE_ASSERT(T::BLOCKSIZE == 16);
49 static std::string StaticAlgorithmName() {
return std::string(
"Poly1305(") + T::StaticAlgorithmName() +
")";}
51 CRYPTOPP_CONSTANT(DIGESTSIZE=T::BLOCKSIZE);
52 CRYPTOPP_CONSTANT(BLOCKSIZE=T::BLOCKSIZE);
61 void Update(
const byte *input,
size_t length);
72 void HashBlocks(
const byte *input,
size_t length,
word32 padbit);
73 void HashFinal(
byte *mac,
size_t length);
75 typename T::Encryption m_cipher;
155 Poly1305(
const byte *key,
size_t keyLength=DEFAULT_KEYLENGTH,
const byte *nonce=NULLPTR,
size_t nonceLength=0)
167 static std::string StaticAlgorithmName() {
return std::string(
"Poly1305TLS");}
168 CRYPTOPP_CONSTANT(DIGESTSIZE=16);
169 CRYPTOPP_CONSTANT(BLOCKSIZE=16);
175 void Update(
const byte *input,
size_t length);
Classes for working with NameValuePairs.
AlgorithmParameters MakeParameters(const char *name, const T &value, bool throwIfNotUsed=true)
Create an object that implements NameValuePairs.
Standard names for retrieving values by name when working with NameValuePairs.
virtual std::string AlgorithmProvider() const
Retrieve the provider of this algorithm.
Used to pass byte array input as part of a NameValuePairs object.
Inherited by keyed algorithms with fixed key length.
Fixed size stack-based SecBlock with 16-byte alignment.
Provides class member functions to key a message authentication code.
Interface for message authentication codes.
Interface for retrieving values given their names.
Poly1305 message authentication code base class.
unsigned int DigestSize() const
unsigned int BlockSize() const
Provides the block size of the compression function.
Poly1305 message authentication code.
Poly1305(const byte *key, size_t keyLength=DEFAULT_KEYLENGTH, const byte *nonce=NULLPTR, size_t nonceLength=0)
Construct a Poly1305.
Poly1305()
Construct a Poly1305.
Poly1305-TLS message authentication code base class.
unsigned int BlockSize() const
Provides the block size of the compression function.
void UncheckedSetKey(const byte *key, unsigned int length, const NameValuePairs ¶ms)
Sets the key for this object without performing parameter validation.
void TruncatedFinal(byte *mac, size_t size)
Computes the hash of the current message.
void Update(const byte *input, size_t length)
Updates a hash with additional input.
unsigned int DigestSize() const
void Restart()
Restart the hash.
Interface for random number generators.
virtual void UncheckedSetKey(const byte *key, unsigned int length, const NameValuePairs ¶ms)=0
Sets the key for this object without performing parameter validation.
virtual void GetNextIV(RandomNumberGenerator &rng, byte *iv)
Retrieves a secure IV for the next message.
virtual void Resynchronize(const byte *iv, int ivLength=-1)
Resynchronize with an IV.
unsigned int word32
32-bit unsigned datatype
Abstract base classes that provide a uniform interface to this library.
Classes and functions for secure memory allocations.
Classes and functions for implementing secret key algorithms.