Scrum4Me/patterns/iron-session.md
Janpeter Visser fd72fd85f8
Document iron-session pattern and usage
Add documentation for iron-session pattern including session options and usage in server actions.
2026-04-24 22:08:27 +02:00

808 B

Patroon: iron-session

lib/session.ts

import { SessionOptions } from 'iron-session'

export interface SessionData {
  userId: string
  isDemo: boolean
}

export const sessionOptions: SessionOptions = {
  password: process.env.SESSION_SECRET!,
  cookieName: 'scrum4me-session',
  cookieOptions: {
    secure: process.env.NODE_ENV === 'production',
    httpOnly: true,
    sameSite: 'lax',
  },
}

Gebruik in Server Action of Route Handler

import { getIronSession } from 'iron-session'
import { cookies } from 'next/headers'
import { SessionData, sessionOptions } from '@/lib/session'

const session = await getIronSession<SessionData>(await cookies(), sessionOptions)
if (!session.userId) redirect('/login')
if (session.isDemo) return { error: 'Niet beschikbaar in demo-modus' }