mirror of
https://github.com/ajnart/homarr.git
synced 2026-01-31 03:39:21 +01:00
32 lines
1.3 KiB
TypeScript
32 lines
1.3 KiB
TypeScript
import crypto from "crypto";
|
|
|
|
import { env } from "../env";
|
|
|
|
const algorithm = "aes-256-cbc"; //Using AES encryption
|
|
|
|
// We fallback to a key of 0s if the key was not provided because env validation was skipped
|
|
// This should only be the case in CI
|
|
const key = Buffer.from(env.SECRET_ENCRYPTION_KEY || "0".repeat(64), "hex");
|
|
|
|
export function encryptSecret(text: string): `${string}.${string}` {
|
|
const initializationVector = crypto.randomBytes(16);
|
|
const cipher = crypto.createCipheriv(algorithm, Buffer.from(key), initializationVector);
|
|
let encrypted = cipher.update(text);
|
|
encrypted = Buffer.concat([encrypted, cipher.final()]);
|
|
return `${encrypted.toString("hex")}.${initializationVector.toString("hex")}`;
|
|
}
|
|
|
|
export function decryptSecret(value: `${string}.${string}`) {
|
|
return decryptSecretWithKey(value, key);
|
|
}
|
|
|
|
export function decryptSecretWithKey(value: `${string}.${string}`, key: Buffer) {
|
|
const [data, dataIv] = value.split(".") as [string, string];
|
|
const initializationVector = Buffer.from(dataIv, "hex");
|
|
const encryptedText = Buffer.from(data, "hex");
|
|
const decipher = crypto.createDecipheriv(algorithm, Buffer.from(key), initializationVector);
|
|
let decrypted = decipher.update(encryptedText);
|
|
decrypted = Buffer.concat([decrypted, decipher.final()]);
|
|
return decrypted.toString();
|
|
}
|