Files
lcbp3/frontend/components/auth/auth-sync.tsx
T
admin bf5c67fc7e
CI / CD Pipeline / build (push) Successful in 15m34s
CI / CD Pipeline / deploy (push) Successful in 6m11s
690331:1616 Correspondence Page Refactor by GPT-5.3-Codex Medium #03
2026-03-31 16:16:12 +07:00

52 lines
1.6 KiB
TypeScript

'use client';
import { useSession, signOut } from 'next-auth/react';
import { useEffect } from 'react';
import { useAuthStore } from '@/lib/stores/auth-store';
import { clearAuthTokenCache } from '@/lib/api/client';
export function AuthSync() {
const { data: session, status } = useSession();
const { setAuth, logout } = useAuthStore();
useEffect(() => {
if (session?.error === 'RefreshAccessTokenError') {
clearAuthTokenCache(); // Clear cached token on auth error
signOut({ callbackUrl: '/login' });
} else if (status === 'authenticated' && session?.user) {
// Map NextAuth session to AuthStore user
// Assuming session.user has the fields we need based on types/next-auth.d.ts
// Map NextAuth session user to AuthStore user type
const user = session.user as {
id?: string;
user_id?: string;
username?: string;
email?: string;
firstName?: string;
lastName?: string;
role?: string;
permissions?: string[];
};
setAuth(
{
id: user.id || user.user_id || '',
username: user.username || '',
email: user.email || '',
firstName: user.firstName || '',
lastName: user.lastName || '',
role: user.role || 'User',
permissions: user.permissions,
},
(session as { accessToken?: string }).accessToken || ''
);
} else if (status === 'unauthenticated') {
clearAuthTokenCache(); // Clear cached token on logout
logout();
}
}, [session, status, setAuth, logout]);
return null; // This component renders nothing
}