Handle website delete. Added response helper functions.

This commit is contained in:
Mike Cao 2020-08-07 17:19:42 -07:00
parent 0a411a9ad6
commit c4b75e4aec
31 changed files with 314 additions and 96 deletions

View file

@ -1,9 +1,8 @@
import crypto from 'crypto';
import { v5 } from 'uuid';
import { v4, v5, validate } from 'uuid';
import bcrypt from 'bcrypt';
import { JWT, JWE, JWK } from 'jose';
const UUID_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-5][0-9a-f]{3}-[089ab][0-9a-f]{3}-[0-9a-f]{12}$/;
const KEY = JWK.asKey(Buffer.from(secret()));
export function hash(...args) {
@ -15,11 +14,13 @@ export function secret() {
}
export function uuid(...args) {
if (!args.length) return v4();
return v5(args.join(''), v5(process.env.HASH_SALT, v5.DNS));
}
export function isValidId(s) {
return UUID_REGEX.test(s);
return validate(s);
}
export function checkPassword(password, hash) {
@ -30,15 +31,24 @@ export async function createToken(payload) {
return JWT.sign(payload, KEY);
}
export async function verifyToken(token) {
return JWT.verify(token, KEY);
export async function parseToken(token) {
try {
return JWT.verify(token, KEY);
} catch {
return null;
}
}
export async function createSecureToken(payload) {
return JWE.encrypt(await createToken(payload), KEY);
}
export async function verifySecureToken(token) {
const result = await JWE.decrypt(token, KEY);
return verifyToken(result.toString());
export async function parseSecureToken(token) {
try {
const result = await JWE.decrypt(token, KEY);
return parseToken(result.toString());
} catch {
return null;
}
}