From 71ffc6ba50aa3b5cd41fab27614b7172eac7c4c5 Mon Sep 17 00:00:00 2001 From: Sammy Date: Thu, 15 Jun 2023 22:33:22 +0200 Subject: [PATCH 1/2] use yavin to get random movies --- index.ts | 3 ++- server/configuration.ts | 12 ++++++++- server/events/guildScheduledEventCreate.ts | 6 ++--- server/interfaces.ts | 6 +++++ server/jellyfin/handler.ts | 30 ++++++++-------------- server/structures/client.ts | 1 - 6 files changed, 32 insertions(+), 26 deletions(-) diff --git a/index.ts b/index.ts index 49b529f..30ef40c 100644 --- a/index.ts +++ b/index.ts @@ -5,7 +5,8 @@ import { JellyfinHandler } from "./server/jellyfin/handler" import { attachedImages } from "./server/assets/attachments" const requestId = 'startup' -export const jellyfinHandler = new JellyfinHandler(config) +export const jellyfinHandler = new JellyfinHandler({jellyfinToken: config.bot.workaround_token, jellyfinUrl: config.bot.jellyfin_url, movieCollectionId: config.bot.jf_collection_id, collectionUser: config.bot.jf_user}) +export const yavinJellyfinHandler = new JellyfinHandler({jellyfinToken: config.bot.yavin_jellyfin_token, jellyfinUrl: config.bot.yavin_jellyfin_url, movieCollectionId: config.bot.yavin_collection_id, collectionUser: config.bot.yavin_jellyfin_collection_user}) export const client = new ExtendedClient(jellyfinHandler) diff --git a/server/configuration.ts b/server/configuration.ts index 1ad75d6..181e26b 100644 --- a/server/configuration.ts +++ b/server/configuration.ts @@ -25,6 +25,11 @@ export interface Config { announcement_role: string announcement_channel_id: string jf_collection_id: string + jf_user: string + yavin_collection_id: string + yavin_jellyfin_url: string + yavin_jellyfin_token: string + yavin_jellyfin_collection_user: string } } export const config: Config = { @@ -59,6 +64,11 @@ export const config: Config = { jf_admin_role: process.env.ADMIN_ROLE ?? "", announcement_role: process.env.WATCHPARTY_ANNOUNCEMENT_ROLE ?? "", announcement_channel_id: process.env.CHANNEL_ID ?? "", - jf_collection_id: process.env.JELLYFIN_COLLECTION_ID ?? "" + jf_collection_id: process.env.JELLYFIN_COLLECTION_ID ?? "", + yavin_collection_id: process.env.YAVIN_COLLECTION_ID ?? "", + yavin_jellyfin_url: process.env.YAVIN_JELLYFIN_URL ?? "", + yavin_jellyfin_token: process.env.YAVIN_TOKEN ?? "", + yavin_jellyfin_collection_user: process.env.YAVIN_COLLECTION_USER ?? "", + jf_user: process.env.JELLYFIN_USER ?? "" } } diff --git a/server/events/guildScheduledEventCreate.ts b/server/events/guildScheduledEventCreate.ts index 7d36221..d14721e 100644 --- a/server/events/guildScheduledEventCreate.ts +++ b/server/events/guildScheduledEventCreate.ts @@ -3,11 +3,11 @@ import toDate from "date-fns/fp/toDate"; import { GuildScheduledEvent, Message, MessageCreateOptions, TextChannel } from "discord.js"; import { ScheduledTask, schedule } from "node-cron"; import { v4 as uuid } from "uuid"; -import { client, jellyfinHandler } from "../.."; +import { client, yavinJellyfinHandler } from "../.."; import { closePoll } from "../commands/closepoll"; import { config } from "../configuration"; -import { logger } from "../logger"; import { Maybe } from "../interfaces"; +import { logger } from "../logger"; export const name = 'guildScheduledEventCreate' @@ -24,7 +24,7 @@ export async function execute(event: GuildScheduledEvent) { 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) + const movies = await yavinJellyfinHandler.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 }) diff --git a/server/interfaces.ts b/server/interfaces.ts index e9807d3..84e93b1 100644 --- a/server/interfaces.ts +++ b/server/interfaces.ts @@ -32,4 +32,10 @@ export interface ChangedRoles { addedRoles: Collection removedRoles: Collection } +export interface JellyfinConfig { + jellyfinUrl: string, + jellyfinToken: string, + movieCollectionId: string, + collectionUser: string +} export type PermissionLevel = "VIEWER" | "ADMIN" | "TEMPORARY" diff --git a/server/jellyfin/handler.ts b/server/jellyfin/handler.ts index 7b777d2..a1af178 100644 --- a/server/jellyfin/handler.ts +++ b/server/jellyfin/handler.ts @@ -1,6 +1,5 @@ import { GuildMember } from "discord.js"; -import { Config } from "../configuration"; -import { Maybe, PermissionLevel } from "../interfaces"; +import { JellyfinConfig, Maybe, PermissionLevel } from "../interfaces"; import { logger } from "../logger"; import { CreateUserByNameOperationRequest, DeleteUserRequest, GetItemsRequest, ItemsApi, SystemApi, UpdateUserPasswordOperationRequest, UpdateUserPolicyOperationRequest, UserApi } from "./apis"; import { BaseItemDto, UpdateUserPasswordRequest } from "./models"; @@ -15,34 +14,27 @@ export class JellyfinHandler { private moviesApi: ItemsApi private token: string private authHeader: { headers: { 'X-Emby-Authorization': string } } - private config: Config + private config: JellyfinConfig private serverName = ""; - public async ServerName(): Promise { - if (this.serverName === "") { - const info = await this.systemApi.getSystemInfo(this.authHeader) - this.serverName = info.serverName ?? this.config.bot.jellyfin_url - } - return this.serverName - } - constructor(_config: Config, _userApi?: UserApi, _systemApi?: SystemApi, _itemsApi?: ItemsApi) { + constructor(_config: JellyfinConfig, _userApi?: UserApi, _systemApi?: SystemApi, _itemsApi?: ItemsApi) { this.config = _config - this.token = this.config.bot.jellfin_token + this.token = this.config.jellyfinToken this.authHeader = { headers: { - "X-Emby-Authorization": this.config.bot.workaround_token + "X-Emby-Authorization": this.config.jellyfinToken } } const userApiConfigurationParams: ConfigurationParameters = { - basePath: this.config.bot.jellyfin_url, + basePath: this.config.jellyfinUrl, headers: this.authHeader.headers } const systemApiConfigurationParams: ConfigurationParameters = { - basePath: this.config.bot.jellyfin_url, + basePath: this.config.jellyfinUrl, headers: this.authHeader.headers } const libraryApiConfigurationParams: ConfigurationParameters = { - basePath: this.config.bot.jellyfin_url, + basePath: this.config.jellyfinUrl, headers: this.authHeader.headers } @@ -228,11 +220,9 @@ export class JellyfinHandler { public async getAllMovies(guildId: string, requestId: string): Promise { logger.info("requesting all movies from jellyfin", { guildId, requestId }) - const liloJfUser = await this.getUser({ guild: { id: guildId }, displayName: "lilo" }, requestId) - const searchParams: GetItemsRequest = { - userId: liloJfUser?.id, - parentId: this.config.bot.jf_collection_id // collection ID for all movies + userId: this.config.collectionUser, + parentId: this.config.movieCollectionId // collection ID for all movies } const movies = (await (this.moviesApi.getItems(searchParams))).items?.filter(item => !item.isFolder) // logger.debug(JSON.stringify(movies, null, 2), { guildId: guildId, requestId }) diff --git a/server/structures/client.ts b/server/structures/client.ts index 9ac2c1a..6ecaf6b 100644 --- a/server/structures/client.ts +++ b/server/structures/client.ts @@ -33,7 +33,6 @@ export class ExtendedClient extends Client { Promise.all(promises).then(() => { this.login(config.bot.token) }) - logger.info(`Connected with ${await this.jellyfin.ServerName()}`) } private async importFile(filepath: string): Promise { logger.debug(`Importing ${filepath}`) From 2fae61fc1fb1bc77965816f2eb6f590a90e0cb63 Mon Sep 17 00:00:00 2001 From: Sammy Date: Thu, 15 Jun 2023 22:33:42 +0200 Subject: [PATCH 2/2] change announcement message to specify MOVIE watchparties --- server/commands/announce.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/commands/announce.ts b/server/commands/announce.ts index 85f3b43..ca939b9 100644 --- a/server/commands/announce.ts +++ b/server/commands/announce.ts @@ -67,7 +67,7 @@ async function sendInitialAnnouncement(guildId: string, requestId: string): Prom const body = `[initial] Hey! @everyone! Hier ist der Watchparty Bot vom Hartzarett. -Wir machen in Zukunft regelmäßig Watchparties! Falls du mitmachen möchtest, reagiere einfach auf diesen Post mit 🎫, dann bekommst du automatisch eine Rolle zugewiesen und wirst benachrichtigt sobald es in der Zukunft weitere Watchparties und Filme zum abstimmen gibt. +Wir machen in Zukunft regelmäßig Watchparties in denen wir zusammen Filme gucken! Falls du mitmachen möchtest, reagiere einfach auf diesen Post mit 🎫, dann bekommst du automatisch eine Rolle zugewiesen und wirst benachrichtigt sobald es in der Zukunft weitere Watchparties und Filme zum abstimmen gibt. Für eine Erklärung wie das alles funktioniert mach einfach /mitgucken für eine lange Erklärung am Stück oder /guides wenn du auswählen möchtest wozu du Infos bekommst.`