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
30 lines
715 B
TypeScript
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
|
|
}
|