From 1246aeab9a0dbe139d4c28180031381c979993a8 Mon Sep 17 00:00:00 2001 From: pixel Date: Sat, 28 Dec 2024 09:02:55 +0100 Subject: [PATCH] trying to make playback work with user-defined tracks --- bin/jana.dart | 23 +++++++++++++---------- pubspec.yaml | 2 +- 2 files changed, 14 insertions(+), 11 deletions(-) diff --git a/bin/jana.dart b/bin/jana.dart index 2f257e8..19029f8 100644 --- a/bin/jana.dart +++ b/bin/jana.dart @@ -15,6 +15,7 @@ const internal = Snowflake(826983242493591592); const news = Snowflake(551908144641605642); const twinkspotting = Snowflake(1292515671439315027); const priv = [Snowflake(1310347280406151168), Snowflake(1285544156185366559)]; +const admins = Snowflake(569251424370819088); final yt = YoutubePoll(); final startupTime = DateTime.now().subtract(Duration(days: 1)); const ytChannels = <(String, bool, Snowflake)>[ @@ -80,7 +81,7 @@ void main(List argv) async { var lastLogCount = 1; Logger.root.onRecord.listen((rec) => logMutex.protect(() async { // TODO: if > 3900 dont send? - final ping = rec.level >= Level.WARNING ? ' <@231670489779666944>' : ''; + final ping = rec.level >= Level.WARNING ? ' <@&$admins>' : ''; var msg = '[${rec.level.name}] [${rec.loggerName}] ${rec.message}$ping'; if (rec.error != null) msg += '\nError: ${rec.error}'; if (rec.stackTrace != null) { @@ -123,18 +124,20 @@ void main(List argv) async { if (lavalink != null) '!play': () async { if (!member.roleIds.any(priv.contains)) throw 'Not authorized'; - //final file = await msg.attachments - // .firstWhere((a) => a.url.path.endsWith('.mp3')) - // .fetch(); - //final voice = - // await bot.voice.fetchVoiceState(event.guildId!, member.id); + final sources = ['https://gock.dev/email_empfangen.flac']; + if (member.roleIds.contains(admins)) { + sources.addAll(msg.attachments + .where((a) => a.url.path.endsWith('.mp3')) + .map((a) => a.url.toString())); + sources.addAll(args); + } final voice = event.guild!.voiceStates[member.id]!; final vc = await voice.channel!.fetch() as VoiceChannel; final player = await vc.connectLavalink(); - await player.play(await lavalink - .loadTrack('https://gock.dev/email_empfangen.flac') - .then((v) => v.data)); - player.onTrackEnd.listen((e) => player.disconnect()); + await player.playIdentifier(sources.removeAt(0)); + player.onTrackEnd.listen((_) => sources.isNotEmpty + ? player.playIdentifier(sources.removeAt(0)) + : player.disconnect()); }, }; diff --git a/pubspec.yaml b/pubspec.yaml index 8f8ee32..e1c9bb8 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,6 +1,6 @@ name: jana description: A Discord bot -version: 2.0.0-beta.2 +version: 2.0.0-beta.3 homepage: https://github.com/chrissxMedia/jana environment: