mirror of
https://github.com/denoland/deno.git
synced 2025-01-07 06:46:59 -05:00
08e5606c34
Previously we had many different code paths all handling digests in different places, all with wildly different digest support. This commit rewrites this to use a single digest handling mechanism for all digest operations. It adds various aliases for digest algorithms, like node does. For example `sha1WithRSAEncryption` is an alias for `sha1`. It also adds support for `md5-sha1` digests in various places.
190 lines
2.7 KiB
TypeScript
190 lines
2.7 KiB
TypeScript
// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.
|
|
import { scrypt, scryptSync } from "node:crypto";
|
|
import { Buffer } from "node:buffer";
|
|
import { assertEquals } from "@std/assert/mod.ts";
|
|
|
|
Deno.test("scrypt works correctly", async () => {
|
|
const { promise, resolve } = Promise.withResolvers<boolean>();
|
|
|
|
scrypt("password", "salt", 32, (err, key) => {
|
|
if (err) throw err;
|
|
assertEquals(
|
|
key,
|
|
Buffer.from([
|
|
116,
|
|
87,
|
|
49,
|
|
175,
|
|
68,
|
|
132,
|
|
243,
|
|
35,
|
|
150,
|
|
137,
|
|
105,
|
|
237,
|
|
162,
|
|
137,
|
|
174,
|
|
238,
|
|
0,
|
|
91,
|
|
89,
|
|
3,
|
|
172,
|
|
86,
|
|
30,
|
|
100,
|
|
165,
|
|
172,
|
|
161,
|
|
33,
|
|
121,
|
|
123,
|
|
247,
|
|
115,
|
|
]),
|
|
);
|
|
resolve(true);
|
|
});
|
|
|
|
await promise;
|
|
});
|
|
|
|
Deno.test("scrypt works with options", async () => {
|
|
const { promise, resolve } = Promise.withResolvers<boolean>();
|
|
|
|
scrypt(
|
|
"password",
|
|
"salt",
|
|
32,
|
|
{
|
|
N: 512,
|
|
},
|
|
(err, key) => {
|
|
if (err) throw err;
|
|
assertEquals(
|
|
key,
|
|
Buffer.from([
|
|
57,
|
|
134,
|
|
165,
|
|
72,
|
|
236,
|
|
9,
|
|
166,
|
|
182,
|
|
42,
|
|
46,
|
|
138,
|
|
230,
|
|
251,
|
|
154,
|
|
25,
|
|
15,
|
|
214,
|
|
209,
|
|
57,
|
|
208,
|
|
31,
|
|
163,
|
|
203,
|
|
87,
|
|
251,
|
|
42,
|
|
144,
|
|
179,
|
|
98,
|
|
92,
|
|
193,
|
|
71,
|
|
]),
|
|
);
|
|
resolve(true);
|
|
},
|
|
);
|
|
|
|
await promise;
|
|
});
|
|
|
|
Deno.test("scryptSync works correctly", () => {
|
|
const key = scryptSync("password", "salt", 32);
|
|
assertEquals(
|
|
key,
|
|
Buffer.from([
|
|
116,
|
|
87,
|
|
49,
|
|
175,
|
|
68,
|
|
132,
|
|
243,
|
|
35,
|
|
150,
|
|
137,
|
|
105,
|
|
237,
|
|
162,
|
|
137,
|
|
174,
|
|
238,
|
|
0,
|
|
91,
|
|
89,
|
|
3,
|
|
172,
|
|
86,
|
|
30,
|
|
100,
|
|
165,
|
|
172,
|
|
161,
|
|
33,
|
|
121,
|
|
123,
|
|
247,
|
|
115,
|
|
]),
|
|
);
|
|
});
|
|
|
|
Deno.test("scryptSync with options works correctly", () => {
|
|
const key = scryptSync("password", "salt", 32, { N: 512 });
|
|
assertEquals(
|
|
key,
|
|
Buffer.from([
|
|
57,
|
|
134,
|
|
165,
|
|
72,
|
|
236,
|
|
9,
|
|
166,
|
|
182,
|
|
42,
|
|
46,
|
|
138,
|
|
230,
|
|
251,
|
|
154,
|
|
25,
|
|
15,
|
|
214,
|
|
209,
|
|
57,
|
|
208,
|
|
31,
|
|
163,
|
|
203,
|
|
87,
|
|
251,
|
|
42,
|
|
144,
|
|
179,
|
|
98,
|
|
92,
|
|
193,
|
|
71,
|
|
]),
|
|
);
|
|
});
|