From 878975bc065ed07203cc961762aad6ef846044ad Mon Sep 17 00:00:00 2001 From: Zeyad Date: Wed, 27 Nov 2024 13:02:25 +0200 Subject: [PATCH 1/2] Add signup authentication --- src/api/Signup/signup-auth.ts | 20 ++++++++++++++++++++ src/components/signup/SignupForm.tsx | 20 ++++++++++++++++++-- 2 files changed, 38 insertions(+), 2 deletions(-) create mode 100644 src/api/Signup/signup-auth.ts diff --git a/src/api/Signup/signup-auth.ts b/src/api/Signup/signup-auth.ts new file mode 100644 index 0000000..9f9fd3d --- /dev/null +++ b/src/api/Signup/signup-auth.ts @@ -0,0 +1,20 @@ +import axios from 'axios'; + +const signupAxios = axios.create({ + baseURL: 'http://localhost:8080', +}); + +signupAxios.interceptors.request.use( + (config) => { + const token = localStorage.getItem('jwt'); + if (token) { + config.headers.Authorization = `Bearer ${token}`; + } + return config; + }, + (error) => { + return Promise.reject(error); + } +); + +export default signupAxios; diff --git a/src/components/signup/SignupForm.tsx b/src/components/signup/SignupForm.tsx index 180dbec..b070b31 100644 --- a/src/components/signup/SignupForm.tsx +++ b/src/components/signup/SignupForm.tsx @@ -2,14 +2,15 @@ import { Button, Grid, Link, TextField, Typography } from '@mui/material'; import { Box } from '@mui/system'; import { ChangeEvent, FormEvent, useState } from 'react'; import { Link as RouterLink, useParams } from 'react-router-dom'; - +import './auth/signup-auth'; import { green, grey } from '@mui/material/colors'; - +import customAxios from '../../api/Signup/signup-auth'; interface FormData { lastname: string; firstname: string; email: string; password: string; + role: string[]; } interface FormErrors { @@ -17,6 +18,7 @@ interface FormErrors { firstname?: string; email?: string; password?: string; + role?: string[]; } const SignupForm = () => { @@ -28,6 +30,7 @@ const SignupForm = () => { lastname: '', email: '', password: '', + role: [`${userType}`], }); const handleSubmit = (e: FormEvent) => { @@ -35,7 +38,20 @@ const SignupForm = () => { if (validate()) { console.log('Form Submitted: ', formData); console.log(`user type: ${userType}`); + // POST REQUEST FOR THE BACKEND GOES HERE .... + const PostRequest = async () => { + try { + const response = await customAxios.post('/api/auth/register', { + ...formData, + }); + console.log('Signup Successful: ', response.data); + } catch (error) { + console.error('Signup Failed: ', error); + } + }; + PostRequest(); + //-------------------------// } }; From b332c170cc46953330cd6a9acd82d643aa9f3ed5 Mon Sep 17 00:00:00 2001 From: Zeyad Date: Wed, 27 Nov 2024 13:10:53 +0200 Subject: [PATCH 2/2] update signup authentication --- src/components/signup/SignupForm.tsx | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/components/signup/SignupForm.tsx b/src/components/signup/SignupForm.tsx index b070b31..236567c 100644 --- a/src/components/signup/SignupForm.tsx +++ b/src/components/signup/SignupForm.tsx @@ -42,9 +42,13 @@ const SignupForm = () => { // POST REQUEST FOR THE BACKEND GOES HERE .... const PostRequest = async () => { try { - const response = await customAxios.post('/api/auth/register', { - ...formData, - }); + const response = await customAxios.post( + '/api/auth/register', + { + ...formData, + }, + { withCredentials: true } + ); console.log('Signup Successful: ', response.data); } catch (error) { console.error('Signup Failed: ', error);