eax

package
v1.1.0-alpha.1-proton Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 28, 2024 License: BSD-3-Clause Imports: 4 Imported by: 1

Documentation

Overview

Package eax provides an implementation of the EAX (encrypt-authenticate-translate) mode of operation, as described in Bellare, Rogaway, and Wagner "THE EAX MODE OF OPERATION: A TWO-PASS AUTHENTICATED-ENCRYPTION SCHEME OPTIMIZED FOR SIMPLICITY AND EFFICIENCY." In FSE'04, volume 3017 of LNCS, 2004

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewEAX

func NewEAX(block cipher.Block) (cipher.AEAD, error)

NewEAX returns an EAX instance with AES-{KEYLENGTH} and default nonce and tag lengths. Supports {128, 192, 256}- bit key length.

func NewEAXWithNonceAndTagSize

func NewEAXWithNonceAndTagSize(
	block cipher.Block, nonceSize, tagSize int) (cipher.AEAD, error)

NewEAXWithNonceAndTagSize returns an EAX instance with AES-{keyLength} and given nonce and tag lengths in bytes. Panics on zero nonceSize and exceedingly long tags.

It is recommended to use at least 12 bytes as tag length (see, for instance, NIST SP 800-38D).

Only to be used for compatibility with existing cryptosystems with non-standard parameters. For all other cases, prefer NewEAX.

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL