Compare commits

..

1 Commits

Author SHA1 Message Date
abc551eee2 replace ws library
All checks were successful
Build / build (pull_request) Successful in 51s
2025-06-22 01:01:04 +02:00
3 changed files with 27 additions and 58 deletions

24
package-lock.json generated
View File

@ -24,8 +24,7 @@
"warframe-riven-info": "^0.1.2", "warframe-riven-info": "^0.1.2",
"websocket": "^1.0.35", "websocket": "^1.0.35",
"winston": "^3.17.0", "winston": "^3.17.0",
"winston-daily-rotate-file": "^5.0.0", "winston-daily-rotate-file": "^5.0.0"
"ws": "^8.18.2"
}, },
"devDependencies": { "devDependencies": {
"@typescript-eslint/eslint-plugin": "^8.28.0", "@typescript-eslint/eslint-plugin": "^8.28.0",
@ -3644,27 +3643,6 @@
"integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==",
"license": "ISC" "license": "ISC"
}, },
"node_modules/ws": {
"version": "8.18.2",
"resolved": "https://registry.npmjs.org/ws/-/ws-8.18.2.tgz",
"integrity": "sha512-DMricUmwGZUVr++AEAe2uiVM7UoO9MAVZMDu05UQOaUII0lp+zOzLLU4Xqh/JvTqklB1T4uELaaPBKyjE1r4fQ==",
"license": "MIT",
"engines": {
"node": ">=10.0.0"
},
"peerDependencies": {
"bufferutil": "^4.0.1",
"utf-8-validate": ">=5.0.2"
},
"peerDependenciesMeta": {
"bufferutil": {
"optional": true
},
"utf-8-validate": {
"optional": true
}
}
},
"node_modules/yaeti": { "node_modules/yaeti": {
"version": "0.0.6", "version": "0.0.6",
"resolved": "https://registry.npmjs.org/yaeti/-/yaeti-0.0.6.tgz", "resolved": "https://registry.npmjs.org/yaeti/-/yaeti-0.0.6.tgz",

View File

@ -33,8 +33,7 @@
"warframe-riven-info": "^0.1.2", "warframe-riven-info": "^0.1.2",
"websocket": "^1.0.35", "websocket": "^1.0.35",
"winston": "^3.17.0", "winston": "^3.17.0",
"winston-daily-rotate-file": "^5.0.0", "winston-daily-rotate-file": "^5.0.0"
"ws": "^8.18.2"
}, },
"devDependencies": { "devDependencies": {
"@typescript-eslint/eslint-plugin": "^8.28.0", "@typescript-eslint/eslint-plugin": "^8.28.0",

View File

@ -5,7 +5,6 @@ import { config } from "./configService";
import { logger } from "../utils/logger"; import { logger } from "../utils/logger";
import { app } from "../app"; import { app } from "../app";
import { AddressInfo } from "node:net"; import { AddressInfo } from "node:net";
import ws from "ws";
import { Account } from "../models/loginModel"; import { Account } from "../models/loginModel";
import { createAccount, createNonce, getUsernameFromEmail, isCorrectPassword } from "./loginService"; import { createAccount, createNonce, getUsernameFromEmail, isCorrectPassword } from "./loginService";
import { IDatabaseAccountJson } from "../types/loginTypes"; import { IDatabaseAccountJson } from "../types/loginTypes";
@ -14,8 +13,8 @@ import websocket from "websocket";
let httpServer: http.Server | undefined; let httpServer: http.Server | undefined;
let httpsServer: https.Server | undefined; let httpsServer: https.Server | undefined;
let wsServer: ws.Server | undefined; let wsServer: websocket.server | undefined;
let wssServer: ws.Server | undefined; let wssServer: websocket.server | undefined;
const tlsOptions = { const tlsOptions = {
key: fs.readFileSync("static/certs/key.pem"), key: fs.readFileSync("static/certs/key.pem"),
@ -29,16 +28,16 @@ export const startWebServer = (): void => {
// eslint-disable-next-line @typescript-eslint/no-misused-promises // eslint-disable-next-line @typescript-eslint/no-misused-promises
httpServer = http.createServer(app); httpServer = http.createServer(app);
httpServer.listen(httpPort, () => { httpServer.listen(httpPort, () => {
wsServer = new ws.Server({ server: httpServer }); wsServer = new websocket.server({ httpServer: httpServer! });
wsServer.on("connection", wsOnConnect); wsServer.on("request", wsOnRequest);
logger.info("HTTP server started on port " + httpPort); logger.info("HTTP server started on port " + httpPort);
// eslint-disable-next-line @typescript-eslint/no-misused-promises // eslint-disable-next-line @typescript-eslint/no-misused-promises
httpsServer = https.createServer(tlsOptions, app); httpsServer = https.createServer(tlsOptions, app);
httpsServer.listen(httpsPort, () => { httpsServer.listen(httpsPort, () => {
wssServer = new ws.Server({ server: httpsServer }); wssServer = new websocket.server({ httpServer: httpsServer! });
wssServer.on("connection", wsOnConnect); wssServer.on("request", wsOnRequest);
logger.info("HTTPS server started on port " + httpsPort); logger.info("HTTPS server started on port " + httpsPort);
@ -88,6 +87,13 @@ export const getWebPorts = (): Record<"http" | "https", number | undefined> => {
}; };
export const stopWebServer = async (): Promise<void> => { export const stopWebServer = async (): Promise<void> => {
if (wsServer) {
wsServer.shutDown();
}
if (wssServer) {
wssServer.shutDown();
}
const promises: Promise<void>[] = []; const promises: Promise<void>[] = [];
if (httpServer) { if (httpServer) {
promises.push( promises.push(
@ -107,28 +113,10 @@ export const stopWebServer = async (): Promise<void> => {
}) })
); );
} }
if (wsServer) {
promises.push(
new Promise(resolve => {
wsServer!.close(() => {
resolve();
});
})
);
}
if (wssServer) {
promises.push(
new Promise(resolve => {
wssServer!.close(() => {
resolve();
});
})
);
}
await Promise.all(promises); await Promise.all(promises);
}; };
interface IWsCustomData extends ws { interface IWsCustomData extends websocket.connection {
accountId?: string; accountId?: string;
} }
@ -159,15 +147,19 @@ interface IWsMsgToClient {
logged_out?: boolean; logged_out?: boolean;
} }
const wsOnConnect = (ws: ws, req: http.IncomingMessage): void => { const wsOnRequest = (req: websocket.request): void => {
if (req.url == "/custom/selftest") { const ws = req.accept();
if (req.httpRequest.url == "/custom/selftest") {
ws.send("SpaceNinjaServer"); ws.send("SpaceNinjaServer");
ws.close(); ws.close();
return; return;
} }
// eslint-disable-next-line @typescript-eslint/no-misused-promises // eslint-disable-next-line @typescript-eslint/no-misused-promises
ws.on("message", async msg => { ws.on("message", async msg => {
const data = JSON.parse(String(msg)) as IWsMsgFromClient; if (msg.type != "utf8") {
return;
}
const data = JSON.parse(String(msg.utf8Data)) as IWsMsgFromClient;
if (data.auth) { if (data.auth) {
let account: IDatabaseAccountJson | null = await Account.findOne({ email: data.auth.email }); let account: IDatabaseAccountJson | null = await Account.findOne({ email: data.auth.email });
if (account) { if (account) {
@ -221,12 +213,12 @@ const wsOnConnect = (ws: ws, req: http.IncomingMessage): void => {
export const sendWsBroadcast = (data: IWsMsgToClient): void => { export const sendWsBroadcast = (data: IWsMsgToClient): void => {
const msg = JSON.stringify(data); const msg = JSON.stringify(data);
if (wsServer) { if (wsServer) {
for (const client of wsServer.clients) { for (const client of wsServer.connections) {
client.send(msg); client.send(msg);
} }
} }
if (wssServer) { if (wssServer) {
for (const client of wssServer.clients) { for (const client of wssServer.connections) {
client.send(msg); client.send(msg);
} }
} }
@ -235,14 +227,14 @@ export const sendWsBroadcast = (data: IWsMsgToClient): void => {
export const sendWsBroadcastTo = (accountId: string, data: IWsMsgToClient): void => { export const sendWsBroadcastTo = (accountId: string, data: IWsMsgToClient): void => {
const msg = JSON.stringify(data); const msg = JSON.stringify(data);
if (wsServer) { if (wsServer) {
for (const client of wsServer.clients) { for (const client of wsServer.connections) {
if ((client as IWsCustomData).accountId == accountId) { if ((client as IWsCustomData).accountId == accountId) {
client.send(msg); client.send(msg);
} }
} }
} }
if (wssServer) { if (wssServer) {
for (const client of wssServer.clients) { for (const client of wssServer.connections) {
if ((client as IWsCustomData).accountId == accountId) { if ((client as IWsCustomData).accountId == accountId) {
client.send(msg); client.send(msg);
} }