Files
web/packages/trpc/lib/utils/session.ts
Joakim Jäderberg daf765f3d5 Merged in feature/wrap-logging (pull request #2511)
Feature/wrap logging

* feat: change all logging to go through our own logger function so that we can control log levels

* move packages/trpc to using our own logger

* merge


Approved-by: Linus Flood
2025-07-03 12:37:04 +00:00

30 lines
715 B
TypeScript

import "server-only"
import { createLogger } from "@scandic-hotels/common/logger/createLogger"
import type { Session } from "next-auth"
export function isValidSession(session: Session | null): session is Session {
const sessionLogger = createLogger("session")
if (!session) {
return false
}
if (session.error) {
sessionLogger.error(`Session error: ${session.error}`)
return false
}
const token = session.token
if (token?.error) {
sessionLogger.error(`Session token error: ${token.error}`)
return false
}
if (token?.expires_at && token.expires_at < Date.now()) {
sessionLogger.debug(`Session expired: ${session.token.expires_at}`)
return false
}
return true
}