2022-12-12 14:57:57 +00:00
|
|
|
const { log } = require("../../src/util");
|
|
|
|
const { Settings } = require("../settings");
|
|
|
|
const { sendInfo } = require("../client");
|
2022-12-16 04:56:40 +00:00
|
|
|
const { checkLogin } = require("../util-server");
|
2023-01-24 15:03:01 +00:00
|
|
|
const GameResolver = require("gamedig/lib/GameResolver");
|
2023-06-27 07:54:33 +00:00
|
|
|
const { testChrome } = require("../monitor-types/real-browser-monitor-type");
|
2023-01-24 15:03:01 +00:00
|
|
|
|
|
|
|
let gameResolver = new GameResolver();
|
|
|
|
let gameList = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a game list via GameDig
|
2023-02-24 13:09:55 +00:00
|
|
|
* @returns {Object[]} list of games supported by GameDig
|
2023-01-24 15:03:01 +00:00
|
|
|
*/
|
|
|
|
function getGameList() {
|
2023-02-24 13:06:00 +00:00
|
|
|
if (gameList == null) {
|
2023-01-24 15:03:01 +00: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 13:06:00 +00:00
|
|
|
return gameList;
|
2023-01-24 15:03:01 +00:00
|
|
|
}
|
2022-12-12 14:57:57 +00:00
|
|
|
|
|
|
|
module.exports.generalSocketHandler = (socket, server) => {
|
|
|
|
|
|
|
|
socket.on("initServerTimezone", async (timezone) => {
|
|
|
|
try {
|
2022-12-16 04:56:40 +00:00
|
|
|
checkLogin(socket);
|
2022-12-12 14:57:57 +00:00
|
|
|
log.debug("generalSocketHandler", "Timezone: " + timezone);
|
|
|
|
await Settings.set("initServerTimezone", true);
|
|
|
|
await server.setTimezone(timezone);
|
|
|
|
await sendInfo(socket);
|
|
|
|
} catch (e) {
|
2022-12-16 04:56:40 +00:00
|
|
|
log.warn("initServerTimezone", e.message);
|
2022-12-12 14:57:57 +00:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-01-24 15:03:01 +00:00
|
|
|
socket.on("getGameList", async (callback) => {
|
2023-11-24 08:37:52 +00:00
|
|
|
try {
|
|
|
|
checkLogin(socket);
|
2023-06-27 07:54:33 +00:00
|
|
|
callback({
|
|
|
|
ok: true,
|
2023-11-24 08:37:52 +00:00
|
|
|
gameList: getGameList(),
|
2023-06-27 07:54:33 +00:00
|
|
|
});
|
2023-11-24 08:37:52 +00:00
|
|
|
} catch (e) {
|
2023-06-27 07:54:33 +00:00
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: e.message,
|
2023-11-24 09:33:13 +00:00
|
|
|
});
|
2023-11-24 08:37:52 +00: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 07:54:33 +00:00
|
|
|
});
|
2023-11-24 08:37:52 +00:00
|
|
|
} catch (e) {
|
|
|
|
callback({
|
|
|
|
ok: false,
|
|
|
|
msg: e.message,
|
2023-11-24 09:33:13 +00:00
|
|
|
});
|
2023-11-24 08:37:52 +00:00
|
|
|
}
|
2023-06-27 07:54:33 +00:00
|
|
|
});
|
2023-12-10 12:40:40 +00: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 14:57:57 +00:00
|
|
|
};
|