mirror of
https://github.com/odin-lang/Odin.git
synced 2026-01-07 05:23:12 +00:00
98 lines
2.5 KiB
Odin
98 lines
2.5 KiB
Odin
/*
|
|
package sha3 implements the SHA3 hash algorithm family.
|
|
|
|
The SHAKE XOF can be found in crypto/shake. While discouraged if the
|
|
pre-standardization Keccak algorithm is required, it can be found in
|
|
crypto/legacy/keccak.
|
|
|
|
See:
|
|
- [[ https://nvlpubs.nist.gov/nistpubs/fips/nist.fips.202.pdf ]]
|
|
*/
|
|
package sha3
|
|
|
|
/*
|
|
Copyright 2021 zhibog
|
|
Made available under the BSD-3 license.
|
|
|
|
List of contributors:
|
|
zhibog, dotbmp: Initial implementation.
|
|
*/
|
|
|
|
import "../_sha3"
|
|
|
|
// DIGEST_SIZE_224 is the SHA3-224 digest size.
|
|
DIGEST_SIZE_224 :: 28
|
|
// DIGEST_SIZE_256 is the SHA3-256 digest size.
|
|
DIGEST_SIZE_256 :: 32
|
|
// DIGEST_SIZE_384 is the SHA3-384 digest size.
|
|
DIGEST_SIZE_384 :: 48
|
|
// DIGEST_SIZE_512 is the SHA3-512 digest size.
|
|
DIGEST_SIZE_512 :: 64
|
|
|
|
// BLOCK_SIZE_224 is the SHA3-224 block size in bytes.
|
|
BLOCK_SIZE_224 :: _sha3.RATE_224
|
|
// BLOCK_SIZE_256 is the SHA3-256 block size in bytes.
|
|
BLOCK_SIZE_256 :: _sha3.RATE_256
|
|
// BLOCK_SIZE_384 is the SHA3-384 block size in bytes.
|
|
BLOCK_SIZE_384 :: _sha3.RATE_384
|
|
// BLOCK_SIZE_512 is the SHA3-512 block size in bytes.
|
|
BLOCK_SIZE_512 :: _sha3.RATE_512
|
|
|
|
// Context is a SHA3 instance.
|
|
Context :: distinct _sha3.Context
|
|
|
|
// init_224 initializes a Context for SHA3-224.
|
|
init_224 :: proc(ctx: ^Context) {
|
|
ctx.mdlen = DIGEST_SIZE_224
|
|
_init(ctx)
|
|
}
|
|
|
|
// init_256 initializes a Context for SHA3-256.
|
|
init_256 :: proc(ctx: ^Context) {
|
|
ctx.mdlen = DIGEST_SIZE_256
|
|
_init(ctx)
|
|
}
|
|
|
|
// init_384 initializes a Context for SHA3-384.
|
|
init_384 :: proc(ctx: ^Context) {
|
|
ctx.mdlen = DIGEST_SIZE_384
|
|
_init(ctx)
|
|
}
|
|
|
|
// init_512 initializes a Context for SHA3-512.
|
|
init_512 :: proc(ctx: ^Context) {
|
|
ctx.mdlen = DIGEST_SIZE_512
|
|
_init(ctx)
|
|
}
|
|
|
|
@(private)
|
|
_init :: proc(ctx: ^Context) {
|
|
ctx.dsbyte = _sha3.DS_SHA3
|
|
_sha3.init((^_sha3.Context)(ctx))
|
|
}
|
|
|
|
// update adds more data to the Context.
|
|
update :: proc(ctx: ^Context, data: []byte) {
|
|
_sha3.update((^_sha3.Context)(ctx), data)
|
|
}
|
|
|
|
// final finalizes the Context, writes the digest to hash, and calls
|
|
// reset on the Context.
|
|
//
|
|
// Iff finalize_clone is set, final will work on a copy of the Context,
|
|
// which is useful for for calculating rolling digests.
|
|
final :: proc(ctx: ^Context, hash: []byte, finalize_clone: bool = false) {
|
|
_sha3.final((^_sha3.Context)(ctx), hash, finalize_clone)
|
|
}
|
|
|
|
// clone clones the Context other into ctx.
|
|
clone :: proc(ctx, other: ^Context) {
|
|
_sha3.clone((^_sha3.Context)(ctx), (^_sha3.Context)(other))
|
|
}
|
|
|
|
// reset sanitizes the Context. The Context must be re-initialized to
|
|
// be used again.
|
|
reset :: proc(ctx: ^Context) {
|
|
_sha3.reset((^_sha3.Context)(ctx))
|
|
}
|