This operation:
A typical use case for additional data is to store protocol-specific metadata about the message, such as its length and encoding.
The chosen construction uses encrypt-then-MAC and decryption will never be performed, even partially, before verification.
libsodium implements three versions of the ChaCha20-Poly1305 construction:
The first two variants are fully interoperable with other crypto libaries. The XChaCha20 variant is currently only implemented in libsodium, but is the recommended option if interoperability is not a concern.
They all share the same security properties when used properly, and are accessible via a similar API.
The crypto_aead_chacha20poly1305_*()
set of functions implements the original construction, the crypto_aead_chacha20poly1305_ietf_*()
functions implement the IETF version, and the crypto_aead_xchacha20poly1305_ietf_*()
functions implement the XChaCha20 variant.
The constants are the same, except for the nonce size.