sendou.ink/app/features/auth/core/session.server.ts

22 lines
715 B
TypeScript

import { createCookieSessionStorage } from "@remix-run/node";
import invariant from "~/utils/invariant";
const ONE_YEAR_IN_SECONDS = 31_536_000;
if (process.env.NODE_ENV === "production") {
invariant(process.env["SESSION_SECRET"], "SESSION_SECRET is required");
}
export const authSessionStorage = createCookieSessionStorage({
cookie: {
name: "__session",
sameSite: "lax",
// need to specify domain so that sub-domains can access it
domain: process.env.NODE_ENV === "production" ? "sendou.ink" : undefined,
path: "/",
httpOnly: true,
secrets: [process.env["SESSION_SECRET"] ?? "secret"],
secure: process.env.NODE_ENV === "production",
maxAge: ONE_YEAR_IN_SECONDS,
},
});