mirror of
https://github.com/LucasVbr/meeting-app.git
synced 2026-05-13 17:21:53 +00:00
Fix hash password
Took 30 minutes
This commit is contained in:
@@ -25,18 +25,16 @@ export default function RegisterForm() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const handleSubmit = () => {
|
const handleSubmit = () => {
|
||||||
const {password, confirmPassword} = registerData;
|
let {email, firstName, lastName, password, confirmPassword} = registerData;
|
||||||
if (password !== confirmPassword) setInvalidInput(true);
|
if (password !== confirmPassword) setInvalidInput(true);
|
||||||
|
|
||||||
fetch('/api/user', {
|
fetch('/api/user', {
|
||||||
method: 'PUT',
|
method: 'PUT',
|
||||||
headers: {'Content-Type': 'application/json'},
|
headers: {'Content-Type': 'application/json'},
|
||||||
body: JSON.stringify(registerData),
|
body: JSON.stringify({email, firstName, lastName, password}),
|
||||||
}).then(() => {
|
}).then(() => {
|
||||||
const {email, password} = registerData;
|
signIn('credentials', {email, password, redirect: false})
|
||||||
|
.then((res) => {
|
||||||
signIn('credentials',
|
|
||||||
{email, password, redirect: false}).then((res) => {
|
|
||||||
const {ok: connexionSuccess} = res as SignInResponse;
|
const {ok: connexionSuccess} = res as SignInResponse;
|
||||||
|
|
||||||
// TODO If success -> goto interactive form else login
|
// TODO If success -> goto interactive form else login
|
||||||
|
|||||||
@@ -0,0 +1,13 @@
|
|||||||
|
import bcrypt from "bcrypt";
|
||||||
|
|
||||||
|
export async function hashPassword(unHashedPassword: string): Promise<string> {
|
||||||
|
return await bcrypt.hash(unHashedPassword, 10).then((hash: string) => hash);
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function isSamePassword(
|
||||||
|
unHashedPassword: string,
|
||||||
|
hashedPassword: string
|
||||||
|
): Promise<boolean> {
|
||||||
|
return await bcrypt.compare(unHashedPassword, hashedPassword).
|
||||||
|
then((result: boolean) => result);
|
||||||
|
}
|
||||||
@@ -3,6 +3,7 @@ import CredentialsProvider from "next-auth/providers/credentials";
|
|||||||
import {PrismaClient} from '@prisma/client';
|
import {PrismaClient} from '@prisma/client';
|
||||||
import {NextApiRequest, NextApiResponse} from 'next';
|
import {NextApiRequest, NextApiResponse} from 'next';
|
||||||
import {LoginData} from '@/models/form/LoginData';
|
import {LoginData} from '@/models/form/LoginData';
|
||||||
|
import {isSamePassword} from '@/lib/PasswordTools';
|
||||||
|
|
||||||
const prisma = new PrismaClient();
|
const prisma = new PrismaClient();
|
||||||
|
|
||||||
@@ -24,7 +25,10 @@ export default async function auth(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
});
|
});
|
||||||
|
|
||||||
// Vérification de la connexion
|
// Vérification de la connexion
|
||||||
if (user && user.password === password) return user;
|
if (user && await isSamePassword(password, user.password)) {
|
||||||
|
return user;
|
||||||
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -2,6 +2,9 @@ import type {NextApiRequest, NextApiResponse} from 'next';
|
|||||||
import CRUD from '@/utils/CRUD';
|
import CRUD from '@/utils/CRUD';
|
||||||
import {CreateUserQuery} from '@/models/api/user';
|
import {CreateUserQuery} from '@/models/api/user';
|
||||||
import {PrismaClient} from '@prisma/client';
|
import {PrismaClient} from '@prisma/client';
|
||||||
|
import {LoginData} from '@/models/form/LoginData';
|
||||||
|
import {RegisterData} from '@/models/form/RegisterData';
|
||||||
|
import {hashPassword} from '@/lib/PasswordTools';
|
||||||
|
|
||||||
export default function handler(
|
export default function handler(
|
||||||
req: NextApiRequest,
|
req: NextApiRequest,
|
||||||
@@ -10,7 +13,6 @@ export default function handler(
|
|||||||
switch (req.method) {
|
switch (req.method) {
|
||||||
case CRUD.CREATE: return createUser(req, res);
|
case CRUD.CREATE: return createUser(req, res);
|
||||||
case CRUD.READ: return readUser(req, res);
|
case CRUD.READ: return readUser(req, res);
|
||||||
// case CRUD.DELETE: return deleteUser(req, res);
|
|
||||||
default: return help(res);
|
default: return help(res);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -27,8 +29,10 @@ async function createUser(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
if (!email || !password || !firstName || !lastName)
|
if (!email || !password || !firstName || !lastName)
|
||||||
return res.status(400).send({message: req.body});
|
return res.status(400).send({message: req.body});
|
||||||
|
|
||||||
|
const hashedPassword = await hashPassword(password)
|
||||||
|
|
||||||
const newUser = await prisma.user.create({
|
const newUser = await prisma.user.create({
|
||||||
data: {...req.body},
|
data: {...req.body, password: hashedPassword},
|
||||||
});
|
});
|
||||||
|
|
||||||
return res.status(201).send({message: 'createUser', newUser});
|
return res.status(201).send({message: 'createUser', newUser});
|
||||||
@@ -36,7 +40,7 @@ async function createUser(req: NextApiRequest, res: NextApiResponse) {
|
|||||||
|
|
||||||
async function readUser(req: NextApiRequest, res: NextApiResponse) {
|
async function readUser(req: NextApiRequest, res: NextApiResponse) {
|
||||||
const {id} = req.query as {id: string}
|
const {id} = req.query as {id: string}
|
||||||
|
|
||||||
const user = (req.query.id)
|
const user = (req.query.id)
|
||||||
? await prisma.user.findUnique({where: {id}})
|
? await prisma.user.findUnique({where: {id}})
|
||||||
: await prisma.user.findMany()
|
: await prisma.user.findMany()
|
||||||
|
|||||||
Reference in New Issue
Block a user