55 lines
1.1 KiB
TypeScript
55 lines
1.1 KiB
TypeScript
import { create } from 'zustand';
|
|
import { persist } from 'zustand/middleware';
|
|
import { getMe, logout as apiLogout } from '../services/authService';
|
|
|
|
export interface UserResponse {
|
|
id: string;
|
|
username: string;
|
|
email: string;
|
|
avatar_url: string | null;
|
|
is_admin: boolean;
|
|
created_at: string;
|
|
}
|
|
|
|
interface AuthState {
|
|
user: UserResponse | null;
|
|
isLoading: boolean;
|
|
checkSession: () => Promise<void>;
|
|
setUser: (user: UserResponse | null) => void;
|
|
logout: () => Promise<void>;
|
|
}
|
|
|
|
export const useAuthStore = create<AuthState>()(
|
|
persist(
|
|
(set) => ({
|
|
user: null,
|
|
isLoading: false,
|
|
|
|
checkSession: async () => {
|
|
set({ isLoading: true });
|
|
try {
|
|
const user = await getMe();
|
|
set({ user, isLoading: false });
|
|
} catch {
|
|
set({ user: null, isLoading: false });
|
|
}
|
|
},
|
|
|
|
setUser: (user) => set({ user }),
|
|
|
|
logout: async () => {
|
|
try {
|
|
await apiLogout();
|
|
} catch {
|
|
// ignore
|
|
}
|
|
set({ user: null });
|
|
},
|
|
}),
|
|
{
|
|
name: 'auth-store',
|
|
partialize: (state) => ({ user: state.user }),
|
|
}
|
|
)
|
|
);
|