aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--settings.gradle1
-rw-r--r--spark-common/build.gradle7
-rw-r--r--spark-velocity/build.gradle4
-rw-r--r--spark-velocity2/build.gradle43
-rw-r--r--spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityCommandSender.java66
-rw-r--r--spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityPlatformInfo.java53
-rw-r--r--spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocitySparkPlugin.java115
7 files changed, 285 insertions, 4 deletions
diff --git a/settings.gradle b/settings.gradle
index 239b70a..b47da02 100644
--- a/settings.gradle
+++ b/settings.gradle
@@ -16,6 +16,7 @@ include (
'spark-bukkit',
'spark-bungeecord',
'spark-velocity',
+ 'spark-velocity2',
'spark-sponge',
'spark-sponge8',
'spark-forge',
diff --git a/spark-common/build.gradle b/spark-common/build.gradle
index 8530a0e..e07647d 100644
--- a/spark-common/build.gradle
+++ b/spark-common/build.gradle
@@ -37,8 +37,11 @@ processResources {
protobuf {
protoc {
- artifact = 'com.google.protobuf:protoc:3.15.6'
- //path = '/opt/homebrew/bin/protoc' // required to support building on osx-aarch64
+ if (System.getProperty("os.name") == "Mac OS X" && System.getProperty("os.arch") == "aarch64") {
+ path = '/opt/homebrew/bin/protoc'
+ } else {
+ artifact = 'com.google.protobuf:protoc:3.15.6'
+ }
}
generateProtoTasks {
all().each { task ->
diff --git a/spark-velocity/build.gradle b/spark-velocity/build.gradle
index 22533af..28e2724 100644
--- a/spark-velocity/build.gradle
+++ b/spark-velocity/build.gradle
@@ -5,8 +5,8 @@ plugins {
dependencies {
compile project(':spark-common')
- compileOnly 'com.velocitypowered:velocity-api:1.1.0'
- annotationProcessor 'com.velocitypowered:velocity-api:1.1.0'
+ compileOnly 'com.velocitypowered:velocity-api:1.1.5'
+ annotationProcessor 'com.velocitypowered:velocity-api:1.1.5'
}
repositories {
diff --git a/spark-velocity2/build.gradle b/spark-velocity2/build.gradle
new file mode 100644
index 0000000..ebb925f
--- /dev/null
+++ b/spark-velocity2/build.gradle
@@ -0,0 +1,43 @@
+plugins {
+ id 'net.kyori.blossom' version '1.1.0'
+ id 'com.github.johnrengelman.shadow' version '4.0.1'
+}
+
+sourceCompatibility = 11
+targetCompatibility = 11
+
+dependencies {
+ compile project(':spark-common')
+ compileOnly 'com.velocitypowered:velocity-api:2.0.0-SNAPSHOT'
+ annotationProcessor 'com.velocitypowered:velocity-annotation-processor:2.0.0-SNAPSHOT'
+}
+
+repositories {
+ maven { url "https://repo.velocitypowered.com/snapshots/" }
+}
+
+blossom {
+ replaceTokenIn('src/main/java/me/lucko/spark/velocity/VelocitySparkPlugin.java')
+ replaceToken '@version@', project.pluginVersion
+ replaceToken '@desc@', project.pluginDescription
+}
+
+shadowJar {
+ archiveName = 'spark-velocity2.jar'
+
+ relocate 'okio', 'me.lucko.spark.lib.okio'
+ relocate 'okhttp3', 'me.lucko.spark.lib.okhttp3'
+ relocate 'org.tukaani.xz', 'me.lucko.spark.lib.xz'
+ relocate 'com.google.protobuf', 'me.lucko.spark.lib.protobuf'
+ relocate 'org.objectweb.asm', 'me.lucko.spark.lib.asm'
+ relocate 'one.profiler', 'me.lucko.spark.lib.asyncprofiler'
+
+ exclude 'module-info.class'
+ exclude 'META-INF/maven/**'
+ exclude 'META-INF/proguard/**'
+}
+
+artifacts {
+ archives shadowJar
+ shadow shadowJar
+} \ No newline at end of file
diff --git a/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityCommandSender.java b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityCommandSender.java
new file mode 100644
index 0000000..f14b521
--- /dev/null
+++ b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityCommandSender.java
@@ -0,0 +1,66 @@
+/*
+ * This file is part of spark.
+ *
+ * Copyright (c) lucko (Luck) <luck@lucko.me>
+ * Copyright (c) contributors
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+package me.lucko.spark.velocity;
+
+import com.velocitypowered.api.command.CommandSource;
+import com.velocitypowered.api.command.ConsoleCommandSource;
+import com.velocitypowered.api.proxy.connection.Player;
+
+import me.lucko.spark.common.command.sender.AbstractCommandSender;
+
+import net.kyori.adventure.text.Component;
+
+import java.util.UUID;
+
+public class VelocityCommandSender extends AbstractCommandSender<CommandSource> {
+ public VelocityCommandSender(CommandSource source) {
+ super(source);
+ }
+
+ @Override
+ public String getName() {
+ if (super.delegate instanceof Player) {
+ return ((Player) super.delegate).username();
+ } else if (super.delegate instanceof ConsoleCommandSource) {
+ return "Console";
+ } else {
+ return "unknown:" + super.delegate.getClass().getSimpleName();
+ }
+ }
+
+ @Override
+ public UUID getUniqueId() {
+ if (super.delegate instanceof Player) {
+ return ((Player) super.delegate).id();
+ }
+ return null;
+ }
+
+ @Override
+ public void sendMessage(Component message) {
+ super.delegate.sendMessage(message);
+ }
+
+ @Override
+ public boolean hasPermission(String permission) {
+ return super.delegate.hasPermission(permission);
+ }
+}
diff --git a/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityPlatformInfo.java b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityPlatformInfo.java
new file mode 100644
index 0000000..3ae6929
--- /dev/null
+++ b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocityPlatformInfo.java
@@ -0,0 +1,53 @@
+/*
+ * This file is part of spark.
+ *
+ * Copyright (c) lucko (Luck) <luck@lucko.me>
+ * Copyright (c) contributors
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+package me.lucko.spark.velocity;
+
+import com.velocitypowered.api.proxy.ProxyServer;
+
+import me.lucko.spark.common.platform.AbstractPlatformInfo;
+
+public class VelocityPlatformInfo extends AbstractPlatformInfo {
+ private final ProxyServer proxy;
+
+ public VelocityPlatformInfo(ProxyServer proxy) {
+ this.proxy = proxy;
+ }
+
+ @Override
+ public Type getType() {
+ return Type.PROXY;
+ }
+
+ @Override
+ public String getName() {
+ return "Velocity";
+ }
+
+ @Override
+ public String getVersion() {
+ return this.proxy.version().version();
+ }
+
+ @Override
+ public String getMinecraftVersion() {
+ return null;
+ }
+}
diff --git a/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocitySparkPlugin.java b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocitySparkPlugin.java
new file mode 100644
index 0000000..cfd8255
--- /dev/null
+++ b/spark-velocity2/src/main/java/me/lucko/spark/velocity/VelocitySparkPlugin.java
@@ -0,0 +1,115 @@
+/*
+ * This file is part of spark.
+ *
+ * Copyright (c) lucko (Luck) <luck@lucko.me>
+ * Copyright (c) contributors
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+package me.lucko.spark.velocity;
+
+import com.google.inject.Inject;
+import com.velocitypowered.api.command.SimpleCommand;
+import com.velocitypowered.api.event.PostOrder;
+import com.velocitypowered.api.event.Subscribe;
+import com.velocitypowered.api.event.lifecycle.ProxyInitializeEvent;
+import com.velocitypowered.api.event.lifecycle.ProxyShutdownEvent;
+import com.velocitypowered.api.plugin.Plugin;
+import com.velocitypowered.api.plugin.annotation.DataDirectory;
+import com.velocitypowered.api.proxy.ProxyServer;
+
+import me.lucko.spark.common.SparkPlatform;
+import me.lucko.spark.common.SparkPlugin;
+import me.lucko.spark.common.platform.PlatformInfo;
+
+import java.nio.file.Path;
+import java.util.List;
+import java.util.stream.Stream;
+
+@Plugin(
+ id = "spark",
+ name = "spark",
+ version = "@version@",
+ description = "@desc@",
+ authors = {"Luck"}
+)
+public class VelocitySparkPlugin implements SparkPlugin, SimpleCommand {
+
+ private final ProxyServer proxy;
+ private final Path configDirectory;
+
+ private SparkPlatform platform;
+
+ @Inject
+ public VelocitySparkPlugin(ProxyServer proxy, @DataDirectory Path configDirectory) {
+ this.proxy = proxy;
+ this.configDirectory = configDirectory;
+ }
+
+ @Subscribe(order = PostOrder.FIRST)
+ public void onEnable(ProxyInitializeEvent e) {
+ this.platform = new SparkPlatform(this);
+ this.platform.enable();
+ this.proxy.commandManager().register("sparkv", this, "sparkvelocity");
+ }
+
+ @Subscribe(order = PostOrder.LAST)
+ public void onDisable(ProxyShutdownEvent e) {
+ this.platform.disable();
+ }
+
+ @Override
+ public void execute(Invocation inv) {
+ this.platform.executeCommand(new VelocityCommandSender(inv.source()), inv.arguments());
+ }
+
+ @Override
+ public List<String> suggest(Invocation inv) {
+ return this.platform.tabCompleteCommand(new VelocityCommandSender(inv.source()), inv.arguments());
+ }
+
+ @Override
+ public String getVersion() {
+ return VelocitySparkPlugin.class.getAnnotation(Plugin.class).version();
+ }
+
+ @Override
+ public Path getPluginDirectory() {
+ return this.configDirectory;
+ }
+
+ @Override
+ public String getCommandName() {
+ return "sparkv";
+ }
+
+ @Override
+ public Stream<VelocityCommandSender> getCommandSenders() {
+ return Stream.concat(
+ this.proxy.connectedPlayers().stream(),
+ Stream.of(this.proxy.consoleCommandSource())
+ ).map(VelocityCommandSender::new);
+ }
+
+ @Override
+ public void executeAsync(Runnable task) {
+ this.proxy.scheduler().buildTask(this, task).schedule();
+ }
+
+ @Override
+ public PlatformInfo getPlatformInfo() {
+ return new VelocityPlatformInfo(this.proxy);
+ }
+}