Implement Linkage for SpigotCore

This commit is contained in:
2025-10-03 13:39:19 +02:00
parent b8eb95e067
commit f8ea79811e
10 changed files with 44 additions and 28 deletions

View File

@@ -20,6 +20,7 @@
package de.steamwar.command; package de.steamwar.command;
import de.steamwar.core.Core; import de.steamwar.core.Core;
import de.steamwar.linkage.Linked;
import de.steamwar.providers.BauServerInfo; import de.steamwar.providers.BauServerInfo;
import de.steamwar.sql.AuditLog; import de.steamwar.sql.AuditLog;
import de.steamwar.sql.SteamwarUser; import de.steamwar.sql.SteamwarUser;
@@ -28,6 +29,7 @@ import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerCommandPreprocessEvent; import org.bukkit.event.player.PlayerCommandPreprocessEvent;
@Linked
public class CaseInsensitiveCommandsListener implements Listener { public class CaseInsensitiveCommandsListener implements Listener {
@EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true) @EventHandler(priority = EventPriority.LOWEST, ignoreCancelled = true)

View File

@@ -21,15 +21,14 @@ package de.steamwar.core;
import com.comphenix.tinyprotocol.TinyProtocol; import com.comphenix.tinyprotocol.TinyProtocol;
import de.steamwar.Reflection; import de.steamwar.Reflection;
import de.steamwar.command.*; import de.steamwar.command.SWCommandUtils;
import de.steamwar.core.authlib.AuthlibInjector; import de.steamwar.command.SWTypeMapperCreator;
import de.steamwar.core.events.AntiNocom; import de.steamwar.command.TabCompletionCache;
import de.steamwar.core.events.ChattingEvent; import de.steamwar.command.TypeMapper;
import de.steamwar.core.events.PlayerJoinedEvent; import de.steamwar.linkage.AbstractLinker;
import de.steamwar.core.events.WorldLoadEvent; import de.steamwar.linkage.SpigotLinker;
import de.steamwar.message.Message; import de.steamwar.message.Message;
import de.steamwar.network.NetworkReceiver; import de.steamwar.network.NetworkReceiver;
import de.steamwar.network.handlers.ServerDataHandler;
import de.steamwar.sql.SchematicNode; import de.steamwar.sql.SchematicNode;
import de.steamwar.sql.SteamwarUser; import de.steamwar.sql.SteamwarUser;
import de.steamwar.sql.internal.Statement; import de.steamwar.sql.internal.Statement;
@@ -37,7 +36,6 @@ import lombok.Getter;
import lombok.Setter; import lombok.Setter;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;
import org.bukkit.event.Listener;
import org.bukkit.plugin.java.JavaPlugin; import org.bukkit.plugin.java.JavaPlugin;
import java.io.BufferedReader; import java.io.BufferedReader;
@@ -95,9 +93,16 @@ public class Core extends JavaPlugin {
} }
}); });
for(Listener listener : new Listener[]{new CaseInsensitiveCommandsListener(), new PlayerJoinedEvent(), new ChattingEvent(), new WorldLoadEvent(), RecipeDiscoverWrapper.impl}) { SpigotLinker spigotLinker = new SpigotLinker(this, MESSAGE);
getServer().getPluginManager().registerEvents(listener, this); try {
spigotLinker.link();
} catch (AbstractLinker.LinkException e) {
e.printStackTrace();
Bukkit.shutdown();
return;
} }
Bukkit.getServer().getPluginManager().registerEvents(RecipeDiscoverWrapper.impl, this);
if(!Statement.productionDatabase()) { if(!Statement.productionDatabase()) {
getServer().getPluginManager().registerEvents(LocaleChangeWrapper.impl, this); getServer().getPluginManager().registerEvents(LocaleChangeWrapper.impl, this);
} }
@@ -105,18 +110,8 @@ public class Core extends JavaPlugin {
getServer().getMessenger().registerIncomingPluginChannel(this, "sw:bridge", new NetworkReceiver()); getServer().getMessenger().registerIncomingPluginChannel(this, "sw:bridge", new NetworkReceiver());
getServer().getMessenger().registerOutgoingPluginChannel(this, "sw:bridge"); getServer().getMessenger().registerOutgoingPluginChannel(this, "sw:bridge");
if(Core.getVersion() < 19)
AuthlibInjector.inject();
TinyProtocol.init(); TinyProtocol.init();
CheckpointUtils.signalHandler(); CheckpointUtils.signalHandler();
new AntiNocom();
if(Core.getVersion() >= 19)
new ServerDataHandler();
if(Bukkit.getPluginManager().getPlugin("WorldEdit") != null)
new WorldEditRenderer();
Bukkit.getScheduler().runTaskTimer(this, TabCompletionCache::invalidateOldEntries, 20, 20); Bukkit.getScheduler().runTaskTimer(this, TabCompletionCache::invalidateOldEntries, 20, 20);
Bukkit.getScheduler().runTaskTimer(Core.getInstance(), SteamwarUser::clear, 72000, 72000); Bukkit.getScheduler().runTaskTimer(Core.getInstance(), SteamwarUser::clear, 72000, 72000);

View File

@@ -28,6 +28,8 @@ import com.sk89q.worldedit.math.transform.Transform;
import com.sk89q.worldedit.regions.Region; import com.sk89q.worldedit.regions.Region;
import com.sk89q.worldedit.regions.RegionSelector; import com.sk89q.worldedit.regions.RegionSelector;
import com.sk89q.worldedit.world.World; import com.sk89q.worldedit.world.World;
import de.steamwar.linkage.Linked;
import de.steamwar.linkage.PluginCheck;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Material; import org.bukkit.Material;
import org.bukkit.entity.Player; import org.bukkit.entity.Player;
@@ -37,6 +39,8 @@ import org.bukkit.event.block.BlockBreakEvent;
import org.bukkit.event.player.*; import org.bukkit.event.player.*;
import org.bukkit.util.Vector; import org.bukkit.util.Vector;
@Linked
@PluginCheck("WorldEdit")
public class WorldEditRenderer implements Listener { public class WorldEditRenderer implements Listener {
private static WorldEditRenderer INSTANCE; private static WorldEditRenderer INSTANCE;

View File

@@ -22,11 +22,16 @@ package de.steamwar.core.authlib;
import de.steamwar.Reflection; import de.steamwar.Reflection;
import com.mojang.authlib.GameProfileRepository; import com.mojang.authlib.GameProfileRepository;
import com.mojang.authlib.yggdrasil.YggdrasilGameProfileRepository; import com.mojang.authlib.yggdrasil.YggdrasilGameProfileRepository;
import de.steamwar.linkage.Linked;
import de.steamwar.linkage.MaxVersion;
import de.steamwar.linkage.api.Enable;
public class AuthlibInjector { @Linked
private AuthlibInjector() {} @MaxVersion(18)
public class AuthlibInjector implements Enable {
public static void inject() { @Override
public void enable() {
Class<?> minecraftServerClass = Reflection.getClass("net.minecraft.server.MinecraftServer"); Class<?> minecraftServerClass = Reflection.getClass("net.minecraft.server.MinecraftServer");
Reflection.Field<GameProfileRepository> gameProfile = Reflection.getField(minecraftServerClass, GameProfileRepository.class, 0); Reflection.Field<GameProfileRepository> gameProfile = Reflection.getField(minecraftServerClass, GameProfileRepository.class, 0);
Object minecraftServer = Reflection.getTypedMethod(minecraftServerClass, "getServer", minecraftServerClass).invoke(null); Object minecraftServer = Reflection.getTypedMethod(minecraftServerClass, "getServer", minecraftServerClass).invoke(null);

View File

@@ -19,9 +19,10 @@
package de.steamwar.core.events; package de.steamwar.core.events;
import de.steamwar.Reflection;
import com.comphenix.tinyprotocol.TinyProtocol; import com.comphenix.tinyprotocol.TinyProtocol;
import de.steamwar.Reflection;
import de.steamwar.core.Core; import de.steamwar.core.Core;
import de.steamwar.linkage.Linked;
import de.steamwar.sql.SWException; import de.steamwar.sql.SWException;
import de.steamwar.techhider.ProtocolUtils; import de.steamwar.techhider.ProtocolUtils;
import de.steamwar.techhider.TechHider; import de.steamwar.techhider.TechHider;
@@ -35,14 +36,13 @@ import java.util.Map;
import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap;
import java.util.function.Function; import java.util.function.Function;
@Linked
public class AntiNocom implements Listener { public class AntiNocom implements Listener {
private final Map<Player, Integer> flags = new ConcurrentHashMap<>(); private final Map<Player, Integer> flags = new ConcurrentHashMap<>();
public AntiNocom() { public AntiNocom() {
Bukkit.getServer().getPluginManager().registerEvents(this, Core.getInstance());
TinyProtocol.instance.addFilter(blockDig, this::onDig); TinyProtocol.instance.addFilter(blockDig, this::onDig);
if(Core.getVersion() > 8) { if(Core.getVersion() > 8) {
registerUseItem(); registerUseItem();
} }

View File

@@ -20,11 +20,13 @@
package de.steamwar.core.events; package de.steamwar.core.events;
import de.steamwar.core.Core; import de.steamwar.core.Core;
import de.steamwar.linkage.Linked;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.EventPriority; import org.bukkit.event.EventPriority;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.player.AsyncPlayerChatEvent; import org.bukkit.event.player.AsyncPlayerChatEvent;
@Linked
public class ChattingEvent implements Listener { public class ChattingEvent implements Listener {
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true) @EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)

View File

@@ -20,6 +20,7 @@
package de.steamwar.core.events; package de.steamwar.core.events;
import de.steamwar.core.Core; import de.steamwar.core.Core;
import de.steamwar.linkage.Linked;
import de.steamwar.providers.BauServerInfo; import de.steamwar.providers.BauServerInfo;
import de.steamwar.sql.AuditLog; import de.steamwar.sql.AuditLog;
import de.steamwar.sql.SteamwarUser; import de.steamwar.sql.SteamwarUser;
@@ -32,7 +33,7 @@ import org.bukkit.event.Listener;
import org.bukkit.event.player.PlayerJoinEvent; import org.bukkit.event.player.PlayerJoinEvent;
import org.bukkit.event.player.PlayerQuitEvent; import org.bukkit.event.player.PlayerQuitEvent;
@Linked
public class PlayerJoinedEvent implements Listener{ public class PlayerJoinedEvent implements Listener{
@EventHandler(priority = EventPriority.LOWEST) @EventHandler(priority = EventPriority.LOWEST)

View File

@@ -19,10 +19,12 @@
package de.steamwar.core.events; package de.steamwar.core.events;
import de.steamwar.linkage.Linked;
import org.bukkit.event.EventHandler; import org.bukkit.event.EventHandler;
import org.bukkit.event.Listener; import org.bukkit.event.Listener;
import org.bukkit.event.world.WorldInitEvent; import org.bukkit.event.world.WorldInitEvent;
@Linked
public class WorldLoadEvent implements Listener { public class WorldLoadEvent implements Listener {
@EventHandler @EventHandler

View File

@@ -21,7 +21,11 @@ package de.steamwar.network.handlers;
import de.steamwar.Reflection; import de.steamwar.Reflection;
import com.comphenix.tinyprotocol.TinyProtocol; import com.comphenix.tinyprotocol.TinyProtocol;
import de.steamwar.linkage.Linked;
import de.steamwar.linkage.MinVersion;
@Linked
@MinVersion(19)
public class ServerDataHandler { public class ServerDataHandler {
public ServerDataHandler() { public ServerDataHandler() {

View File

@@ -223,6 +223,7 @@ public class Subserver {
start(process.getInputStream(), line -> line.contains("Checkpoint restored")); start(process.getInputStream(), line -> line.contains("Checkpoint restored"));
Thread.sleep(100); Thread.sleep(100);
} else { } else {
sendProgress(0);
start(process.getInputStream(), line -> { start(process.getInputStream(), line -> {
if (line.contains("Loading libraries, please wait")) if (line.contains("Loading libraries, please wait"))
sendProgress(2); sendProgress(2);