mirror of
https://github.com/imputnet/cobalt.git
synced 2025-06-29 01:48:28 +00:00
28 lines
929 B
JavaScript
28 lines
929 B
JavaScript
import { createHmac, createCipheriv, createDecipheriv, randomBytes } from "crypto";
|
|
|
|
const algorithm = "aes256";
|
|
|
|
export function generateSalt() {
|
|
return randomBytes(64).toString('hex');
|
|
}
|
|
|
|
export function generateHmac(str, salt) {
|
|
return createHmac("sha256", salt).update(str).digest("base64url");
|
|
}
|
|
|
|
export function encryptStream(plaintext, iv, secret) {
|
|
const buff = Buffer.from(JSON.stringify(plaintext));
|
|
const key = Buffer.from(secret, "base64url");
|
|
const cipher = createCipheriv(algorithm, key, Buffer.from(iv, "base64url"));
|
|
|
|
return Buffer.concat([ cipher.update(buff), cipher.final() ])
|
|
}
|
|
|
|
export function decryptStream(ciphertext, iv, secret) {
|
|
const buff = Buffer.from(ciphertext);
|
|
const key = Buffer.from(secret, "base64url");
|
|
const decipher = createDecipheriv(algorithm, key, Buffer.from(iv, "base64url"));
|
|
|
|
return Buffer.concat([ decipher.update(buff), decipher.final() ])
|
|
}
|