fix cache auth method

This commit is contained in:
Alec Armbruster 2023-06-30 09:42:09 -04:00
parent b6415f828e
commit da45ffb46b
No known key found for this signature in database
GPG key ID: 52BC7C84E960FD1B
2 changed files with 27 additions and 11 deletions

View file

@ -1,5 +1,5 @@
import type { NextFunction, Request, Response } from "express";
import { UserService } from "../shared/services";
import { isRequestAuthenticated } from "./utils/is-request-authenticated";
export function setDefaultCsp({
res,
@ -22,23 +22,30 @@ export function setDefaultCsp({
// interval is rather arbitrary and could be set higher (less server load) or lower (fresher data).
//
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Cache-Control
export function setCacheControl(
req: Request,
res: Response,
next: NextFunction
) {
const user = UserService.Instance;
export function setCacheControl({
res,
req,
next,
}: {
res: Response;
req: Request;
next: NextFunction;
}) {
let caching: string;
// Avoid any sort of caching in development
if (process.env.NODE_ENV !== "production") {
return next();
}
if (
process.env.NODE_ENV === "production" &&
(req.path.match(/\.(js|css|txt|manifest\.webmanifest)\/?$/) ||
req.path.includes("/css/themelist"))
req.path.match(/\.(js|css|txt|manifest\.webmanifest)\/?$/) ||
req.path.includes("/css/themelist")
) {
// Static content gets cached publicly for a day
caching = "public, max-age=86400";
} else {
if (user.auth()) {
if (isRequestAuthenticated(req)) {
caching = "private";
} else {
caching = "public, max-age=5";

View file

@ -0,0 +1,9 @@
import type { Request } from "express";
export function isRequestAuthenticated(req: Request): boolean {
if (!req.headers.cookie) {
return false;
}
return req.headers.cookie?.split("; ").some(c => c.startsWith("jwt"));
}