refactor: ♻️ rewrite cookie and session lifecycle to remove _INSTANCE
cookie
This commit is contained in:
parent
eb13af1ac8
commit
7ea95c67c4
|
@ -2,8 +2,6 @@ import { FreshContext } from '$fresh/server.ts'
|
||||||
import { getCookies, setCookie } from '@std/http/cookie'
|
import { getCookies, setCookie } from '@std/http/cookie'
|
||||||
import { SessionStore } from '../src/session/mod.ts'
|
import { SessionStore } from '../src/session/mod.ts'
|
||||||
|
|
||||||
const instanceToken = crypto.randomUUID() // Instance uuid to reset perform cookie reset on server restart
|
|
||||||
|
|
||||||
export async function handler(request: Request, ctx: FreshContext) {
|
export async function handler(request: Request, ctx: FreshContext) {
|
||||||
// Allow service worker to serve root scope
|
// Allow service worker to serve root scope
|
||||||
const response = await ctx.next()
|
const response = await ctx.next()
|
||||||
|
@ -14,8 +12,9 @@ export async function handler(request: Request, ctx: FreshContext) {
|
||||||
|
|
||||||
const cookies = getCookies(request.headers)
|
const cookies = getCookies(request.headers)
|
||||||
|
|
||||||
// Clear outdated cookies
|
// Start session
|
||||||
if (cookies['_INSTANCE'] !== instanceToken) {
|
if (SessionStore.getSession(cookies['_SESSION'] ?? '') === undefined) {
|
||||||
|
// Clear outdated cookies
|
||||||
for (const cookie in cookies) {
|
for (const cookie in cookies) {
|
||||||
setCookie(response.headers, {
|
setCookie(response.headers, {
|
||||||
name: cookie,
|
name: cookie,
|
||||||
|
@ -24,19 +23,8 @@ export async function handler(request: Request, ctx: FreshContext) {
|
||||||
expires: 0,
|
expires: 0,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
setCookie(response.headers, {
|
|
||||||
name: '_INSTANCE',
|
|
||||||
value: instanceToken,
|
|
||||||
httpOnly: true,
|
|
||||||
sameSite: 'Strict',
|
|
||||||
secure: true,
|
|
||||||
path: '/',
|
|
||||||
expires: 1000 * 2 ** 38, // Never expire
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Start session
|
// Create new session
|
||||||
if (cookies['_SESSION'] === undefined || cookies['_SESSION'] === '') {
|
|
||||||
const session = SessionStore.createSession()
|
const session = SessionStore.createSession()
|
||||||
|
|
||||||
// Set session cookie
|
// Set session cookie
|
||||||
|
|
Loading…
Reference in a new issue