ocb

package
v1.0.2031 Latest Latest
Warning

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

Go to latest
Published: Nov 7, 2023 License: Apache-2.0 Imports: 7 Imported by: 0

Documentation

Overview

Package ocb provides an implementation of the OCB (offset codebook) mode of operation, as described in RFC-7253 of the IRTF and in Rogaway, Bellare, Black and Krovetz - OCB: A BLOCK-CIPHER MODE OF OPERATION FOR EFFICIENT AUTHENTICATED ENCRYPTION (2003). Security considerations (from RFC-7253): A private key MUST NOT be used to encrypt more than 2^48 blocks. Tag length should be at least 12 bytes (a brute-force forging adversary succeeds after 2^{tag length} attempts). A single key SHOULD NOT be used to decrypt ciphertext with different tag lengths. Nonces need not be secret, but MUST NOT be reused. This package only supports underlying block ciphers with 128-bit blocks, such as AES-{128, 192, 256}, but may be extended to other sizes.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func NewOCB

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

NewOCB returns an OCB instance with the given block cipher and default tag and nonce sizes.

func NewOCBWithNonceAndTagSize

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

NewOCBWithNonceAndTagSize returns an OCB instance with the given block cipher, nonce length, and tag length. Panics on zero nonceSize and exceedingly long tag size.

It is recommended to use at least 12 bytes as tag length.

func NewOCBWithNonceSize

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

func NewOCBWithTagSize

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

Types

This section is empty.

Jump to

Keyboard shortcuts

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