Skip to content

Commit

Permalink
Merge: 로그인 통신 (#37)
Browse files Browse the repository at this point in the history
  • Loading branch information
future9061 authored Feb 15, 2024
2 parents 58a8b5d + d6c3ab8 commit 61950eb
Show file tree
Hide file tree
Showing 17 changed files with 121 additions and 112 deletions.
22 changes: 0 additions & 22 deletions frontend/build/asset-manifest.json

This file was deleted.

Binary file removed frontend/build/favicon.ico
Binary file not shown.
1 change: 0 additions & 1 deletion frontend/build/index.html

This file was deleted.

Binary file removed frontend/build/logo192.png
Binary file not shown.
Binary file removed frontend/build/logo512.png
Binary file not shown.
54 changes: 0 additions & 54 deletions frontend/build/manifest.json

This file was deleted.

3 changes: 0 additions & 3 deletions frontend/build/robots.txt

This file was deleted.

7 changes: 6 additions & 1 deletion frontend/src/apis/BaseUrl.ts
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
import axios from 'axios';

export default axios.create({ baseURL: 'https://api.doit-toeic.xyz' });
export default axios.create({
baseURL: 'https://api.doit-toeic.xyz',
headers: {
'Content-Type': 'application/json',
},
});
19 changes: 0 additions & 19 deletions frontend/src/apis/FetchRegister.ts

This file was deleted.

81 changes: 81 additions & 0 deletions frontend/src/apis/auth/FetchLogIn.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
import { LoginData } from '../../types/LoginData';
import axios, { AxiosError, AxiosResponse } from 'axios';

export const httpClientForCredentials = axios.create({});

httpClientForCredentials.defaults.baseURL = 'https://api.doit-toeic.xyz';
httpClientForCredentials.defaults.withCredentials = true;

httpClientForCredentials.interceptors.response.use(
(response) => {
return response;
},

async (error) => {
const {
config,
response: { status },
} = error;

if (status === 401) {
if (error.response.data.message === 'Unauthorized') {
const originRequest = config;
try {
const response = await FetchRefreshToken();

if (response.status === 200) {
const newAccessToken = await response.data.data.accessToken;

httpClientForCredentials.defaults.headers.common.Authorization = `Bearer ${newAccessToken}`;
originRequest.headers.Authorization = `Bearer ${newAccessToken}`;

return axios(originRequest);
}
} catch (error) {
window.location.replace('/login');
alert('로그인해주세요');
}
}
}
return Promise.reject(error);
},
);

export const FetchRefreshToken = async () => {
try {
const response = await httpClientForCredentials.get('/auth/refresh');
return response;
} catch (error) {
const axiosError = error as AxiosError;
if (axiosError.response?.status === 401) {
alert('로그인 해주세요');
window.location.replace('/login');
}
throw error;
}
};

export const onLogInSuccess = async (response: AxiosResponse) => {
try {
const { accessToken } = await response.data.data;

httpClientForCredentials.defaults.headers.common['Authorization'] =
`Bearer ${accessToken}`;
} catch (error) {
console.log('onLogInSuccess 실패', error);
throw error;
}
};

export const FetchLogIn = async (data: LoginData) => {
try {
const response = await httpClientForCredentials.post('/auth/login', data);

if (response.status === 200) {
onLogInSuccess(response);
}
} catch (error) {
console.log('FetchLogIn 실패');
throw error;
}
};
16 changes: 16 additions & 0 deletions frontend/src/apis/auth/FetchRegister.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
import { RegisterData } from '../../types/RegisterData';
import url from '../BaseUrl';

export const FetchRegister = async (register: RegisterData) => {
const data = { email: register.email, password: register.password };

try {
const res = await url.post('/auth/register', data);
if (res.status === 201) {
alert('회원가입이 완료되었습니다.이메일을 확인해주세요!!');
}
} catch (error) {
alert('회원가입이 실패하였습니다.');
throw new Error();
}
};
2 changes: 1 addition & 1 deletion frontend/src/components/common/Button.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import React from 'react';
import { ButtonCSS } from '../../style/components/common/ButtonCSS';
import { useNavigate } from 'react-router-dom';
import { ButtonProps } from '../../types/ButtonPtops';
import { ButtonProps } from '../../types/ButtonProps';

function Button({
children,
Expand Down
20 changes: 13 additions & 7 deletions frontend/src/components/login/LoginForm.tsx
Original file line number Diff line number Diff line change
@@ -1,37 +1,43 @@
import React from 'react';
import { LoginFormCSS } from '../../style/components/login/LoginFormCSS';
import { SubmitHandler, useForm } from 'react-hook-form';
import { FormData } from '../../types/LoginData';
import { LoginData } from '../../types/LoginData';
import SubmitBtn from '../common/SubmitBtn';
import { FetchLogIn } from '../../apis/auth/FetchLogIn';
import { useNavigate } from 'react-router-dom';

function LoginForm() {
const navigate = useNavigate();

const {
register,
handleSubmit,
formState: { errors },
} = useForm<FormData>();
} = useForm<LoginData>();

const onSubmit: SubmitHandler<FormData> = (data) => {
console.log(data);
const onsubmit: SubmitHandler<LoginData> = async (data) => {
await FetchLogIn(data);
navigate('/main');
};

return (
<>
<LoginFormCSS onSubmit={handleSubmit(onSubmit)}>
<LoginFormCSS onSubmit={handleSubmit(onsubmit)}>
<fieldset>
<label>ID</label>
<input
id="id"
spellCheck={false}
{...register('username', { required: true })}
{...register('email', { required: true })}
/>
</fieldset>
{errors.username && <span>아이디를 작성해주세요!</span>}
{errors.email && <span>아이디를 작성해주세요!</span>}

<fieldset>
<label>PW</label>
<input
id="password"
type="password"
spellCheck={false}
{...register('password', { required: true })}
/>
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/components/register/RegisterForm.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import { SubmitHandler, useForm } from 'react-hook-form';
import { RegisterData } from '../../types/RegisterData';
import Agreement from './Agreement';
import SubmitBtn from '../common/SubmitBtn';
import { FetchRegister } from '../../apis/FetchRegister';
import { FetchRegister } from '../../apis/auth/FetchRegister';
import { useNavigate } from 'react-router-dom';

function RegisterForm() {
Expand Down
2 changes: 1 addition & 1 deletion frontend/src/style/components/common/ButtonCSS.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import styled from 'styled-components';
import { ButtonProps } from '../../../types/ButtonPtops';
import { ButtonProps } from '../../../types/ButtonProps';
import { media } from '../../mediaQuery';

export const ButtonCSS = styled.button<ButtonProps>`
Expand Down
File renamed without changes.
4 changes: 2 additions & 2 deletions frontend/src/types/LoginData.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
export type FormData = {
username: string;
export type LoginData = {
email: string;
password: string;
};

0 comments on commit 61950eb

Please sign in to comment.