4466ba436b
## Description This PR ensures that the default prettier config is used for examples and templates. This config is compatible with `prettier@3` as well (upgrading prettier is bigger change that can be a future PR). ## Changes - Updated `.prettierrc.json` in root with `"trailingComma": "es5"` (will be needed upgrading to prettier@3) - Added `examples/.prettierrc.json` with default config (this will change every example) - Added `packages/create-next-app/templates/.prettierrc.json` with default config (this will change every template) ## Related - Fixes #54402 - Closes #54409
46 lines
1.5 KiB
JavaScript
46 lines
1.5 KiB
JavaScript
import crypto from "crypto";
|
|
import { v4 as uuidv4 } from "uuid";
|
|
|
|
/**
|
|
* User methods. The example doesn't contain a DB, but for real applications you must use a
|
|
* db here, such as MongoDB, Fauna, SQL, etc.
|
|
*/
|
|
|
|
const users = [];
|
|
|
|
export async function createUser({ username, password }) {
|
|
// Here you should create the user and save the salt and hashed password (some dbs may have
|
|
// authentication methods that will do it for you so you don't have to worry about it):
|
|
const salt = crypto.randomBytes(16).toString("hex");
|
|
const hash = crypto
|
|
.pbkdf2Sync(password, salt, 1000, 64, "sha512")
|
|
.toString("hex");
|
|
const user = {
|
|
id: uuidv4(),
|
|
createdAt: Date.now(),
|
|
username,
|
|
hash,
|
|
salt,
|
|
};
|
|
|
|
// This is an in memory store for users, there is no data persistence without a proper DB
|
|
users.push(user);
|
|
|
|
return { username, createdAt: Date.now() };
|
|
}
|
|
|
|
// Here you should lookup for the user in your DB
|
|
export async function findUser({ username }) {
|
|
// This is an in memory store for users, there is no data persistence without a proper DB
|
|
return users.find((user) => user.username === username);
|
|
}
|
|
|
|
// Compare the password of an already fetched user (using `findUser`) and compare the
|
|
// password for a potential match
|
|
export function validatePassword(user, inputPassword) {
|
|
const inputHash = crypto
|
|
.pbkdf2Sync(inputPassword, user.salt, 1000, 64, "sha512")
|
|
.toString("hex");
|
|
const passwordsMatch = user.hash === inputHash;
|
|
return passwordsMatch;
|
|
}
|