From b20d45baeb07843d9640d8d26447e718ddff4bac Mon Sep 17 00:00:00 2001 From: Davide Fantino <80767709+fantinodavide@users.noreply.github.com> Date: Tue, 20 Sep 2022 23:21:05 +0200 Subject: [PATCH] fixes and optimizations --- README.MD | 11 ++++++++--- mapvote.js | 43 +++++++++++++++++++++++-------------------- 2 files changed, 31 insertions(+), 23 deletions(-) diff --git a/README.MD b/README.MD index a7f4483..b8c6c3e 100644 --- a/README.MD +++ b/README.MD @@ -118,6 +118,13 @@ The ID of the channel to log votes to. ```json "112233445566778899" ``` +#### timezone +###### Description +Timezone relative to UTC time. 0 for UTC, 2 for CEST (UTC+2), -1 (UTC-1) +###### Default +```json +0 +``` #### timeFrames ###### Description Array of timeframes that allows to override options based on local time. See example configuration @@ -131,7 +138,6 @@ Array of timeframes that allows to override options based on local time. See exa name: "friendly name", // a friendly name visible in the logs start: "12:00", // timeframe start time : end: "18:00", // timeframe end time : - timezone: 0, // Timezone relative to UTC time. 0 for UTC, 2 for CEST (UTC+2), -1 (UTC-1) overrides: { // options to override automaticVoteStart: false, layerLevelBlacklist: [ "Anvil", "Chora" ] @@ -157,12 +163,12 @@ Array of timeframes that allows to override options based on local time. See exa "voteBroadcastMessage": "✯ MAPVOTE ✯ Vote for the next map by writing in chat the corresponding number!", "logToDiscord": true, "channelID": "112233445566778899", + "timezone": 2, "timeFrames": [ { "name": "follow layer rotation list", "start": "12:00", "end": "18:00", - "timezone": 2, "overrides": { "automaticVoteStart": false } @@ -170,7 +176,6 @@ Array of timeframes that allows to override options based on local time. See exa { "start": "22:00", "end": "02:00", - "timezone": -1, "overrides": { "voteBroadcastMessage": "Late night games? Vote your favourite map!" } diff --git a/mapvote.js b/mapvote.js index 5185eb1..4706d0f 100644 --- a/mapvote.js +++ b/mapvote.js @@ -96,6 +96,11 @@ export default class MapVote extends DiscordBasePlugin { default: '', example: '112233445566778899' }, + timezone: { + required: false, + description: "Timezone relative to UTC time. 0 for UTC, 2 for CEST (UTC+2), -1 (UTC-1) ", + default: 0 + }, timeFrames: { required: false, description: 'Array of timeframes to override options', @@ -142,7 +147,10 @@ export default class MapVote extends DiscordBasePlugin { this.server.on('NEW_GAME', this.onNewGame); this.server.on('CHAT_MESSAGE', this.onChatMessage); this.server.on('PLAYER_DISCONNECTED', this.onPlayerDisconnected); - this.server.on('PLAYER_CONNECTED', () => { setTimeout(this.setSeedingMode, 5000) }); + setTimeout(() => { + this.verbose(1, 'Enabled late listeners.'); + this.server.on('PLAYER_CONNECTED', this.setSeedingMode); + }, 10 * 1000) // wait 10 seconds to be sure to have an updated player list this.verbose(1, 'Map vote was mounted.'); this.verbose(1, "Blacklisted Layers/Levels: " + this.options.layerLevelBlacklist.join(', ')) // await this.checkUpdates(); @@ -178,25 +186,11 @@ export default class MapVote extends DiscordBasePlugin { } async timeframeOptionOverrider() { const orOpt = { ...this.or_options }; - - let tfFilter = function (tf, key, arr) { - const utcDelay = tf.timezone ? parseFloat(tf.timezone) : 0; - const timeNow = new Date(0, 0, 0, new Date().getUTCHours() + utcDelay, new Date().getUTCMinutes()); - this.verbose(1, `Current time (UTC+${utcDelay}) ${timeNow.getHours()}:${timeNow.getMinutes()}`) - - const tfStartSplit = [ parseInt(tf.start.split(':')[ 0 ]), parseInt(tf.start.split(':')[ 1 ]) ]; - const tfEndSplit = [ parseInt(tf.end.split(':')[ 0 ]), parseInt(tf.end.split(':')[ 1 ]) ]; - - const tfStart = new Date(0, 0, 0, ...tfStartSplit) - const tfStart2 = new Date(0, 0, 0, 0, 0) - const tfEnd = new Date(0, 0, 0, ...tfEndSplit) - const tfEnd2 = new Date(0, 0, 0, 24, 0) - return (tfStart <= timeNow && timeNow < tfEnd) || (tfStart > tfEnd && ((tfStart <= timeNow && timeNow < tfEnd2) || (tfStart2 <= timeNow && timeNow < tfEnd))) - } - tfFilter = tfFilter.bind(this); - + const utcDelay = parseFloat(this.options.timezone); + const timeNow = new Date(0, 0, 0, new Date().getUTCHours() + utcDelay, new Date().getUTCMinutes()); + this.verbose(1, `Current time (UTC+${utcDelay}) ${timeNow.toLocaleTimeString().split(':').splice(0, 2).join(':')}`) + const activeTimeframes = orOpt.timeFrames.filter(tfFilter); - let logTimeframe = "Active Time Frames: "; let activeTfIds = []; this.options = { ...this.or_options }; @@ -208,8 +202,17 @@ export default class MapVote extends DiscordBasePlugin { } } this.verbose(1, logTimeframe + activeTfIds.join(', ')); - // this.verbose(1, `Current UTC time: ${timeNow.getHours()}:${timeNow.getMinutes()}`) + function tfFilter(tf, key, arr) { + const tfStartSplit = [ parseInt(tf.start.split(':')[ 0 ]), parseInt(tf.start.split(':')[ 1 ]) ]; + const tfEndSplit = [ parseInt(tf.end.split(':')[ 0 ]), parseInt(tf.end.split(':')[ 1 ]) ]; + + const tfStart = new Date(0, 0, 0, ...tfStartSplit) + const tfStart2 = new Date(0, 0, 0, 0, 0) + const tfEnd = new Date(0, 0, 0, ...tfEndSplit) + const tfEnd2 = new Date(0, 0, 0, 24, 0) + return (tfStart <= timeNow && timeNow < tfEnd) || (tfStart > tfEnd && ((tfStart <= timeNow && timeNow < tfEnd2) || (tfStart2 <= timeNow && timeNow < tfEnd))) + } } async checkUpdates(callback) { const versionN = "1.0.0"