UNPKG

better-auth

Version:

The most comprehensive authentication framework for TypeScript.

36 lines (34 loc) 1.12 kB
import { constantTimeEqual } from "./buffer.mjs"; import { BetterAuthError } from "@better-auth/core/error"; import { hex } from "@better-auth/utils/hex"; import { scryptAsync } from "@noble/hashes/scrypt.js"; import { hexToBytes } from "@noble/hashes/utils.js"; //#region src/crypto/password.ts const config = { N: 16384, r: 16, p: 1, dkLen: 64 }; async function generateKey(password, salt) { return await scryptAsync(password.normalize("NFKC"), salt, { N: config.N, p: config.p, r: config.r, dkLen: config.dkLen, maxmem: 128 * config.N * config.r * 2 }); } const hashPassword = async (password) => { const salt = hex.encode(crypto.getRandomValues(new Uint8Array(16))); const key = await generateKey(password, salt); return `${salt}:${hex.encode(key)}`; }; const verifyPassword = async ({ hash, password }) => { const [salt, key] = hash.split(":"); if (!salt || !key) throw new BetterAuthError("Invalid password hash"); return constantTimeEqual(await generateKey(password, salt), hexToBytes(key)); }; //#endregion export { hashPassword, verifyPassword }; //# sourceMappingURL=password.mjs.map