blob: 61bb16dcb206bf2bc03150d9e9e4c8d793ab7b1a [file] [log] [blame] [edit]
// See file LICENSE for more information.
library impl.digest.sha512;
import 'dart:typed_data';
import 'package:pointycastle/api.dart';
import 'package:pointycastle/src/impl/long_sha2_family_digest.dart';
import 'package:pointycastle/src/registry/registry.dart';
/// Implementation of SHA-512 digest.
class SHA512Digest extends LongSHA2FamilyDigest implements Digest {
static final FactoryConfig factoryConfig =
StaticFactoryConfig(Digest, 'SHA-512', () => SHA512Digest());
static const _DIGEST_LENGTH = 64;
SHA512Digest() {
reset();
}
@override
final algorithmName = 'SHA-512';
@override
final digestSize = _DIGEST_LENGTH;
@override
void reset() {
super.reset();
h1.set(0x6a09e667, 0xf3bcc908);
h2.set(0xbb67ae85, 0x84caa73b);
h3.set(0x3c6ef372, 0xfe94f82b);
h4.set(0xa54ff53a, 0x5f1d36f1);
h5.set(0x510e527f, 0xade682d1);
h6.set(0x9b05688c, 0x2b3e6c1f);
h7.set(0x1f83d9ab, 0xfb41bd6b);
h8.set(0x5be0cd19, 0x137e2179);
}
@override
int doFinal(Uint8List out, int outOff) {
finish();
var view = ByteData.view(out.buffer, out.offsetInBytes, out.length);
h1.pack(view, outOff, Endian.big);
h2.pack(view, outOff + 8, Endian.big);
h3.pack(view, outOff + 16, Endian.big);
h4.pack(view, outOff + 24, Endian.big);
h5.pack(view, outOff + 32, Endian.big);
h6.pack(view, outOff + 40, Endian.big);
h7.pack(view, outOff + 48, Endian.big);
h8.pack(view, outOff + 56, Endian.big);
reset();
return _DIGEST_LENGTH;
}
}