uptime-kuma/server/socket-handlers/general-socket-handler.js

92 lines
2.6 KiB
JavaScript
Raw Normal View History

2022-12-12 09:57:57 -05:00
const { log } = require("../../src/util");
const { Settings } = require("../settings");
const { sendInfo } = require("../client");
2022-12-15 23:56:40 -05:00
const { checkLogin } = require("../util-server");
2023-01-24 10:03:01 -05:00
const GameResolver = require("gamedig/lib/GameResolver");
2023-06-27 03:54:33 -04:00
const { testChrome } = require("../monitor-types/real-browser-monitor-type");
2023-01-24 10:03:01 -05:00
let gameResolver = new GameResolver();
let gameList = null;
/**
* Get a game list via GameDig
2023-02-24 08:09:55 -05:00
* @returns {Object[]} list of games supported by GameDig
2023-01-24 10:03:01 -05:00
*/
function getGameList() {
if (gameList == null) {
2023-01-24 10:03:01 -05:00
gameList = gameResolver._readGames().games.sort((a, b) => {
if ( a.pretty < b.pretty ) {
return -1;
}
if ( a.pretty > b.pretty ) {
return 1;
}
return 0;
});
}
return gameList;
2023-01-24 10:03:01 -05:00
}
2022-12-12 09:57:57 -05:00
module.exports.generalSocketHandler = (socket, server) => {
socket.on("initServerTimezone", async (timezone) => {
try {
2022-12-15 23:56:40 -05:00
checkLogin(socket);
2022-12-12 09:57:57 -05:00
log.debug("generalSocketHandler", "Timezone: " + timezone);
await Settings.set("initServerTimezone", true);
await server.setTimezone(timezone);
await sendInfo(socket);
} catch (e) {
2022-12-15 23:56:40 -05:00
log.warn("initServerTimezone", e.message);
2022-12-12 09:57:57 -05:00
}
});
2023-01-24 10:03:01 -05:00
socket.on("getGameList", async (callback) => {
try {
checkLogin(socket);
2023-06-27 03:54:33 -04:00
callback({
ok: true,
gameList: getGameList(),
2023-06-27 03:54:33 -04:00
});
} catch (e) {
2023-06-27 03:54:33 -04:00
callback({
ok: false,
msg: e.message,
2023-11-24 04:33:13 -05:00
});
}
});
socket.on("testChrome", (executable, callback) => {
try {
checkLogin(socket);
// Just noticed that await call could block the whole socket.io server!!! Use pure promise instead.
testChrome(executable).then((version) => {
callback({
ok: true,
msg: "Found Chromium/Chrome. Version: " + version,
});
}).catch((e) => {
callback({
ok: false,
msg: e.message,
});
2023-06-27 03:54:33 -04:00
});
} catch (e) {
callback({
ok: false,
msg: e.message,
2023-11-24 04:33:13 -05:00
});
}
2023-06-27 03:54:33 -04:00
});
// Disconnect all other socket clients of the user
socket.on("disconnectOtherSocketClients", async () => {
try {
checkLogin(socket);
server.disconnectAllSocketClients(socket.userID, socket.id);
} catch (e) {
log.warn("disconnectAllSocketClients", e.message);
}
});
2022-12-12 09:57:57 -05:00
};