diff --git a/README.md b/README.md
index e0f3524..2d87a9b 100644
--- a/README.md
+++ b/README.md
@@ -26,6 +26,7 @@ A Discord music bot, written in Kotlin using the kord library.
- skip -- Skip to the next song
- queue -- Show what songs are next up
- nowplaying -- Show what is currently playing
+ - seek -- Seek to a specific time in the song
- Features
- Button Controller -- You can control the currently playing music using buttons.
diff --git a/build.gradle.kts b/build.gradle.kts
index cef6c28..f31be78 100644
--- a/build.gradle.kts
+++ b/build.gradle.kts
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
import org.jetbrains.gradle.ext.ProjectSettings
@@ -33,7 +32,7 @@ val ownerID = 372703841151614976L
group = "net.moonleay.botendo"
version = System.getenv("CI_COMMIT_TAG")?.let { "$it-${System.getenv("CI_COMMIT_SHORT_SHA")}-prod" }
?: System.getenv("CI_COMMIT_SHORT_SHA")?.let { "$it-dev" }
- ?: "6.5.3"
+ ?: "6.5.5"
val kordext_ver = "1.7.1-SNAPSHOT"
val lavakord_ver = "6.0.0"
diff --git a/gradle.properties b/gradle.properties
index 6ff0886..b2ec467 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -15,5 +15,4 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
#
-#
kotlin.code.style=official
diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar
index 249e583..d64cd49 100644
Binary files a/gradle/wrapper/gradle-wrapper.jar and b/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
index 85958c5..22d4fe0 100644
--- a/gradle/wrapper/gradle-wrapper.properties
+++ b/gradle/wrapper/gradle-wrapper.properties
@@ -15,9 +15,11 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
#
-#
+
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-bin.zip
+distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
+networkTimeout=10000
+validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists
diff --git a/gradlew b/gradlew
index 10c8ca9..3052411 100755
--- a/gradlew
+++ b/gradlew
@@ -17,7 +17,6 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
#
-#
##############################################################################
#
@@ -58,7 +57,7 @@
# Darwin, MinGW, and NonStop.
#
# (3) This script is generated from the Groovy template
-# https://github.com/gradle/gradle/blob/master/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
+# https://github.com/gradle/gradle/blob/HEAD/subprojects/plugins/src/main/resources/org/gradle/api/internal/plugins/unixStartScript.txt
# within the Gradle project.
#
# You can find Gradle at https://github.com/gradle/gradle/.
@@ -83,13 +82,11 @@ do
esac
done
-APP_HOME=$( cd "${APP_HOME:-./}" && pwd -P ) || exit
-
-APP_NAME="Gradle"
+# This is normally unused
+# shellcheck disable=SC2034
APP_BASE_NAME=${0##*/}
-
-# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
-DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
+# Discard cd standard output in case $CDPATH is set (https://github.com/gradle/gradle/issues/25036)
+APP_HOME=$( cd "${APP_HOME:-./}" > /dev/null && pwd -P ) || exit
# Use the maximum available, or set MAX_FD != -1 to use that value.
MAX_FD=maximum
@@ -136,22 +133,29 @@ location of your Java installation."
fi
else
JAVACMD=java
- which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
+ if ! command -v java >/dev/null 2>&1
+ then
+ die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
Please set the JAVA_HOME variable in your environment to match the
location of your Java installation."
+ fi
fi
# Increase the maximum file descriptors if we can.
if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
case $MAX_FD in #(
max*)
+ # In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC2039,SC3045
MAX_FD=$( ulimit -H -n ) ||
warn "Could not query maximum file descriptor limit"
esac
case $MAX_FD in #(
'' | soft) :;; #(
*)
+ # In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
+ # shellcheck disable=SC2039,SC3045
ulimit -n "$MAX_FD" ||
warn "Could not set maximum file descriptor limit to $MAX_FD"
esac
@@ -196,11 +200,15 @@ if "$cygwin" || "$msys" ; then
done
fi
-# Collect all arguments for the java command;
-# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
-# shell script including quotes and variable substitutions, so put them in
-# double quotes to make sure that they get re-expanded; and
-# * put everything else in single quotes, so that it's not re-expanded.
+
+# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
+DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
+
+# Collect all arguments for the java command:
+# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
+# and any embedded shellness will be escaped.
+# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
+# treated as '${Hostname}' itself on the command line.
set -- \
"-Dorg.gradle.appname=$APP_BASE_NAME" \
@@ -208,6 +216,12 @@ set -- \
org.gradle.wrapper.GradleWrapperMain \
"$@"
+# Stop when "xargs" is not available.
+if ! command -v xargs >/dev/null 2>&1
+then
+ die "xargs is not available"
+fi
+
# Use "xargs" to parse quoted args.
#
# With -n1 it outputs one arg per line, with the quotes and backslashes removed.
diff --git a/gradlew.bat b/gradlew.bat
index 107acd3..93e3f59 100644
--- a/gradlew.bat
+++ b/gradlew.bat
@@ -14,7 +14,7 @@
@rem limitations under the License.
@rem
-@if "%DEBUG%" == "" @echo off
+@if "%DEBUG%"=="" @echo off
@rem ##########################################################################
@rem
@rem Gradle startup script for Windows
@@ -25,7 +25,8 @@
if "%OS%"=="Windows_NT" setlocal
set DIRNAME=%~dp0
-if "%DIRNAME%" == "" set DIRNAME=.
+if "%DIRNAME%"=="" set DIRNAME=.
+@rem This is normally unused
set APP_BASE_NAME=%~n0
set APP_HOME=%DIRNAME%
@@ -40,7 +41,7 @@ if defined JAVA_HOME goto findJavaFromJavaHome
set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
-if "%ERRORLEVEL%" == "0" goto execute
+if %ERRORLEVEL% equ 0 goto execute
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
@@ -75,13 +76,15 @@ set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar
:end
@rem End local scope for the variables with windows NT shell
-if "%ERRORLEVEL%"=="0" goto mainEnd
+if %ERRORLEVEL% equ 0 goto mainEnd
:fail
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of
rem the _cmd.exe /c_ return code!
-if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1
-exit /b 1
+set EXIT_CODE=%ERRORLEVEL%
+if %EXIT_CODE% equ 0 set EXIT_CODE=1
+if not ""=="%GRADLE_EXIT_CONSOLE%" exit %EXIT_CODE%
+exit /b %EXIT_CODE%
:mainEnd
if "%OS%"=="Windows_NT" endlocal
diff --git a/settings.gradle.kts b/settings.gradle.kts
index 7a3ef44..3934113 100644
--- a/settings.gradle.kts
+++ b/settings.gradle.kts
@@ -1,20 +1,19 @@
/*
- * Botendo
- * Copyright (C) 2023 limited_dev
+ * Botendo
+ * Copyright (C) 2023 moonleay
*
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
*
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
*
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see .
*/
rootProject.name = "Botendo"
diff --git a/src/main/kotlin/net/moonleay/botendo/Bot.kt b/src/main/kotlin/net/moonleay/botendo/Bot.kt
index 73545fc..ca3bb19 100644
--- a/src/main/kotlin/net/moonleay/botendo/Bot.kt
+++ b/src/main/kotlin/net/moonleay/botendo/Bot.kt
@@ -14,25 +14,31 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo
import com.kotlindiscord.kord.extensions.ExtensibleBot
import dev.kord.common.Color
+import dev.kord.common.entity.Snowflake
+import dev.kord.core.behavior.getChannelOf
import dev.kord.core.behavior.interaction.response.respond
+import dev.kord.core.entity.channel.VoiceChannel
import dev.kord.core.event.interaction.ButtonInteractionCreateEvent
+import dev.kord.core.event.user.VoiceStateUpdateEvent
import dev.kord.core.on
import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.LavaKord
+import dev.schlaubi.lavakord.audio.Link
+import dev.schlaubi.lavakord.kord.getLink
import dev.schlaubi.lavakord.kord.lavakord
+import kotlinx.coroutines.flow.count
import net.moonleay.botendo.data.CredentialManager
import net.moonleay.botendo.extensions.music.*
+import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.extensions.util.InfoExtension
import net.moonleay.botendo.util.Logger
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
object Bot {
//The kord object gets set at app launch
@@ -69,7 +75,7 @@ object Bot {
}
this.presence {
- this.streaming("music", "https://twitch.tv/limited_dev")
+ this.streaming("music", "https://twitch.tv/moonleaytv")
}
}
@@ -91,6 +97,7 @@ object Bot {
b.onInteraction(response, g, u)
return@on
}
+ // Button not found
response.respond {
this.embed {
this.color = Color(0xE0311A)
@@ -103,6 +110,34 @@ object Bot {
}
}
+ // Allow the bot to leave the VC if there are no users in the VC
+ bot.kordRef.on {
+ if (this.state.userId == bot.kordRef.selfId) {
+ // Ignore self
+ return@on
+ }
+ val g = this.state.getGuild().asGuild()
+ val link = lava.getLink(g.id)
+ if (link.state != Link.State.CONNECTED) {
+ // Ignore if not connected
+ return@on
+ }
+ val myChannel = link.lastChannelId!!
+ if (g.getChannelOrNull(Snowflake(myChannel)) == null) {
+ // Ignore if channel cannot be found
+ return@on
+ }
+ val ch = g.getChannelOf(Snowflake(myChannel))
+ if (ch.voiceStates.count() > 1) {
+ // Ignore if there are other users in the channel
+ return@on
+ }
+ // Stop playing if there are no users in the channel
+ val pl = MusicManager.getMusicManager(g)!!.pl
+ pl.stopTrack()
+ link.destroy()
+ }
+
//Start the bot
bot.start()
}
diff --git a/src/main/kotlin/net/moonleay/botendo/Main.kt b/src/main/kotlin/net/moonleay/botendo/Main.kt
index 882f7fb..0555150 100644
--- a/src/main/kotlin/net/moonleay/botendo/Main.kt
+++ b/src/main/kotlin/net/moonleay/botendo/Main.kt
@@ -14,14 +14,15 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo
+import net.moonleay.botendo.util.Logger
+
///Show the splash and launch the Bot
-suspend fun main() {
+suspend fun main(args: Array) {
println(
"M#\"\"\"\"\"\"\"'M dP dP \n" +
"## mmmm. `M 88 88 \n" +
@@ -33,5 +34,9 @@ suspend fun main() {
" "
)
println("Bot v.${net.moonleay.botendo.build.BuildConstants.version}, Kord Extensions v.${net.moonleay.botendo.build.BuildConstants.kordVersion}, LavaKord v.${net.moonleay.botendo.build.BuildConstants.lavaVersion}, Coroutines v.${net.moonleay.botendo.build.BuildConstants.coroutinesVersion}")
+ if(args.isEmpty() || args[0] != "--debug") {
+ Logger.out("Waiting 10 seconds for Lavalink to start...")
+ Thread.sleep(10000)
+ }
Bot.start()
}
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/Button.kt b/src/main/kotlin/net/moonleay/botendo/buttons/Button.kt
index 40b55ec..e0c10ef 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/Button.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/Button.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/ButtonManager.kt b/src/main/kotlin/net/moonleay/botendo/buttons/ButtonManager.kt
index 512dcbb..3ab406e 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/ButtonManager.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/ButtonManager.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/music/PauseButton.kt b/src/main/kotlin/net/moonleay/botendo/buttons/music/PauseButton.kt
index aa6f314..a03ee51 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/music/PauseButton.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/music/PauseButton.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons.music
@@ -27,12 +26,10 @@ import dev.kord.core.entity.User
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
import dev.kord.rest.builder.message.embed
-import dev.kord.rest.builder.message.modify.actionRow
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.ButtonUtil
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
class PauseButton : net.moonleay.botendo.buttons.Button("btn.music.pause") {
override suspend fun onInteraction(
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/music/QueueButton.kt b/src/main/kotlin/net/moonleay/botendo/buttons/music/QueueButton.kt
index 291a663..c786818 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/music/QueueButton.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/music/QueueButton.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons.music
@@ -27,13 +26,11 @@ import dev.kord.core.entity.User
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
import dev.kord.rest.builder.message.embed
-import dev.kord.rest.builder.message.modify.actionRow
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.ButtonUtil
import net.moonleay.botendo.util.MessageUtil
import net.moonleay.botendo.util.TimeUtil
-import net.moonleay.botendo.util.UserUtil
class QueueButton : net.moonleay.botendo.buttons.Button("btn.music.queue") {
override suspend fun onInteraction(
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/music/RepeatButton.kt b/src/main/kotlin/net/moonleay/botendo/buttons/music/RepeatButton.kt
index 8de589f..462f207 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/music/RepeatButton.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/music/RepeatButton.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons.music
@@ -27,12 +26,10 @@ import dev.kord.core.entity.User
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
import dev.kord.rest.builder.message.embed
-import dev.kord.rest.builder.message.modify.actionRow
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.ButtonUtil
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
class RepeatButton : net.moonleay.botendo.buttons.Button("btn.music.repeat") {
override suspend fun onInteraction(
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/music/SkipButton.kt b/src/main/kotlin/net/moonleay/botendo/buttons/music/SkipButton.kt
index 32cc50e..8f04ea1 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/music/SkipButton.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/music/SkipButton.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons.music
@@ -28,10 +27,12 @@ import dev.kord.core.entity.User
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
import dev.kord.rest.builder.message.embed
-import dev.kord.rest.builder.message.modify.actionRow
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
-import net.moonleay.botendo.util.*
+import net.moonleay.botendo.util.ButtonUtil
+import net.moonleay.botendo.util.MessageUtil
+import net.moonleay.botendo.util.TimeUtil
+import net.moonleay.botendo.util.UrlUtil
class SkipButton : net.moonleay.botendo.buttons.Button("btn.music.skip") {
override suspend fun onInteraction(
diff --git a/src/main/kotlin/net/moonleay/botendo/buttons/music/StopButton.kt b/src/main/kotlin/net/moonleay/botendo/buttons/music/StopButton.kt
index d1cf8c0..eb1a213 100644
--- a/src/main/kotlin/net/moonleay/botendo/buttons/music/StopButton.kt
+++ b/src/main/kotlin/net/moonleay/botendo/buttons/music/StopButton.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.buttons.music
@@ -28,7 +27,6 @@ import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
class StopButton : net.moonleay.botendo.buttons.Button("btn.music.stop") {
override suspend fun onInteraction(
diff --git a/src/main/kotlin/net/moonleay/botendo/data/CredentialManager.kt b/src/main/kotlin/net/moonleay/botendo/data/CredentialManager.kt
index 63fc538..23ca661 100644
--- a/src/main/kotlin/net/moonleay/botendo/data/CredentialManager.kt
+++ b/src/main/kotlin/net/moonleay/botendo/data/CredentialManager.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.data
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/NowPlayingExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/NowPlayingExtension.kt
index 1b24159..de60cde 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/NowPlayingExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/NowPlayingExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -24,12 +23,14 @@ import com.kotlindiscord.kord.extensions.extensions.publicSlashCommand
import dev.kord.common.Color
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
-import dev.kord.rest.builder.message.create.actionRow
import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import dev.schlaubi.lavakord.kord.getLink
import net.moonleay.botendo.extensions.music.components.MusicManager
-import net.moonleay.botendo.util.*
+import net.moonleay.botendo.util.ButtonUtil
+import net.moonleay.botendo.util.MessageUtil
+import net.moonleay.botendo.util.TimeUtil
+import net.moonleay.botendo.util.UrlUtil
class NowPlayingExtension : Extension() {
override val name = "nowplaying"
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/PlayExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/PlayExtension.kt
index b22eade..7342c14 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/PlayExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/PlayExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -25,6 +24,7 @@ import dev.kord.common.Color
import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import dev.schlaubi.lavakord.kord.getLink
+import net.moonleay.botendo.Bot
import net.moonleay.botendo.extensions.music.components.LinkArguments
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.MessageUtil
@@ -41,7 +41,7 @@ class PlayExtension : Extension() {
description = "Play music"
this.action {
val guildId = this.guild!!.id
- val link = net.moonleay.botendo.Bot.lava.getLink(guildId)
+ val link = Bot.lava.getLink(guildId)
val u = this.user
val vcsUser = u.asMember(guildId).getVoiceStateOrNull()
if (vcsUser == null) {
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/QueueExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/QueueExtension.kt
index 0d7029c..f63078a 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/QueueExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/QueueExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -23,16 +22,13 @@ import com.kotlindiscord.kord.extensions.extensions.Extension
import com.kotlindiscord.kord.extensions.extensions.publicSlashCommand
import dev.kord.common.Color
import dev.kord.rest.builder.component.ActionRowBuilder
-import dev.kord.rest.builder.message.EmbedBuilder.Limits.title
import dev.kord.rest.builder.message.actionRow
-import dev.kord.rest.builder.message.create.actionRow
import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.ButtonUtil
import net.moonleay.botendo.util.MessageUtil
import net.moonleay.botendo.util.TimeUtil
-import net.moonleay.botendo.util.UserUtil
class QueueExtension : Extension() {
override val name = "queue"
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/SeekExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/SeekExtension.kt
index 2b33d20..f5bfb34 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/SeekExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/SeekExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -28,7 +27,10 @@ import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.extensions.music.components.SeekArguments
-import net.moonleay.botendo.util.*
+import net.moonleay.botendo.util.ButtonUtil
+import net.moonleay.botendo.util.MessageUtil
+import net.moonleay.botendo.util.TimeUtil
+import net.moonleay.botendo.util.UrlUtil
class SeekExtension : Extension() {
override val name = "seek"
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/SkipExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/SkipExtension.kt
index 12115e0..e11cdc6 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/SkipExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/SkipExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -24,11 +23,13 @@ import com.kotlindiscord.kord.extensions.extensions.publicSlashCommand
import dev.kord.common.Color
import dev.kord.rest.builder.component.ActionRowBuilder
import dev.kord.rest.builder.message.actionRow
-import dev.kord.rest.builder.message.create.actionRow
import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import net.moonleay.botendo.extensions.music.components.MusicManager
-import net.moonleay.botendo.util.*
+import net.moonleay.botendo.util.ButtonUtil
+import net.moonleay.botendo.util.MessageUtil
+import net.moonleay.botendo.util.TimeUtil
+import net.moonleay.botendo.util.UrlUtil
class SkipExtension : Extension() {
override val name = "skip"
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/StopExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/StopExtension.kt
index 6a6b117..5c0722a 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/StopExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/StopExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -27,7 +26,6 @@ import dev.schlaubi.lavakord.audio.Link
import dev.schlaubi.lavakord.kord.getLink
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
class StopExtension : Extension() {
override val name = "stop"
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/UpsertExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/UpsertExtension.kt
index 56fc44d..f2d90d7 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/UpsertExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/UpsertExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music
@@ -28,7 +27,6 @@ import dev.schlaubi.lavakord.kord.getLink
import net.moonleay.botendo.extensions.music.components.LinkArguments
import net.moonleay.botendo.extensions.music.components.MusicManager
import net.moonleay.botendo.util.MessageUtil
-import net.moonleay.botendo.util.UserUtil
class UpsertExtension : Extension() {
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/GuildTrackScheduler.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/GuildTrackScheduler.kt
index e3471fc..ed90f17 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/GuildTrackScheduler.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/GuildTrackScheduler.kt
@@ -14,15 +14,14 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music.components
-import dev.arbjerg.lavalink.protocol.v4.LoadResult
import dev.arbjerg.lavalink.protocol.v4.Track
import dev.schlaubi.lavakord.audio.*
import dev.schlaubi.lavakord.audio.player.Player
+import net.moonleay.botendo.Bot
import net.moonleay.botendo.util.Logger
import java.util.concurrent.BlockingQueue
import java.util.concurrent.LinkedBlockingQueue
@@ -97,7 +96,7 @@ class GuildTrackScheduler(val pl: Player) {
return
}
Logger.out("Track has ended; Playing next...")
- playNext(net.moonleay.botendo.Bot.lava.getLink(e.guildId))
+ playNext(Bot.lava.getLink(e.guildId))
}
}
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/LinkArguments.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/LinkArguments.kt
index 8c0c065..406187f 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/LinkArguments.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/LinkArguments.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music.components
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/MusicManager.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/MusicManager.kt
index 534c0fb..faaef75 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/MusicManager.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/MusicManager.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music.components
@@ -31,11 +30,18 @@ import dev.kord.rest.builder.message.embed
import dev.schlaubi.lavakord.audio.Link
import dev.schlaubi.lavakord.audio.player.Player
import dev.schlaubi.lavakord.rest.loadItem
-import net.moonleay.botendo.util.*
+import net.moonleay.botendo.util.ButtonUtil
+import net.moonleay.botendo.util.MessageUtil
+import net.moonleay.botendo.util.TimeUtil
+import net.moonleay.botendo.util.UrlUtil
object MusicManager {
private var musicManagerMap: MutableMap = mutableMapOf()
+ fun getMusicManager(guild: Guild): GuildTrackScheduler? {
+ return musicManagerMap[guild.id]
+ }
+
fun getGuildTrackScheduler(guild: Guild, player: Player): GuildTrackScheduler {
return musicManagerMap.computeIfAbsent(guild.id) {
GuildTrackScheduler(player)
@@ -181,6 +187,10 @@ object MusicManager {
}
is LoadResult.NoMatches -> {
+ if (gts.isEmpty() && player.playingTrack == null) {
+ player.stopTrack()
+ link.destroy()
+ }
if (!silent)
ctx.respond {
this.embed {
@@ -194,6 +204,10 @@ object MusicManager {
}
}
is LoadResult.LoadFailed -> {
+ if (gts.isEmpty() && player.playingTrack == null) {
+ player.stopTrack()
+ link.destroy()
+ }
if (!silent)
ctx.respond {
this.embed {
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/SeekArguments.kt b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/SeekArguments.kt
index d5d0c61..852ea7b 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/music/components/SeekArguments.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/music/components/SeekArguments.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.music.components
diff --git a/src/main/kotlin/net/moonleay/botendo/extensions/util/InfoExtension.kt b/src/main/kotlin/net/moonleay/botendo/extensions/util/InfoExtension.kt
index 57e0b04..a315e2a 100644
--- a/src/main/kotlin/net/moonleay/botendo/extensions/util/InfoExtension.kt
+++ b/src/main/kotlin/net/moonleay/botendo/extensions/util/InfoExtension.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.extensions.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/ButtonUtil.kt b/src/main/kotlin/net/moonleay/botendo/util/ButtonUtil.kt
index c3b5ce6..c598096 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/ButtonUtil.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/ButtonUtil.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/Logger.kt b/src/main/kotlin/net/moonleay/botendo/util/Logger.kt
index dde0ed5..3e2ee34 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/Logger.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/Logger.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/MessageUtil.kt b/src/main/kotlin/net/moonleay/botendo/util/MessageUtil.kt
index 839dc32..4fc4f44 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/MessageUtil.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/MessageUtil.kt
@@ -14,17 +14,11 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
-import com.kotlindiscord.kord.extensions.commands.Arguments
-import com.kotlindiscord.kord.extensions.commands.application.slash.PublicSlashCommandContext
-import com.kotlindiscord.kord.extensions.components.forms.ModalForm
-import dev.kord.common.Color
import dev.kord.core.behavior.UserBehavior
-import dev.kord.rest.builder.message.EmbedBuilder
import java.time.LocalDateTime
import java.time.format.DateTimeFormatter
diff --git a/src/main/kotlin/net/moonleay/botendo/util/Status.kt b/src/main/kotlin/net/moonleay/botendo/util/Status.kt
index cc39a5d..161e50c 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/Status.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/Status.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/TimeUtil.kt b/src/main/kotlin/net/moonleay/botendo/util/TimeUtil.kt
index 4cbc381..534234d 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/TimeUtil.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/TimeUtil.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/UrlUtil.kt b/src/main/kotlin/net/moonleay/botendo/util/UrlUtil.kt
index a922c1a..33a1275 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/UrlUtil.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/UrlUtil.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/kotlin/net/moonleay/botendo/util/UserUtil.kt b/src/main/kotlin/net/moonleay/botendo/util/UserUtil.kt
index 3925ad6..8b14825 100644
--- a/src/main/kotlin/net/moonleay/botendo/util/UserUtil.kt
+++ b/src/main/kotlin/net/moonleay/botendo/util/UserUtil.kt
@@ -14,7 +14,6 @@
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
- *
*/
package net.moonleay.botendo.util
diff --git a/src/main/resources/simplelogger.properties b/src/main/resources/simplelogger.properties
index 6378344..3cf67d8 100644
--- a/src/main/resources/simplelogger.properties
+++ b/src/main/resources/simplelogger.properties
@@ -15,4 +15,3 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
#
-#