diff --git a/build.gradle.kts b/build.gradle.kts index cc2006b..9bd7385 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -1,5 +1,4 @@ import com.github.jengelman.gradle.plugins.shadow.tasks.ShadowJar -import org.jetbrains.kotlin.gradle.tasks.KotlinCompile val fruxzAscendVersion: String by project val fruxzStackedVersion: String by project @@ -58,6 +57,14 @@ kotlin { compilerOptions { jvmTarget.set(org.jetbrains.kotlin.gradle.dsl.JvmTarget.JVM_21) apiVersion.set(org.jetbrains.kotlin.gradle.dsl.KotlinVersion.KOTLIN_2_0) - freeCompilerArgs.addAll(listOf("-opt-in=kotlin.RequiresOptIn", "-Xopt-in=dev.kord.common.annotation.KordPreview", "-Xopt-in=dev.kord.common.annotation.KordExperimental", "-Xopt-in=kotlin.time.ExperimentalTime", "-Xopt-in=kotlin.contracts.ExperimentalContracts")) + freeCompilerArgs.addAll( + listOf( + "-opt-in=kotlin.RequiresOptIn", + "-Xopt-in=dev.kord.common.annotation.KordPreview", + "-Xopt-in=dev.kord.common.annotation.KordExperimental", + "-Xopt-in=kotlin.time.ExperimentalTime", + "-Xopt-in=kotlin.contracts.ExperimentalContracts" + ) + ) } } \ No newline at end of file diff --git a/src/main/kotlin/de/themeparkcraft/proxy/ProxyPlugin.kt b/src/main/kotlin/de/themeparkcraft/proxy/ProxyPlugin.kt index 52347f6..717dd81 100644 --- a/src/main/kotlin/de/themeparkcraft/proxy/ProxyPlugin.kt +++ b/src/main/kotlin/de/themeparkcraft/proxy/ProxyPlugin.kt @@ -6,6 +6,7 @@ import com.velocitypowered.api.event.proxy.ProxyInitializeEvent import com.velocitypowered.api.event.proxy.ProxyShutdownEvent import com.velocitypowered.api.plugin.Plugin import com.velocitypowered.api.proxy.ProxyServer +import de.themeparkcraft.proxy.commands.BroadcastCommand import de.themeparkcraft.proxy.commands.HubCommand import de.themeparkcraft.proxy.listener.PingListener import org.slf4j.Logger @@ -21,6 +22,8 @@ class ProxyPlugin @Inject constructor(val server: ProxyServer, private val logge companion object { lateinit var instance: ProxyPlugin + val PREFIX: String = + "ThemeParkCraft " } init { @@ -35,10 +38,21 @@ class ProxyPlugin @Inject constructor(val server: ProxyServer, private val logge val eventManager = server.eventManager commandManager.register( - commandManager.metaBuilder("hub").aliases("lobby", "l", "h").build(), + commandManager + .metaBuilder("hub") + .aliases("lobby", "l", "h") + .build(), HubCommand(server) ) + commandManager.register( + commandManager + .metaBuilder("broadcast") + .aliases("bc") + .build(), + BroadcastCommand(server) + ) + eventManager.register(this, PingListener()) } diff --git a/src/main/kotlin/de/themeparkcraft/proxy/commands/BroadcastCommand.kt b/src/main/kotlin/de/themeparkcraft/proxy/commands/BroadcastCommand.kt new file mode 100644 index 0000000..1eccab4 --- /dev/null +++ b/src/main/kotlin/de/themeparkcraft/proxy/commands/BroadcastCommand.kt @@ -0,0 +1,53 @@ +package de.themeparkcraft.proxy.commands + +import com.velocitypowered.api.command.SimpleCommand +import com.velocitypowered.api.proxy.Player +import com.velocitypowered.api.proxy.ProxyServer +import de.themeparkcraft.proxy.ProxyPlugin +import de.themeparkcraft.proxy.extensions.text + +/** + * Represents a command that broadcasts a message to all players on the server. + * + * @param proxy The proxy server instance. + */ +class BroadcastCommand(private val proxy: ProxyServer) : SimpleCommand { + + /** + * Executes the broadcast command by sending a message to all players on the server. + * + * @param invocation The command invocation. + */ + override fun execute(invocation: SimpleCommand.Invocation?) { + if (invocation == null) return + + val message = invocation.arguments().joinToString(" ") + val textComp = text("${ProxyPlugin.PREFIX}$message") + + proxy.allPlayers.forEach { it.sendMessage(textComp) } + } + + /** + * Returns a list of suggestions for the given command invocation. + * + * @param invocation The command invocation. + * @return The list of suggestions. + */ + override fun suggest(invocation: SimpleCommand.Invocation?): MutableList { + return mutableListOf() + } + + /** + * Checks if the invocation source has the permission "ventureproxy.broadcast". + * + * @param invocation The invocation representing the command execution. + * @return true if the source has the permission, false otherwise. + */ + override fun hasPermission(invocation: SimpleCommand.Invocation?): Boolean { + if (invocation == null) return true + if (invocation.source() !is Player) return true + + val player = invocation.source() as Player + return player.hasPermission("ventureproxy.broadcast") + } +} \ No newline at end of file diff --git a/src/main/kotlin/de/themeparkcraft/proxy/listener/PingListener.kt b/src/main/kotlin/de/themeparkcraft/proxy/listener/PingListener.kt index 8479540..1fdb18d 100644 --- a/src/main/kotlin/de/themeparkcraft/proxy/listener/PingListener.kt +++ b/src/main/kotlin/de/themeparkcraft/proxy/listener/PingListener.kt @@ -29,8 +29,12 @@ class PingListener { val connection = connection.virtualHost.getOrNull() ?: return try { - when(connection.hostString) { - "blockventuremc.net" -> response.favicon(Favicon("")) + when (connection.hostString) { + "blockventuremc.net" -> response.favicon( + Favicon( + "" + ) + ) } } catch (e: Exception) {