fosrl.pangolin/server/index.ts

101 lines
2.7 KiB
TypeScript
Raw Normal View History

2024-10-12 21:23:12 -04:00
import config from "@server/config";
2024-09-27 21:39:03 -04:00
import express, { Request, Response } from "express";
import next from "next";
import { parse } from "url";
2024-09-27 21:49:52 -04:00
import logger from "@server/logger";
2024-09-27 21:39:03 -04:00
import helmet from "helmet";
import cors from "cors";
import {
errorHandlerMiddleware,
2024-10-06 12:39:05 -04:00
notFoundMiddleware,
rateLimitMiddleware,
} from "@server/middlewares";
2024-09-28 12:56:36 -04:00
import internal from "@server/routers/internal";
import { authenticated, unauthenticated } from "@server/routers/external";
import cookieParser from "cookie-parser";
2024-10-03 20:55:54 -04:00
import { User } from "@server/db/schema";
2024-10-10 21:59:30 -04:00
import { ensureActions } from "./db/ensureActions";
2024-09-27 21:39:03 -04:00
2024-10-21 23:40:49 -04:00
const dev = process.env.ENVIRONMENT !== "prod";
2024-09-27 21:39:03 -04:00
const app = next({ dev });
const handle = app.getRequestHandler();
2024-10-12 18:21:31 -04:00
const externalPort = config.server.external_port;
const internalPort = config.server.internal_port;
app.prepare().then(() => {
2024-09-28 11:59:13 -04:00
2024-10-10 21:59:30 -04:00
ensureActions(); // This loads the actions into the database
// External server
const externalServer = express();
2024-10-06 22:09:30 -04:00
externalServer.set("trust proxy", 1);
2024-10-06 11:13:50 -04:00
// externalServer.use(helmet()); // Disabled because causes issues with Next.js
externalServer.use(cors());
externalServer.use(cookieParser());
externalServer.use(express.json());
2024-10-19 18:47:41 -04:00
if (!dev) {
externalServer.use(
rateLimitMiddleware({
windowMin: 1,
max: 100,
type: "IP_ONLY",
}),
);
}
2024-09-27 21:39:03 -04:00
2024-09-29 14:37:26 -04:00
const prefix = `/api/v1`;
externalServer.use(prefix, unauthenticated);
externalServer.use(prefix, authenticated);
2024-09-28 12:42:38 -04:00
2024-10-06 12:39:05 -04:00
externalServer.use(notFoundMiddleware)
2024-09-28 12:42:38 -04:00
// We are using NEXT from here on
externalServer.all("*", (req: Request, res: Response) => {
2024-09-27 21:39:03 -04:00
const parsedUrl = parse(req.url!, true);
handle(req, res, parsedUrl);
});
externalServer.listen(externalPort, (err?: any) => {
2024-09-28 12:56:36 -04:00
if (err) throw err;
logger.info(
`Main server is running on http://localhost:${externalPort}`,
);
2024-09-28 12:56:36 -04:00
});
externalServer.use(errorHandlerMiddleware);
2024-10-01 20:48:03 -04:00
2024-09-28 12:56:36 -04:00
// Internal server
const internalServer = express();
2024-09-28 12:56:36 -04:00
internalServer.use(helmet());
internalServer.use(cors());
internalServer.use(cookieParser());
internalServer.use(express.json());
2024-09-28 12:56:36 -04:00
internalServer.use(prefix, internal);
2024-09-28 12:56:36 -04:00
internalServer.listen(internalPort, (err?: any) => {
if (err) throw err;
2024-09-28 13:40:24 -04:00
logger.info(
`Internal server is running on http://localhost:${internalPort}`,
);
2024-09-27 21:39:03 -04:00
});
internalServer.use(notFoundMiddleware)
internalServer.use(errorHandlerMiddleware);
2024-09-27 21:39:03 -04:00
});
2024-10-03 20:55:54 -04:00
declare global {
namespace Express {
interface Request {
user?: User;
userOrgRoleId?: number;
2024-10-14 15:11:18 -04:00
userOrgId?: string;
userOrgIds?: string[];
2024-10-03 20:55:54 -04:00
}
}
}