Logout correctly

This commit is contained in:
2025-10-06 20:17:46 +02:00
parent 3fbd333385
commit ed608ba281
3 changed files with 7 additions and 15 deletions

View File

@@ -4,7 +4,7 @@ import Credentials from 'next-auth/providers/credentials';
import { z } from 'zod'; import { z } from 'zod';
import { authConfig } from './auth.config'; import { authConfig } from './auth.config';
export const { auth, signIn } = NextAuth({ export const { auth, signIn, signOut } = NextAuth({
...authConfig, ...authConfig,
providers: [ providers: [
Credentials({ Credentials({

View File

@@ -1,7 +1,7 @@
'use client'; 'use client';
import logo from '@/assets/logo_text.png'; import logo from '@/assets/logo_text.png';
import { logout } from '@/lib/actions'; import { performLogout } from '@/lib/actions';
import { getAuthStatus } from '@/lib/auth-utils'; import { getAuthStatus } from '@/lib/auth-utils';
import styles from '@/styles/Header.module.scss'; import styles from '@/styles/Header.module.scss';
import { faInstagram } from '@fortawesome/free-brands-svg-icons'; import { faInstagram } from '@fortawesome/free-brands-svg-icons';
@@ -41,8 +41,7 @@ export default function Header() {
{isAuth ? ( {isAuth ? (
<p <p
onClick={async () => { onClick={async () => {
await logout(); performLogout();
window.location.reload();
}} }}
className={`${styles.navLink}`}> className={`${styles.navLink}`}>
Logout Logout

View File

@@ -1,8 +1,7 @@
'use server'; 'use server';
import { signIn } from '@/auth'; import { signIn, signOut } from '@/auth';
import { AuthError } from 'next-auth'; import { AuthError } from 'next-auth';
import { cookies } from 'next/headers';
import { redirect } from 'next/navigation'; import { redirect } from 'next/navigation';
export async function authenticate(_prevState: string | undefined, formData: FormData): Promise<string> { export async function authenticate(_prevState: string | undefined, formData: FormData): Promise<string> {
@@ -30,13 +29,7 @@ export async function authenticate(_prevState: string | undefined, formData: For
} }
} }
export async function logout() { export async function performLogout() {
const c = await cookies(); await signOut({ redirectTo: '/', redirect: true });
redirect('/');
c.delete('authjs.session-token');
c.delete('authjs.csrf-token');
c.delete('authjs.callback-url');
c.delete('__Host-authjs.csrf-token');
c.delete('__Secure-authjs.callback-url');
c.delete('__Secure-authjs.session-token');
} }