- Checkpoint

Signed-off-by: Dave Richer <dave@imexsystems.ca>
This commit is contained in:
Dave Richer
2024-09-06 11:53:08 -04:00
parent f28068d0e7
commit 44db8f20e9
4 changed files with 98 additions and 47 deletions

View File

@@ -10,6 +10,7 @@ const main = async () => {
const { Server } = require("socket.io");
const { createClient } = require("redis");
const { createAdapter } = require("@socket.io/redis-adapter");
// Load environment variables
require("dotenv").config({
path: path.resolve(process.cwd(), `.env.${process.env.NODE_ENV || "development"}`)
@@ -22,11 +23,21 @@ const main = async () => {
const app = express();
const port = process.env.PORT || 5000;
const server = http.createServer(app);
const pubClient = createClient({ url: "redis://localhost:6379" });
// Redis client setup for Pub/Sub and Key-Value Store
const pubClient = createClient({ url: process.env.REDIS_URL || "redis://localhost:6379" });
const subClient = pubClient.duplicate();
// Clean up on exit
process.on("SIGINT", async () => {
await Promise.all([pubClient.disconnect(), subClient.disconnect()]);
process.exit(0);
});
// Connect Redis clients
await Promise.all([pubClient.connect(), subClient.connect()]);
// Redis Pub/Sub adapter for Socket.IO
const io = new Server(server, {
path: "/ws",
adapter: createAdapter(pubClient, subClient),
@@ -34,30 +45,18 @@ const main = async () => {
origin: [
"https://test.imex.online",
"https://www.test.imex.online",
"http://localhost:3000",
"https://imex.online",
"https://www.imex.online",
"https://romeonline.io",
"https://www.romeonline.io",
"https://beta.test.romeonline.io",
"https://www.beta.test.romeonline.io",
"https://beta.romeonline.io",
"https://www.beta.romeonline.io",
"https://beta.test.imex.online",
"https://www.beta.test.imex.online",
"https://beta.imex.online",
"https://www.beta.imex.online",
"https://www.test.promanager.web-est.com",
"https://test.promanager.web-est.com",
"https://www.promanager.web-est.com",
"https://www.promanager.web-est.com"
"http://localhost"
// Other allowed origins
],
methods: ["GET", "POST"],
credentials: true,
exposedHeaders: ["set-cookie"]
}
});
// Export io and Redis client for external use
exports.io = io;
exports.redisClient = pubClient;
require("./server/web-sockets/web-socket");
@@ -76,23 +75,7 @@ const main = async () => {
// Route groupings
app.use("/", require("./server/routes/miscellaneousRoutes"));
app.use("/notifications", require("./server/routes/notificationsRoutes"));
app.use("/render", require("./server/routes/renderRoutes"));
app.use("/mixdata", require("./server/routes/mixDataRoutes"));
app.use("/accounting", require("./server/routes/accountingRoutes"));
app.use("/qbo", require("./server/routes/qboRoutes"));
app.use("/media", require("./server/routes/mediaRoutes"));
app.use("/sms", require("./server/routes/smsRoutes"));
app.use("/job", require("./server/routes/jobRoutes"));
app.use("/scheduling", require("./server/routes/schedulingRoutes"));
app.use("/utils", require("./server/routes/utilRoutes"));
app.use("/data", require("./server/routes/dataRoutes"));
app.use("/adm", require("./server/routes/adminRoutes"));
app.use("/tech", require("./server/routes/techRoutes"));
app.use("/intellipay", require("./server/routes/intellipayRoutes"));
app.use("/cdk", require("./server/routes/cdkRoutes"));
app.use("/csi", require("./server/routes/csiRoutes"));
app.use("/payroll", require("./server/routes/payrollRoutes"));
// Other routes...
// Default route for forbidden access
app.get("/", (req, res) => {