82 lines
4.1 KiB
TypeScript
82 lines
4.1 KiB
TypeScript
import { GuildScheduledEvent, Message, TextChannel } from "discord.js";
|
||
import { ScheduledTask, schedule } from "node-cron";
|
||
import { v4 as uuid } from "uuid";
|
||
import { jellyfinHandler } from "../..";
|
||
import { closePoll } from "../commands/closepoll";
|
||
import { config } from "../configuration";
|
||
import { logger } from "../logger";
|
||
|
||
|
||
export const name = 'guildScheduledEventCreate'
|
||
|
||
export enum Emotes { "1️⃣", "2️⃣", "3️⃣", "4️⃣", "5️⃣", "6️⃣", "7️⃣", "8️⃣", "9️⃣", "🔟" }
|
||
|
||
export let task: ScheduledTask | undefined
|
||
|
||
export async function execute(event: GuildScheduledEvent) {
|
||
const requestId = uuid()
|
||
logger.debug(`New event created: ${JSON.stringify(event, null, 2)}`, { guildId: event.guildId, requestId })
|
||
|
||
if (event.name.toLowerCase().includes("!nextwp")) {
|
||
logger.info("Event was a placeholder event to start a new watchparty and voting. Creating vote!", { guildId: event.guildId, requestId })
|
||
logger.debug("Renaming event", { guildId: event.guildId, requestId })
|
||
event.edit({ name: "Watchparty - Voting offen" })
|
||
const movies = await jellyfinHandler.getRandomMovies(5, event.guildId, requestId)
|
||
|
||
logger.info(`Got ${movies.length} random movies. Creating voting`, { guildId: event.guildId, requestId })
|
||
logger.debug(`Movies: ${JSON.stringify(movies.map(movie => movie.name))}`, { guildId: event.guildId, requestId })
|
||
|
||
const channel: TextChannel = <TextChannel>(await event.guild?.channels.fetch())?.filter(channel => channel!.id === config.bot.announcement_channel_id).map((value, _) => value)[0] //todo: needs to be done less sketchy
|
||
logger.debug(`Found channel ${JSON.stringify(channel, null, 2)}`)
|
||
|
||
let message = "[Abstimmung]\nEs gibt eine neue Abstimmung für die nächste Watchparty! Stimme hierunter für den nächsten Film ab!\n"
|
||
|
||
for (let i = 0; i < movies.length; i++) {
|
||
message = message.concat(Emotes[i]).concat(": ").concat(movies[i].name!).concat("\n")
|
||
}
|
||
|
||
const sentMessage: Message<true> = await (await channel.fetch()).send(message)
|
||
|
||
for (let i = 0; i < movies.length; i++) {
|
||
sentMessage.react(Emotes[i])
|
||
}
|
||
|
||
if(!task){
|
||
task = schedule("0 * * * * *", () => checkForPollsToClose(event))
|
||
}
|
||
|
||
// sentMessage.pin() //todo: uncomment when bot has permission to pin messages. Also update closepoll.ts to only fetch pinned messages
|
||
}
|
||
}
|
||
|
||
async function checkForPollsToClose(event: GuildScheduledEvent): Promise<void> {
|
||
const requestId = uuid()
|
||
logger.info(`Automatic check for poll closing.`, { guildId: event.guildId, requestId })
|
||
if (!event.guild) {
|
||
logger.error("No guild in event. Cancelling.", { guildId: event.guildId, requestId })
|
||
return
|
||
}
|
||
//refetch event in case the time changed or the poll is already closed
|
||
const events = (await event.guild.scheduledEvents.fetch())
|
||
.filter(event => event.name.toLowerCase().includes("voting offen"))
|
||
.map((value, _) => value)
|
||
|
||
if(!events || events.length <= 0) {
|
||
logger.info("Did not find any events. Cancelling", { guildId: event.guildId, requestId })
|
||
return
|
||
} else if(events.length > 1) {
|
||
logger.error(`More than one event found. Don't know which one is the right one :( Events: ${JSON.stringify(events, null, 2)}`, { guildId: event.guildId, requestId })
|
||
return
|
||
}
|
||
const updatedEvent = events[0] //add two hours because of different timezones in discord api and Date.now()
|
||
if(!updatedEvent.scheduledStartTimestamp) {
|
||
logger.error("Event does not have a scheduled start time. Cancelling", { guildId: event.guildId, requestId })
|
||
return
|
||
}
|
||
if ((updatedEvent.scheduledStartTimestamp - Date.now()) <= (1000 * 60 * 60 * 24 * 2)) {
|
||
logger.info("Less than two days until event. Closing poll", { guildId: event.guildId, requestId })
|
||
closePoll(event.guild, requestId)
|
||
} else {
|
||
logger.info(`ScheduledStart: ${updatedEvent.scheduledStartTimestamp}. Now: ${Date.now()}`, { guildId: event.guildId, requestId })
|
||
}
|
||
} |