src/context/AuthContext.js (view raw)
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 |
"use client"; import { createContext, useContext, useState, useEffect } from "react"; import { useRouter } from "next/navigation"; const AuthContext = createContext({}); export function AuthProvider({ children }) { const [user, setUser] = useState(null); const [isLoading, setIsLoading] = useState(true); const router = useRouter(); // Function to fetch user data using the token const fetchUserData = async (token) => { try { const response = await fetch("http://localhost:8080/auth/me", { headers: { Authorization: `Bearer ${token}`, }, }); if (!response.ok) { throw new Error("Failed to fetch user data" + response.statusText); } const userData = await response.json(); setUser(userData); return userData; } catch (error) { console.error("Error fetching user data:", error); localStorage.removeItem("token"); setUser(null); router.push("/login"); } }; // Check for token and fetch user data on initial load useEffect(() => { const token = localStorage.getItem("token"); if (token) { fetchUserData(token).finally(() => setIsLoading(false)); } else { setIsLoading(false); } }, []); const login = async (userData, token) => { setUser(userData); localStorage.setItem("token", token); }; const logout = () => { setUser(null); localStorage.removeItem("token"); router.push("/login"); }; return ( <AuthContext.Provider value={{ user, login, logout, isLoading }}> {children} </AuthContext.Provider> ); } export const useAuth = () => useContext(AuthContext); |