signal-desktop/ts/util/appendMacStream.ts

43 lines
971 B
TypeScript
Raw Normal View History

2024-04-15 20:54:21 +00:00
// Copyright 2024 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import { createHmac } from 'crypto';
import { Transform } from 'stream';
import type { Duplex } from 'stream';
import { HashType } from '../types/Crypto';
export const MAC_KEY_SIZE = 32;
export const MAC_SIZE = 32;
2024-07-11 19:44:09 +00:00
export function appendMacStream(
macKey: Uint8Array,
onMac?: (mac: Uint8Array) => undefined
): Duplex {
2024-04-15 20:54:21 +00:00
if (macKey.byteLength !== MAC_KEY_SIZE) {
throw new Error('appendMacStream: invalid macKey length');
}
const hmac = createHmac(HashType.size256, macKey);
return new Transform({
transform(chunk, _encoding, callback) {
try {
hmac.update(chunk);
callback(null, chunk);
} catch (error) {
callback(error);
}
},
flush(callback) {
try {
2024-07-11 19:44:09 +00:00
const mac = hmac.digest();
onMac?.(mac);
callback(null, mac);
2024-04-15 20:54:21 +00:00
} catch (error) {
callback(error);
}
},
});
}