2022-12-12 06:57:57 -08:00
|
|
|
const { log } = require("../../src/util");
|
|
|
|
const { Settings } = require("../settings");
|
|
|
|
const { sendInfo } = require("../client");
|
2022-12-15 20:56:40 -08:00
|
|
|
const { checkLogin } = require("../util-server");
|
2023-01-24 07:03:01 -08:00
|
|
|
const GameResolver = require("gamedig/lib/GameResolver");
|
2023-06-27 00:54:33 -07:00
|
|
|
const { testChrome } = require("../monitor-types/real-browser-monitor-type");
|
2023-09-25 02:49:00 -07:00
|
|
|
const fs = require("fs");
|
|
|
|
const path = require("path");
|
2023-01-24 07:03:01 -08:00
|
|
|
|
|
|
|
let gameResolver = new GameResolver();
|
|
|
|
let gameList = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a game list via GameDig
|
2023-08-11 00:46:41 -07:00
|
|
|
* @returns {object[]} list of games supported by GameDig
|
2023-01-24 07:03:01 -08:00
|
|
|
*/
|
|
|
|
function getGameList() {
|
2023-02-24 05:06:00 -08:00
|
|
|
if (gameList == null) {
|
2023-01-24 07:03:01 -08:00
|
|
|
gameList = gameResolver._readGames().games.sort((a, b) => {
|
|
|
|
if ( a.pretty < b.pretty ) {
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
if ( a.pretty > b.pretty ) {
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
}
|
2023-02-24 05:06:00 -08:00
|
|
|
return gameList;
|
2023-01-24 07:03:01 -08:00
|
|
|
}
|
2022-12-12 06:57:57 -08:00
|
|
|
|
2024-08-24 09:40:50 -07:00
|
|
|
/**
|
|
|
|
* Handler for general events
|
|
|
|
* @param {Socket} socket Socket.io instance
|
|
|
|
* @param {UptimeKumaServer} server Uptime Kuma server
|
|
|
|
* @returns {void}
|
|
|
|
*/
|
2022-12-12 06:57:57 -08:00
|
|
|
module.exports.generalSocketHandler = (socket, server) => {
|
|
|
|
socket.on("initServerTimezone", async (timezone) => {
|
|
|
|
try {
|
2022-12-15 20:56:40 -08:00
|
|
|
checkLogin(socket);
|
2022-12-12 06:57:57 -08:00
|
|
|
log.debug("generalSocketHandler", "Timezone: " + timezone);
|
|
|
|
await Settings.set("initServerTimezone", true);
|
|
|
|
await server.setTimezone(timezone);
|
|
|
|
await sendInfo(socket);
|
|
|
|
} catch (e) {
|
2022-12-15 20:56:40 -08:00
|
|
|
log.warn("initServerTimezone", e.message);
|
2022-12-12 06:57:57 -08:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-01-24 07:03:01 -08:00
|
|
|
socket.on("getGameList", async (callback) => {
|
2023-11-24 00:37:52 -08:00
|
|
|
try {
|
|
|
|
checkLogin(socket);
|
2023-06-27 00:54:33 -07:00
|
|
|
callback({
|
|
|
|
ok: true,
|
2023-11-24 00:37:52 -08:00
|
|
|
gameList: getGameList(),
|
2023-06-27 00:54:33 -07:00
|
|
|
});
|
2023-11-24 00:37:52 -08:00
|
|
|
} catch (e) {
|
2023-06-27 00:54:33 -07:00
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: e.message,
|
2023-11-24 01:33:13 -08:00
|
|
|
});
|
2023-11-24 00:37:52 -08:00
|
|
|
}
|
2023-01-24 07:03:01 -08:00
|
|
|
});
|
|
|
|
|
2023-06-27 00:54:33 -07:00
|
|
|
socket.on("testChrome", (executable, callback) => {
|
2023-11-24 00:37:52 -08:00
|
|
|
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,
|
2023-11-24 11:25:03 -08:00
|
|
|
msg: {
|
|
|
|
key: "foundChromiumVersion",
|
|
|
|
values: [ version ],
|
|
|
|
},
|
|
|
|
msgi18n: true,
|
2023-11-24 00:37:52 -08:00
|
|
|
});
|
|
|
|
}).catch((e) => {
|
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: e.message,
|
|
|
|
});
|
2023-06-27 00:54:33 -07:00
|
|
|
});
|
2023-11-24 00:37:52 -08:00
|
|
|
} catch (e) {
|
2023-06-27 00:54:33 -07:00
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: e.message,
|
|
|
|
});
|
2023-11-24 00:37:52 -08:00
|
|
|
}
|
2023-06-27 00:54:33 -07:00
|
|
|
});
|
2023-09-25 02:49:00 -07:00
|
|
|
|
|
|
|
socket.on("getPushExample", (language, callback) => {
|
|
|
|
|
|
|
|
try {
|
|
|
|
let dir = path.join("./extra/push-examples", language);
|
|
|
|
let files = fs.readdirSync(dir);
|
|
|
|
|
|
|
|
for (let file of files) {
|
|
|
|
if (file.startsWith("index.")) {
|
|
|
|
callback({
|
|
|
|
ok: true,
|
|
|
|
code: fs.readFileSync(path.join(dir, file), "utf8"),
|
|
|
|
});
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: "Not found",
|
|
|
|
});
|
|
|
|
});
|
2023-12-10 10:13:47 -08:00
|
|
|
|
2023-12-10 04:40:40 -08: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 06:57:57 -08:00
|
|
|
};
|