/** SHA1 (RFC 3174), MD5 (RFC 1321) and RIPEMD160 (RFC 2286) legacy, weak hash functions. Don't use them in a new protocol. What "weak" means: - Collisions can be made with 2^18 effort in MD5, 2^60 in SHA1, 2^80 in RIPEMD160. - No practical pre-image attacks (only theoretical, 2^123.4) - HMAC seems kinda ok: https://datatracker.ietf.org/doc/html/rfc6151 * @module */ import { HashMD } from './_md.ts'; import { type CHash } from './utils.ts'; /** SHA1 legacy hash class. */ export declare class SHA1 extends HashMD { private A; private B; private C; private D; private E; constructor(); protected get(): [number, number, number, number, number]; protected set(A: number, B: number, C: number, D: number, E: number): void; protected process(view: DataView, offset: number): void; protected roundClean(): void; destroy(): void; } /** SHA1 (RFC 3174) legacy hash function. It was cryptographically broken. */ export declare const sha1: CHash; /** MD5 legacy hash class. */ export declare class MD5 extends HashMD { private A; private B; private C; private D; constructor(); protected get(): [number, number, number, number]; protected set(A: number, B: number, C: number, D: number): void; protected process(view: DataView, offset: number): void; protected roundClean(): void; destroy(): void; } /** * MD5 (RFC 1321) legacy hash function. It was cryptographically broken. * MD5 architecture is similar to SHA1, with some differences: * - Reduced output length: 16 bytes (128 bit) instead of 20 * - 64 rounds, instead of 80 * - Little-endian: could be faster, but will require more code * - Non-linear index selection: huge speed-up for unroll * - Per round constants: more memory accesses, additional speed-up for unroll */ export declare const md5: CHash; export declare class RIPEMD160 extends HashMD { private h0; private h1; private h2; private h3; private h4; constructor(); protected get(): [number, number, number, number, number]; protected set(h0: number, h1: number, h2: number, h3: number, h4: number): void; protected process(view: DataView, offset: number): void; protected roundClean(): void; destroy(): void; } /** * RIPEMD-160 - a legacy hash function from 1990s. * * https://homes.esat.kuleuven.be/~bosselae/ripemd160.html * * https://homes.esat.kuleuven.be/~bosselae/ripemd160/pdf/AB-9601/AB-9601.pdf */ export declare const ripemd160: CHash; //# sourceMappingURL=legacy.d.ts.map