1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-21 21:50:00 -05:00
denoland-deno/tests/unit_node/crypto/generate_fixture.mjs
2024-12-31 19:12:39 +00:00

69 lines
1.4 KiB
JavaScript

// Copyright 2018-2025 the Deno authors. MIT license.
// Run this file with `node` to regenerate the testdata/crypto_digest_fixtures.json file.
import { readFileSync, writeFileSync } from "node:fs";
import { join } from "node:path";
import crypto from "node:crypto";
import { Buffer } from "node:buffer";
const privateKey = readFileSync(
join(import.meta.dirname, "..", "testdata", "rsa_private.pem"),
);
const fixtures = [];
const DATA = "Hello, world!";
const SALT = "salt";
const INFO = "info";
const ITERATIONS = 1000;
const KEY_LEN = 64;
for (const digest of crypto.getHashes()) {
const hasher = crypto.createHash(digest);
hasher.update(DATA);
let hash;
try {
hash = hasher.digest().toString("hex");
} catch {
hash = null;
}
const sign = crypto.createSign(digest);
sign.update(DATA);
let signature;
try {
signature = sign.sign(privateKey).toString("hex");
} catch {
signature = null;
}
let pkdf2;
try {
pkdf2 = crypto.pbkdf2Sync(DATA, SALT, ITERATIONS, KEY_LEN, digest).toString(
"hex",
);
} catch {
pkdf2 = null;
}
let hkdf;
try {
hkdf = Buffer.from(crypto.hkdfSync(digest, DATA, SALT, INFO, KEY_LEN))
.toString("hex");
} catch {
hkdf = null;
}
fixtures.push({
digest,
hash,
signature,
pkdf2,
hkdf,
});
}
writeFileSync(
join(import.meta.dirname, "..", "testdata", "crypto_digest_fixtures.json"),
JSON.stringify(fixtures, null, 2),
);