X-Git-Url: https://git.auder.net/?p=vchess.git;a=blobdiff_plain;f=server%2Fsockets.js;h=ef46427bacbd3e9690b912fb4ce0a5581522f38d;hp=9fa09bce2cd2b949974798915523f5df7286b6f2;hb=e8ea1e351fae405a4f3b0a11b17ddada560ba052;hpb=7e98914d2cc787c5d1b1604987a9644b8d4c566f diff --git a/server/sockets.js b/server/sockets.js index 9fa09bce..ef46427b 100644 --- a/server/sockets.js +++ b/server/sockets.js @@ -1,3 +1,6 @@ +const Discord = require('discord.js'); +const { token, channel } = require('./config/discord.json'); + // Node version in Ubuntu 16.04 does not know about URL class function getJsonFromUrl(url) { const query = url.substr(2); //starts with "/?" @@ -24,6 +27,13 @@ module.exports = function(wss) { // NOTE: only purpose of sidToPages = know when to delete keys in idToSid let sidToPages = {}; let idToSid = {}; + const discordClient = new Discord.Client(); + let discordChannel = null; + if (token.length > 0) { + discordClient.login(token).then( () => { + discordChannel = discordClient.channels.cache.get(channel); + }); + } wss.on("connection", (socket, req) => { const query = getJsonFromUrl(req.url); const sid = query["sid"]; @@ -209,6 +219,12 @@ module.exports = function(wss) { // "newgame" message can provide a page (corr Game --> Hall) notifyRoom( obj.page || page, obj.code, {data: obj.data}, obj.excluded); + if (!!discordChannel && obj.code == "newchallenge") { + discordChannel.send("New challenge: " + + obj.data.vname + + " [" + obj.data.cadence + "]" + + " - https://vchess.club"); + } break; case "rnewgame":