reverting back
This commit is contained in:
parent
a33d0fd8b6
commit
13201259cf
601
fastify/app.js
601
fastify/app.js
@ -1,28 +1,40 @@
|
|||||||
const fastify = require("fastify")({ logger: true });
|
|
||||||
const cors = require("@fastify/cors");
|
|
||||||
const WebSocket = require("ws");
|
|
||||||
const path = require("path");
|
|
||||||
const fs = require("fs");
|
|
||||||
const PocketBase = require("pocketbase/cjs");
|
|
||||||
const { serialize } = require("object-to-formdata");
|
|
||||||
const got = require("got");
|
|
||||||
const cheerio = require("cheerio");
|
|
||||||
const sharp = require("sharp");
|
|
||||||
const axios = require("axios");
|
|
||||||
|
|
||||||
let serverRunning = false;
|
let serverRunning = false;
|
||||||
const activeConnections = new Set();
|
|
||||||
|
|
||||||
// Load API KEYS
|
const fastify = require("fastify")({});
|
||||||
|
const cors = require("@fastify/cors");
|
||||||
|
|
||||||
|
//Load API KEYS
|
||||||
require("dotenv").config({ path: "../app/.env" });
|
require("dotenv").config({ path: "../app/.env" });
|
||||||
const fmpAPIKey = process.env.FMP_API_KEY;
|
const fmpAPIKey = process.env.FMP_API_KEY;
|
||||||
|
//const mixpanelAPIKey = process.env.MIXPANEL_API_KEY;
|
||||||
const twitchAPIKey = process.env.TWITCH_API_KEY;
|
const twitchAPIKey = process.env.TWITCH_API_KEY;
|
||||||
const twitchSecretKey = process.env.TWITCH_SECRET_KEY;
|
const twitchSecretKey = process.env.TWITCH_SECRET_KEY;
|
||||||
|
|
||||||
|
//const Mixpanel = require('mixpanel');
|
||||||
|
//const UAParser = require('ua-parser-js');
|
||||||
|
|
||||||
|
const got = require("got"); //Only version npm i got@11.8.3 works with ESM
|
||||||
|
const cheerio = require("cheerio");
|
||||||
|
const sharp = require("sharp");
|
||||||
|
const axios = require("axios");
|
||||||
|
const fs = require("fs");
|
||||||
|
const path = require("path");
|
||||||
|
//const pino = require('pino');
|
||||||
|
|
||||||
|
//const mixpanel = Mixpanel.init(mixpanelAPIKey, { debug: false });
|
||||||
|
|
||||||
|
const PocketBase = require("pocketbase/cjs");
|
||||||
const pb = new PocketBase("http://127.0.0.1:8090");
|
const pb = new PocketBase("http://127.0.0.1:8090");
|
||||||
|
|
||||||
|
// globally disable auto cancellation
|
||||||
|
//See https://github.com/pocketbase/js-sdk#auto-cancellation
|
||||||
|
//Bug happens that get-post gives an error of auto-cancellation. Hence set it to false;
|
||||||
pb.autoCancellation(false);
|
pb.autoCancellation(false);
|
||||||
|
|
||||||
|
const { serialize } = require("object-to-formdata");
|
||||||
|
|
||||||
// Register the CORS plugin
|
// Register the CORS plugin
|
||||||
|
//Add Cors so that only localhost and my stocknear.com can send acceptable requests
|
||||||
fastify.register(cors);
|
fastify.register(cors);
|
||||||
const corsMiddleware = (request, reply, done) => {
|
const corsMiddleware = (request, reply, done) => {
|
||||||
const allowedOrigins = [
|
const allowedOrigins = [
|
||||||
@ -48,7 +60,7 @@ const corsMiddleware = (request, reply, done) => {
|
|||||||
};
|
};
|
||||||
fastify.addHook("onRequest", corsMiddleware);
|
fastify.addHook("onRequest", corsMiddleware);
|
||||||
|
|
||||||
// Register routes
|
//fastify.register(require('./mixpanel/server'), { mixpanel, UAParser });
|
||||||
fastify.register(require("./get-user-stats/server"), { pb });
|
fastify.register(require("./get-user-stats/server"), { pb });
|
||||||
fastify.register(require("./get-community-stats/server"), { pb });
|
fastify.register(require("./get-community-stats/server"), { pb });
|
||||||
fastify.register(require("./get-moderators/server"), { pb });
|
fastify.register(require("./get-moderators/server"), { pb });
|
||||||
@ -92,328 +104,359 @@ fastify.register(require("./downvote/server"), { pb });
|
|||||||
fastify.register(require("./upvote-comment/server"), { pb });
|
fastify.register(require("./upvote-comment/server"), { pb });
|
||||||
fastify.register(require("./downvote-comment/server"), { pb });
|
fastify.register(require("./downvote-comment/server"), { pb });
|
||||||
|
|
||||||
|
//fastify.register(require('./create-comment/server'), { pb });
|
||||||
|
|
||||||
|
function wait(ms) {
|
||||||
|
var start = new Date().getTime();
|
||||||
|
var end = start;
|
||||||
|
while (end < start + ms) {
|
||||||
|
end = new Date().getTime();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fastify.register(require("@fastify/websocket"));
|
fastify.register(require("@fastify/websocket"));
|
||||||
|
|
||||||
|
const WebSocket = require("ws");
|
||||||
|
|
||||||
|
let isSend = false;
|
||||||
|
let sendInterval;
|
||||||
|
|
||||||
fastify.register(async function (fastify) {
|
fastify.register(async function (fastify) {
|
||||||
fastify.get("/realtime-data", { websocket: true }, handleWebSocket);
|
fastify.get("/realtime-data", { websocket: true }, (connection, req) => {
|
||||||
fastify.get(
|
// Send a welcome message to the client
|
||||||
"/realtime-crypto-data",
|
|
||||||
{ websocket: true },
|
|
||||||
handleCryptoWebSocket
|
|
||||||
);
|
|
||||||
fastify.get(
|
|
||||||
"/options-flow-reader",
|
|
||||||
{ websocket: true },
|
|
||||||
handleOptionsFlowWebSocket
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
function handleWebSocket(connection, req) {
|
//connection.socket.send('hi from server');
|
||||||
let symbol = "";
|
|
||||||
let ws;
|
|
||||||
|
|
||||||
const cleanup = () => {
|
// Listen for incoming messages from the client
|
||||||
activeConnections.delete(connection);
|
connection.socket.on("message", (message) => {
|
||||||
if (ws) ws.close();
|
symbol = message.toString("utf-8");
|
||||||
};
|
console.log("Received message from client:", symbol);
|
||||||
|
|
||||||
activeConnections.add(connection);
|
// If you want to dynamically update the subscription based on client's message
|
||||||
|
updateSubscription();
|
||||||
|
});
|
||||||
|
|
||||||
const login = {
|
//======================
|
||||||
event: "login",
|
const login = {
|
||||||
data: {
|
event: "login",
|
||||||
apiKey: fmpAPIKey,
|
data: {
|
||||||
},
|
apiKey: fmpAPIKey,
|
||||||
};
|
},
|
||||||
|
};
|
||||||
|
|
||||||
const subscribe = {
|
const subscribe = {
|
||||||
event: "subscribe",
|
event: "subscribe",
|
||||||
data: {
|
data: {
|
||||||
ticker: "",
|
ticker: "", // Initial value; will be updated dynamically
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
function updateSubscription() {
|
function updateSubscription() {
|
||||||
subscribe.data.ticker = symbol;
|
subscribe.data.ticker = symbol;
|
||||||
if (ws && ws.readyState === WebSocket.OPEN) {
|
|
||||||
ws.send(JSON.stringify(subscribe));
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
function connectToFMP() {
|
// Create a new WebSocket instance for your backend
|
||||||
ws = new WebSocket("wss://websockets.financialmodelingprep.com");
|
const ws = new WebSocket("wss://websockets.financialmodelingprep.com");
|
||||||
|
|
||||||
|
// Handle WebSocket connection open
|
||||||
|
|
||||||
ws.on("open", function open() {
|
ws.on("open", function open() {
|
||||||
fastify.log.info("Connected to FMP WebSocket");
|
|
||||||
ws.send(JSON.stringify(login));
|
ws.send(JSON.stringify(login));
|
||||||
setTimeout(() => updateSubscription(), 2000);
|
wait(2000); //2 seconds in milliseconds
|
||||||
|
ws.send(JSON.stringify(subscribe));
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Handle WebSocket errors
|
||||||
ws.on("error", function (error) {
|
ws.on("error", function (error) {
|
||||||
fastify.log.error("FMP WebSocket error:", error);
|
console.error("WebSocket error:", error);
|
||||||
|
// Handle the error gracefully, you might want to notify the client or log it.
|
||||||
|
// For now, let's close the connection if an error occurs
|
||||||
|
connection.socket.close();
|
||||||
});
|
});
|
||||||
|
|
||||||
ws.on("close", function () {
|
ws.on("message", function (data, flags) {
|
||||||
fastify.log.info("FMP WebSocket closed. Attempting to reconnect...");
|
|
||||||
setTimeout(connectToFMP, 5000);
|
|
||||||
});
|
|
||||||
|
|
||||||
ws.on("message", function (data) {
|
|
||||||
const stringData = data.toString("utf-8");
|
const stringData = data.toString("utf-8");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
const jsonData = JSON.parse(stringData);
|
const jsonData = JSON.parse(stringData);
|
||||||
const bpData = jsonData.bp;
|
const bpData = jsonData.bp;
|
||||||
|
|
||||||
|
// Check if bpData is a number and not equal to zero
|
||||||
if (typeof bpData === "number" && bpData !== 0) {
|
if (typeof bpData === "number" && bpData !== 0) {
|
||||||
if (connection.socket.readyState === WebSocket.OPEN) {
|
if (connection.socket.readyState === WebSocket.OPEN && !isSend) {
|
||||||
connection.socket.send(JSON.stringify({ bp: bpData }));
|
connection.socket.send(JSON.stringify({ bp: bpData }));
|
||||||
|
isSend = true;
|
||||||
|
setTimeout(() => {
|
||||||
|
isSend = false;
|
||||||
|
}, 800);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
fastify.log.error("Error parsing JSON:", error);
|
console.error("Error parsing JSON:", error);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
|
||||||
|
|
||||||
connectToFMP();
|
//======================
|
||||||
|
|
||||||
connection.socket.on("message", (message) => {
|
// Handle client disconnect
|
||||||
symbol = message.toString("utf-8");
|
connection.socket.on("close", () => {
|
||||||
fastify.log.info("Received message from client:", symbol);
|
console.log("Client disconnected");
|
||||||
updateSubscription();
|
connection?.socket?.close();
|
||||||
});
|
// Check if the WebSocket is open before trying to close it
|
||||||
|
if (ws.readyState === WebSocket.OPEN) {
|
||||||
connection.socket.on("close", () => {
|
try {
|
||||||
fastify.log.info("Client disconnected");
|
ws.close();
|
||||||
cleanup();
|
} catch (e) {
|
||||||
});
|
console.error("Error while closing WebSocket:", e);
|
||||||
|
|
||||||
connection.socket.on("error", (error) => {
|
|
||||||
fastify.log.error("WebSocket error:", error);
|
|
||||||
cleanup();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleCryptoWebSocket(connection, req) {
|
|
||||||
let symbol = "";
|
|
||||||
let ws;
|
|
||||||
|
|
||||||
const cleanup = () => {
|
|
||||||
activeConnections.delete(connection);
|
|
||||||
if (ws) ws.close();
|
|
||||||
};
|
|
||||||
|
|
||||||
activeConnections.add(connection);
|
|
||||||
|
|
||||||
const login = {
|
|
||||||
event: "login",
|
|
||||||
data: {
|
|
||||||
apiKey: fmpAPIKey,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
const subscribe = {
|
|
||||||
event: "subscribe",
|
|
||||||
data: {
|
|
||||||
ticker: "",
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
function updateSubscription() {
|
|
||||||
subscribe.data.ticker = symbol;
|
|
||||||
if (ws && ws.readyState === WebSocket.OPEN) {
|
|
||||||
ws.send(JSON.stringify(subscribe));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function connectToCryptoFMP() {
|
|
||||||
ws = new WebSocket("wss://crypto.financialmodelingprep.com");
|
|
||||||
|
|
||||||
ws.on("open", function open() {
|
|
||||||
fastify.log.info("Connected to Crypto FMP WebSocket");
|
|
||||||
ws.send(JSON.stringify(login));
|
|
||||||
setTimeout(() => updateSubscription(), 2000);
|
|
||||||
});
|
|
||||||
|
|
||||||
ws.on("error", function (error) {
|
|
||||||
fastify.log.error("Crypto FMP WebSocket error:", error);
|
|
||||||
});
|
|
||||||
|
|
||||||
ws.on("close", function () {
|
|
||||||
fastify.log.info(
|
|
||||||
"Crypto FMP WebSocket closed. Attempting to reconnect..."
|
|
||||||
);
|
|
||||||
setTimeout(connectToCryptoFMP, 5000);
|
|
||||||
});
|
|
||||||
|
|
||||||
ws.on("message", function (data) {
|
|
||||||
const stringData = data.toString("utf-8");
|
|
||||||
if (connection.socket.readyState === WebSocket.OPEN) {
|
|
||||||
connection.socket.send(stringData);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
connectToCryptoFMP();
|
|
||||||
|
|
||||||
connection.socket.on("message", (message) => {
|
|
||||||
symbol = message.toString("utf-8");
|
|
||||||
fastify.log.info("Received message from client:", symbol);
|
|
||||||
updateSubscription();
|
|
||||||
});
|
|
||||||
|
|
||||||
connection.socket.on("close", () => {
|
|
||||||
fastify.log.info("Client disconnected");
|
|
||||||
cleanup();
|
|
||||||
});
|
|
||||||
|
|
||||||
connection.socket.on("error", (error) => {
|
|
||||||
fastify.log.error("WebSocket error:", error);
|
|
||||||
cleanup();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleOptionsFlowWebSocket(connection, req) {
|
|
||||||
let jsonData;
|
|
||||||
let sendInterval;
|
|
||||||
let clientIds = [];
|
|
||||||
|
|
||||||
const cleanup = () => {
|
|
||||||
activeConnections.delete(connection);
|
|
||||||
clearInterval(sendInterval);
|
|
||||||
};
|
|
||||||
|
|
||||||
activeConnections.add(connection);
|
|
||||||
|
|
||||||
const sendData = async () => {
|
|
||||||
const filePath = path.join(
|
|
||||||
__dirname,
|
|
||||||
"../app/json/options-flow/feed/data.json"
|
|
||||||
);
|
|
||||||
try {
|
|
||||||
if (fs.existsSync(filePath)) {
|
|
||||||
const fileData = fs.readFileSync(filePath, "utf8");
|
|
||||||
jsonData = JSON.parse(fileData);
|
|
||||||
|
|
||||||
if (clientIds.length === 0) {
|
|
||||||
fastify.log.info("Client IDs list is empty, doing nothing.");
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const filteredData = jsonData.filter(
|
|
||||||
(item) => !clientIds.includes(item.id)
|
|
||||||
);
|
|
||||||
|
|
||||||
if (connection.socket.readyState === WebSocket.OPEN) {
|
|
||||||
connection.socket.send(JSON.stringify(filteredData));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fastify.log.error("File not found:", filePath);
|
|
||||||
clearInterval(sendInterval);
|
|
||||||
}
|
}
|
||||||
} catch (err) {
|
});
|
||||||
fastify.log.error("Error sending data to client:", err);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
sendInterval = setInterval(sendData, 5000);
|
|
||||||
|
|
||||||
connection.socket.on("message", (message) => {
|
|
||||||
try {
|
|
||||||
const parsedMessage = JSON.parse(message);
|
|
||||||
if (parsedMessage?.ids) {
|
|
||||||
clientIds = parsedMessage.ids;
|
|
||||||
}
|
|
||||||
} catch (error) {
|
|
||||||
fastify.log.error("Error parsing incoming message:", error);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
connection.socket.on("close", () => {
|
|
||||||
fastify.log.info("Client disconnected");
|
|
||||||
cleanup();
|
|
||||||
});
|
|
||||||
|
|
||||||
connection.socket.on("error", (error) => {
|
|
||||||
fastify.log.error("WebSocket error:", error);
|
|
||||||
cleanup();
|
|
||||||
});
|
|
||||||
|
|
||||||
sendData();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Graceful shutdown
|
|
||||||
async function gracefulShutdown() {
|
|
||||||
fastify.log.info("Shutting down gracefully...");
|
|
||||||
for (const connection of activeConnections) {
|
|
||||||
connection.socket.close();
|
|
||||||
}
|
|
||||||
await fastify.close();
|
|
||||||
process.exit(0);
|
|
||||||
}
|
|
||||||
|
|
||||||
process.on("SIGINT", gracefulShutdown);
|
|
||||||
process.on("SIGTERM", gracefulShutdown);
|
|
||||||
|
|
||||||
// Error handling
|
|
||||||
fastify.setErrorHandler((error, request, reply) => {
|
|
||||||
fastify.log.error(error);
|
|
||||||
reply.status(500).send({ error: "Internal Server Error" });
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Start the server
|
fastify.register(async function (fastify) {
|
||||||
async function startServer() {
|
fastify.get(
|
||||||
try {
|
"/realtime-crypto-data",
|
||||||
await fastify.listen({ port: 2000, host: "0.0.0.0" });
|
{ websocket: true },
|
||||||
serverRunning = true;
|
(connection, req) => {
|
||||||
fastify.log.info("Server started successfully on port 2000!");
|
// Send a welcome message to the client
|
||||||
} catch (err) {
|
|
||||||
fastify.log.error(err);
|
// Listen for incoming messages from the client
|
||||||
process.exit(1);
|
connection.socket.on("message", (message) => {
|
||||||
|
symbol = message.toString("utf-8");
|
||||||
|
console.log("Received message from client:", symbol);
|
||||||
|
|
||||||
|
// If you want to dynamically update the subscription based on client's message
|
||||||
|
updateSubscription();
|
||||||
|
});
|
||||||
|
|
||||||
|
//======================
|
||||||
|
const login = {
|
||||||
|
event: "login",
|
||||||
|
data: {
|
||||||
|
apiKey: fmpAPIKey,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
const subscribe = {
|
||||||
|
event: "subscribe",
|
||||||
|
data: {
|
||||||
|
ticker: "", // Initial value; will be updated dynamically
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
function updateSubscription() {
|
||||||
|
subscribe.data.ticker = symbol;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create a new WebSocket instance for your backend
|
||||||
|
const ws = new WebSocket("wss://crypto.financialmodelingprep.com");
|
||||||
|
|
||||||
|
// Handle WebSocket connection open
|
||||||
|
|
||||||
|
ws.on("open", function open() {
|
||||||
|
ws.send(JSON.stringify(login));
|
||||||
|
wait(2000); //2 seconds in milliseconds
|
||||||
|
ws.send(JSON.stringify(subscribe));
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle WebSocket errors
|
||||||
|
ws.on("error", function (error) {
|
||||||
|
console.error("WebSocket error:", error);
|
||||||
|
// Handle the error gracefully, you might want to notify the client or log it.
|
||||||
|
// For now, let's close the connection if an error occurs
|
||||||
|
connection.socket.close();
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle WebSocket messages
|
||||||
|
ws.on("message", function (data, flags) {
|
||||||
|
const stringData = data.toString("utf-8");
|
||||||
|
|
||||||
|
if (connection.socket.readyState === WebSocket.OPEN && !isSend) {
|
||||||
|
connection.socket.send(stringData);
|
||||||
|
//console.log(stringData)
|
||||||
|
isSend = true;
|
||||||
|
setTimeout(() => {
|
||||||
|
isSend = false;
|
||||||
|
}, 800);
|
||||||
|
|
||||||
|
//wait(2000);
|
||||||
|
}
|
||||||
|
//wait(2000);
|
||||||
|
});
|
||||||
|
|
||||||
|
//======================
|
||||||
|
|
||||||
|
// Handle client disconnect
|
||||||
|
connection.socket.on("close", () => {
|
||||||
|
console.log("Client disconnected");
|
||||||
|
connection?.socket?.close();
|
||||||
|
// Check if the WebSocket is open before trying to close it
|
||||||
|
if (ws.readyState === WebSocket.OPEN) {
|
||||||
|
try {
|
||||||
|
ws.close();
|
||||||
|
} catch (e) {
|
||||||
|
console.error("Error while closing WebSocket:", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
fastify.register(async function (fastify) {
|
||||||
|
fastify.get(
|
||||||
|
"/options-flow-reader",
|
||||||
|
{ websocket: true },
|
||||||
|
(connection, req) => {
|
||||||
|
let jsonData;
|
||||||
|
let sendInterval;
|
||||||
|
let clientIds = [];
|
||||||
|
|
||||||
|
// Function to send filtered data to the client
|
||||||
|
const sendData = async () => {
|
||||||
|
const filePath = path.join(
|
||||||
|
__dirname,
|
||||||
|
"../app/json/options-flow/feed/data.json"
|
||||||
|
);
|
||||||
|
try {
|
||||||
|
if (fs.existsSync(filePath)) {
|
||||||
|
const fileData = fs.readFileSync(filePath, "utf8");
|
||||||
|
jsonData = JSON.parse(fileData);
|
||||||
|
|
||||||
|
// Do nothing if clientIds is empty
|
||||||
|
if (clientIds.length === 0) {
|
||||||
|
console.log("Client IDs list is empty, doing nothing.");
|
||||||
|
return; // Exit function if clientIds is empty
|
||||||
|
}
|
||||||
|
|
||||||
|
// Filter out elements whose ids are not in clientIds
|
||||||
|
const filteredData = jsonData.filter(
|
||||||
|
(item) => !clientIds.includes(item.id)
|
||||||
|
);
|
||||||
|
|
||||||
|
// Send the filtered data back to the client
|
||||||
|
connection.socket.send(JSON.stringify(filteredData));
|
||||||
|
} else {
|
||||||
|
console.error("File not found:", filePath);
|
||||||
|
clearInterval(sendInterval);
|
||||||
|
connection?.socket?.close();
|
||||||
|
console.error("Connection closed");
|
||||||
|
throw new Error("This is an intentional uncaught exception!");
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
console.error("Error sending data to client:", err);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// Send data to the client initially
|
||||||
|
sendData();
|
||||||
|
|
||||||
|
// Start sending data periodically
|
||||||
|
sendInterval = setInterval(sendData, 5000);
|
||||||
|
|
||||||
|
// Handle incoming messages from the client to update the ids
|
||||||
|
connection.socket.on("message", (message) => {
|
||||||
|
try {
|
||||||
|
const parsedMessage = JSON.parse(message);
|
||||||
|
if (parsedMessage?.ids) {
|
||||||
|
//console.log("Received ids from client:", parsedMessage.ids);
|
||||||
|
clientIds = parsedMessage.ids; // Update the ids list from the client
|
||||||
|
} else {
|
||||||
|
//console.log("No ids received in the message");
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error parsing incoming message:", error);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle client disconnect
|
||||||
|
connection.socket.on("close", () => {
|
||||||
|
console.log("Client disconnected");
|
||||||
|
clearInterval(sendInterval);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle server crash cleanup
|
||||||
|
const closeHandler = () => {
|
||||||
|
console.log("Server is closing. Cleaning up resources...");
|
||||||
|
clearInterval(sendInterval);
|
||||||
|
connection.socket.close();
|
||||||
|
};
|
||||||
|
|
||||||
|
// Add close handler to process event
|
||||||
|
process.on("exit", closeHandler);
|
||||||
|
process.on("SIGINT", closeHandler);
|
||||||
|
process.on("SIGTERM", closeHandler);
|
||||||
|
process.on("uncaughtException", closeHandler);
|
||||||
|
process.on("unhandledRejection", closeHandler);
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
// Function to start the server
|
||||||
|
function startServer() {
|
||||||
|
if (!serverRunning) {
|
||||||
|
fastify.listen(2000, (err) => {
|
||||||
|
if (err) {
|
||||||
|
console.error("Error starting server:", err);
|
||||||
|
process.exit(1); // Exit the process if server start fails
|
||||||
|
}
|
||||||
|
serverRunning = true;
|
||||||
|
console.log("Server started successfully on port 2000!");
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
console.log("Server is already running.");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Function to stop the server
|
// Function to stop the server
|
||||||
async function stopServer() {
|
function stopServer() {
|
||||||
if (serverRunning) {
|
if (serverRunning) {
|
||||||
try {
|
return new Promise((resolve, reject) => {
|
||||||
await fastify.close();
|
fastify.close((err) => {
|
||||||
serverRunning = false;
|
if (err) {
|
||||||
fastify.log.info("Server closed successfully!");
|
console.error("Error closing server:", err);
|
||||||
} catch (err) {
|
reject(err);
|
||||||
fastify.log.error("Error closing server:", err);
|
} else {
|
||||||
throw err;
|
serverRunning = false;
|
||||||
}
|
console.log("Server closed successfully!");
|
||||||
|
resolve();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
fastify.log.info("Server is not running.");
|
console.log("Server is not running.");
|
||||||
|
return Promise.resolve();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Function to gracefully close and restart the server
|
// Function to gracefully close and restart the server
|
||||||
async function restartServer() {
|
function restartServer() {
|
||||||
if (serverRunning) {
|
if (serverRunning) {
|
||||||
try {
|
stopServer()
|
||||||
await stopServer();
|
.then(() => {
|
||||||
fastify.log.info("Restarting server...");
|
console.log("Restarting server...");
|
||||||
await startServer();
|
startServer();
|
||||||
} catch (error) {
|
})
|
||||||
fastify.log.error("Failed to restart server:", error);
|
.catch((error) => {
|
||||||
process.exit(1);
|
console.error("Failed to restart server:", error);
|
||||||
}
|
process.exit(1); // Exit the process if server restart fails
|
||||||
|
});
|
||||||
} else {
|
} else {
|
||||||
fastify.log.info("Server is not running. Starting server...");
|
console.log("Server is not running. Starting server...");
|
||||||
await startServer();
|
startServer();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Global error handlers
|
// Add a global error handler for uncaught exceptions
|
||||||
process.on("uncaughtException", (err) => {
|
process.on("uncaughtException", (err) => {
|
||||||
fastify.log.error("Uncaught Exception:", err);
|
console.error("Uncaught Exception:", err);
|
||||||
restartServer();
|
restartServer();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Add a global error handler for unhandled promise rejections
|
||||||
process.on("unhandledRejection", (reason, promise) => {
|
process.on("unhandledRejection", (reason, promise) => {
|
||||||
fastify.log.error("Unhandled Rejection at:", promise, "reason:", reason);
|
console.error("Unhandled Rejection at:", promise, "reason:", reason);
|
||||||
restartServer();
|
restartServer();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user