auth.js
1.25 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
import React, { createContext, useReducer } from "react";
import jwtDecode from "jwt-decode";
const initialState = {
user: null
};
if (localStorage.getItem("jwtToken")) {
const decodedToken = jwtDecode(localStorage.getItem("jwtToken"));
if (decodedToken.exp * 1000 < Date.now()) {
localStorage.removeItem("jwtToken");
} else {
initialState.user = decodedToken;
}
}
const AuthContext = createContext({
user: null,
login: userData => {},
logout: () => {}
});
function authReducer(state, action) {
switch (action.type) {
case "LOGIN":
return {
...state,
user: action.payload
};
case "LOGOUT":
return {
...state,
user: null
};
default:
return state;
}
}
function AuthProvider(props) {
const [state, dispatch] = useReducer(authReducer, initialState);
function login(userData) {
localStorage.setItem("jwtToken", userData.token);
dispatch({
type: "LOGIN",
payload: userData
});
}
function logout() {
localStorage.removeItem("jwtToken");
dispatch({
type: "LOGOUT"
});
}
return (
<AuthContext.Provider
value={{ user: state.user, login, logout }}
{...props}
/>
);
}
export { AuthContext, AuthProvider };