2021-03-16 09:00:00 +11:00
--- a/net/minecraft/server/dedicated/DedicatedServer.java
+++ b/net/minecraft/server/dedicated/DedicatedServer.java
2013-01-10 00:18:11 -05:00
@@ -54,11 +54,23 @@
2024-12-11 22:26:55 +01:00
import net.minecraft.world.entity.player.Player;
import net.minecraft.world.level.GameRules;
import net.minecraft.world.level.GameType;
-import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.entity.SkullBlockEntity;
import net.minecraft.world.level.storage.LevelStorageSource;
2022-03-01 02:00:00 +11:00
import org.slf4j.Logger;
2014-11-26 08:32:16 +11:00
+// CraftBukkit start
2022-12-08 03:00:00 +11:00
+import net.minecraft.server.WorldLoader;
2014-11-26 08:32:16 +11:00
+import org.apache.logging.log4j.Level;
2022-03-01 02:00:00 +11:00
+import org.apache.logging.log4j.LogManager;
2020-09-12 09:05:20 +10:00
+import org.apache.logging.log4j.io.IoBuilder;
2018-07-15 10:00:00 +10:00
+import org.bukkit.command.CommandSender;
2013-01-10 00:18:11 -05:00
+import org.bukkit.craftbukkit.SpigotTimings; // Spigot
2024-04-07 11:54:28 +10:00
+import org.bukkit.craftbukkit.util.TerminalCompletionHandler;
+import org.bukkit.craftbukkit.util.TerminalConsoleWriterThread;
2014-11-26 08:32:16 +11:00
+import org.bukkit.event.server.ServerCommandEvent;
2015-02-26 22:41:06 +00:00
+import org.bukkit.event.server.RemoteServerCommandEvent;
2014-11-26 08:32:16 +11:00
+// CraftBukkit end
+
2024-12-11 22:26:55 +01:00
public class DedicatedServer extends MinecraftServer implements ServerInterface {
2014-11-26 08:32:16 +11:00
2022-03-01 02:00:00 +11:00
static final Logger LOGGER = LogUtils.getLogger();
2013-01-10 00:18:11 -05:00
@@ -67,7 +79,7 @@
2024-12-11 22:26:55 +01:00
private final List<ConsoleInput> consoleInput = Collections.synchronizedList(Lists.newArrayList());
2023-08-26 18:19:22 +10:00
@Nullable
2024-12-11 22:26:55 +01:00
private QueryThreadGs4 queryThreadGs4;
- private final RconConsoleSource rconConsoleSource;
2023-09-22 02:40:00 +10:00
+ // private final RemoteControlCommandListener rconConsoleSource; // CraftBukkit - remove field
2023-08-26 18:19:22 +10:00
@Nullable
2024-12-11 22:26:55 +01:00
private RconThread rconThread;
2023-08-26 18:19:22 +10:00
public DedicatedServerSettings settings;
2013-01-10 00:18:11 -05:00
@@ -81,25 +93,58 @@
2024-04-24 01:15:00 +10:00
private DebugSampleSubscriptionTracker debugSampleSubscriptionTracker;
2024-06-14 01:05:00 +10:00
public ServerLinks serverLinks;
2016-03-01 08:32:46 +11:00
2024-12-11 22:26:55 +01:00
- public DedicatedServer(Thread serverThread, LevelStorageSource.LevelStorageAccess session, PackRepository dataPackManager, WorldStem saveLoader, DedicatedServerSettings propertiesLoader, DataFixer dataFixer, Services apiServices, ChunkProgressListenerFactory worldGenerationProgressListenerFactory) {
- super(serverThread, session, dataPackManager, saveLoader, Proxy.NO_PROXY, dataFixer, apiServices, worldGenerationProgressListenerFactory);
- this.settings = propertiesLoader;
- this.rconConsoleSource = new RconConsoleSource(this);
- this.serverTextFilter = ServerTextFilter.createFromConfig(propertiesLoader.getProperties());
- this.serverLinks = DedicatedServer.createServerLinks(propertiesLoader);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - Signature changed
2024-12-11 22:26:55 +01:00
+ public DedicatedServer(joptsimple.OptionSet options, WorldLoader.DataLoadContext worldLoader, Thread thread, LevelStorageSource.LevelStorageAccess convertable_conversionsession, PackRepository resourcepackrepository, WorldStem worldstem, DedicatedServerSettings dedicatedserversettings, DataFixer datafixer, Services services, ChunkProgressListenerFactory worldloadlistenerfactory) {
2022-12-16 11:13:10 +11:00
+ super(options, worldLoader, thread, convertable_conversionsession, resourcepackrepository, worldstem, Proxy.NO_PROXY, datafixer, services, worldloadlistenerfactory);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
+ this.settings = dedicatedserversettings;
2023-08-26 18:19:22 +10:00
+ // this.rconConsoleSource = new RemoteControlCommandListener(this); // CraftBukkit - remove field
2024-12-11 22:26:55 +01:00
+ this.serverTextFilter = ServerTextFilter.createFromConfig(dedicatedserversettings.getProperties());
+ this.serverLinks = DedicatedServer.createServerLinks(dedicatedserversettings);
2023-08-26 18:19:22 +10:00
}
2024-12-11 22:26:55 +01:00
@Override
2021-11-22 09:00:00 +11:00
public boolean initServer() throws IOException {
2015-02-26 22:41:06 +00:00
Thread thread = new Thread("Server console handler") {
public void run() {
2017-05-14 12:00:00 +10:00
- BufferedReader bufferedreader = new BufferedReader(new InputStreamReader(System.in, StandardCharsets.UTF_8));
2015-02-26 22:41:06 +00:00
+ // CraftBukkit start
+ if (!org.bukkit.craftbukkit.Main.useConsole) {
+ return;
+ }
2024-12-11 22:26:55 +01:00
+ jline.console.ConsoleReader bufferedreader = DedicatedServer.this.reader;
2020-01-28 10:36:47 +11:00
+ // MC-33041, SPIGOT-5538: if System.in is not valid due to javaw, then return
+ try {
+ System.in.available();
+ } catch (IOException ex) {
+ return;
+ }
2015-02-26 22:41:06 +00:00
+ // CraftBukkit end
2024-12-11 22:26:55 +01:00
+
2015-02-26 22:41:06 +00:00
String s;
try {
- while (!DedicatedServer.this.isStopped() && DedicatedServer.this.isRunning() && (s = bufferedreader.readLine()) != null) {
2021-11-22 09:00:00 +11:00
- DedicatedServer.this.handleConsoleInput(s, DedicatedServer.this.createCommandSourceStack());
2015-02-26 22:41:06 +00:00
+ // CraftBukkit start - JLine disabling compatibility
2018-07-15 10:00:00 +10:00
+ while (!DedicatedServer.this.isStopped() && DedicatedServer.this.isRunning()) {
2015-02-26 22:41:06 +00:00
+ if (org.bukkit.craftbukkit.Main.useJline) {
+ s = bufferedreader.readLine(">", null);
+ } else {
+ s = bufferedreader.readLine();
+ }
2019-07-28 08:49:01 +10:00
+
+ // SPIGOT-5220: Throttle if EOF (ctrl^d) or stdin is /dev/null
+ if (s == null) {
+ try {
+ Thread.sleep(50L);
+ } catch (InterruptedException ex) {
+ Thread.currentThread().interrupt();
+ }
+ continue;
+ }
+ if (s.trim().length() > 0) { // Trim to filter lines which are just spaces
2021-11-22 09:00:00 +11:00
+ DedicatedServer.this.handleConsoleInput(s, DedicatedServer.this.createCommandSourceStack());
2015-02-26 22:41:06 +00:00
+ }
+ // CraftBukkit end
}
} catch (IOException ioexception) {
DedicatedServer.LOGGER.error("Exception handling console input", ioexception);
2013-01-10 00:18:11 -05:00
@@ -108,6 +153,29 @@
2015-05-25 22:04:32 +10:00
}
};
2015-02-26 22:41:06 +00:00
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - TODO: handle command-line logging arguments
+ java.util.logging.Logger global = java.util.logging.Logger.getLogger("");
+ global.setUseParentHandlers(false);
+ for (java.util.logging.Handler handler : global.getHandlers()) {
+ global.removeHandler(handler);
+ }
+ global.addHandler(new org.bukkit.craftbukkit.util.ForwardLogHandler());
+
+ final org.apache.logging.log4j.core.Logger logger = ((org.apache.logging.log4j.core.Logger) LogManager.getRootLogger());
+ for (org.apache.logging.log4j.core.Appender appender : logger.getAppenders().values()) {
+ if (appender instanceof org.apache.logging.log4j.core.appender.ConsoleAppender) {
+ logger.removeAppender(appender);
+ }
+ }
+
2024-04-07 11:54:28 +10:00
+ TerminalConsoleWriterThread writerThread = new TerminalConsoleWriterThread(System.out, this.reader);
+ this.reader.setCompletionHandler(new TerminalCompletionHandler(writerThread, this.reader.getCompletionHandler()));
+ writerThread.start();
2014-11-26 08:32:16 +11:00
+
2020-09-12 09:05:20 +10:00
+ System.setOut(IoBuilder.forLogger(logger).setLevel(Level.INFO).buildPrintStream());
+ System.setErr(IoBuilder.forLogger(logger).setLevel(Level.WARN).buildPrintStream());
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
+
2015-05-25 22:04:32 +10:00
thread.setDaemon(true);
2018-07-15 10:00:00 +10:00
thread.setUncaughtExceptionHandler(new DefaultUncaughtExceptionHandler(DedicatedServer.LOGGER));
2015-05-25 22:04:32 +10:00
thread.start();
2022-06-08 22:20:16 -07:00
@@ -126,13 +194,22 @@
2013-07-07 09:32:53 +10:00
this.setPreventProxyConnections(dedicatedserverproperties.preventProxyConnections);
this.setLocalIp(dedicatedserverproperties.serverIp);
}
+ // Spigot start
+ this.setPlayerList(new DedicatedPlayerList(this, this.registries(), this.playerDataStorage));
+ org.spigotmc.SpigotConfig.init((java.io.File) this.options.valueOf("spigot-settings"));
+ org.spigotmc.SpigotConfig.registerCommands();
+ // Spigot end
2022-06-08 22:20:16 -07:00
+ // Paper start - initialize global and world-defaults configuration
+ this.paperConfigurations.initializeGlobalConfiguration(this.registryAccess());
+ this.paperConfigurations.initializeWorldDefaultsConfiguration(this.registryAccess());
+ // Paper end - initialize global and world-defaults configuration
2013-07-07 09:32:53 +10:00
this.setPvpAllowed(dedicatedserverproperties.pvp);
this.setFlightAllowed(dedicatedserverproperties.allowFlight);
2021-06-11 15:00:00 +10:00
this.setMotd(dedicatedserverproperties.motd);
2021-11-22 09:00:00 +11:00
super.setPlayerIdleTimeout((Integer) dedicatedserverproperties.playerIdleTimeout.get());
2021-07-07 00:00:00 +10:00
this.setEnforceWhitelist(dedicatedserverproperties.enforceWhitelist);
2021-06-11 15:00:00 +10:00
- this.worldData.setGameType(dedicatedserverproperties.gamemode);
+ // this.worldData.setGameType(dedicatedserverproperties.gamemode); // CraftBukkit - moved to world loading
2020-06-25 10:00:00 +10:00
DedicatedServer.LOGGER.info("Default game type: {}", dedicatedserverproperties.gamemode);
InetAddress inetaddress = null;
2022-06-08 22:20:16 -07:00
@@ -156,10 +233,23 @@
2019-04-23 12:00:00 +10:00
return false;
2014-11-26 08:32:16 +11:00
}
2022-06-08 22:20:16 -07:00
2019-04-23 12:00:00 +10:00
+ // CraftBukkit start
2013-07-07 09:32:53 +10:00
+ // this.setPlayerList(new DedicatedPlayerList(this, this.registries(), this.playerDataStorage)); // Spigot - moved up
2024-12-11 22:26:55 +01:00
+ this.server.loadPlugins();
+ this.server.enablePlugins(org.bukkit.plugin.PluginLoadOrder.STARTUP);
2019-04-23 12:00:00 +10:00
+ // CraftBukkit end
2022-06-08 22:20:16 -07:00
+
2021-11-22 09:00:00 +11:00
if (!this.usesAuthentication()) {
2019-04-23 12:00:00 +10:00
DedicatedServer.LOGGER.warn("**** SERVER IS RUNNING IN OFFLINE/INSECURE MODE!");
DedicatedServer.LOGGER.warn("The server will make no attempt to authenticate usernames. Beware.");
2014-04-12 21:23:58 +10:00
- DedicatedServer.LOGGER.warn("While this makes the game possible to play without internet access, it also opens up the ability for hackers to connect with any username they choose.");
+ // Spigot start
+ if (org.spigotmc.SpigotConfig.bungee) {
+ DedicatedServer.LOGGER.warn("Whilst this makes it possible to use BungeeCord, unless access to your server is properly restricted, it also opens up the ability for hackers to connect with any username they choose.");
+ DedicatedServer.LOGGER.warn("Please see http://www.spigotmc.org/wiki/firewall-guide/ for further information.");
+ } else {
+ DedicatedServer.LOGGER.warn("While this makes the game possible to play without internet access, it also opens up the ability for hackers to connect with any username they choose.");
+ }
+ // Spigot end
DedicatedServer.LOGGER.warn("To change this, set \"online-mode\" to \"true\" in the server.properties file.");
}
2022-06-08 22:20:16 -07:00
@@ -170,7 +260,7 @@
2024-12-11 22:26:55 +01:00
if (!OldUsersConverter.serverReadyAfterUserconversion(this)) {
2019-04-23 12:00:00 +10:00
return false;
} else {
2022-12-08 03:00:00 +11:00
- this.setPlayerList(new DedicatedPlayerList(this, this.registries(), this.playerDataStorage));
+ // this.setPlayerList(new DedicatedPlayerList(this, this.registries(), this.playerDataStorage)); // CraftBukkit - moved up
2024-04-24 01:15:00 +10:00
this.debugSampleSubscriptionTracker = new DebugSampleSubscriptionTracker(this.getPlayerList());
this.tickTimeLogger = new RemoteSampleLogger(TpsDebugDimensions.values().length, this.debugSampleSubscriptionTracker, RemoteDebugSampleType.TICK_TIME);
2024-12-11 22:26:55 +01:00
long i = Util.getNanos();
2022-06-08 22:20:16 -07:00
@@ -178,13 +268,13 @@
2024-12-11 22:26:55 +01:00
SkullBlockEntity.setup(this.services, this);
GameProfileCache.setUsesAuthentication(this.usesAuthentication());
2021-11-22 09:00:00 +11:00
DedicatedServer.LOGGER.info("Preparing level \"{}\"", this.getLevelIdName());
- this.loadLevel();
2024-12-11 22:26:55 +01:00
+ this.loadLevel(this.storageSource.getLevelId()); // CraftBukkit
long j = Util.getNanos() - i;
2020-06-25 10:00:00 +10:00
String s = String.format(Locale.ROOT, "%.3fs", (double) j / 1.0E9D);
2024-02-04 10:54:20 +11:00
DedicatedServer.LOGGER.info("Done ({})! For help, type \"help\"", s);
if (dedicatedserverproperties.announcePlayerAchievements != null) {
2024-12-11 22:26:55 +01:00
- ((GameRules.BooleanValue) this.getGameRules().getRule(GameRules.RULE_ANNOUNCE_ADVANCEMENTS)).set(dedicatedserverproperties.announcePlayerAchievements, this);
+ ((GameRules.BooleanValue) this.getGameRules().getRule(GameRules.RULE_ANNOUNCE_ADVANCEMENTS)).set(dedicatedserverproperties.announcePlayerAchievements, this.overworld()); // CraftBukkit - per-world
2024-02-04 10:54:20 +11:00
}
if (dedicatedserverproperties.enableQuery) {
2022-06-08 22:20:16 -07:00
@@ -197,7 +287,7 @@
2014-08-05 17:20:19 +01:00
this.rconThread = RconThread.create(this);
}
- if (this.getMaxTickLength() > 0L) {
+ if (false && this.getMaxTickLength() > 0L) { // Spigot - disable
Thread thread1 = new Thread(new ServerWatchdog(this));
thread1.setUncaughtExceptionHandler(new DefaultUncaughtExceptionHandlerWithName(DedicatedServer.LOGGER));
2022-06-08 22:20:16 -07:00
@@ -293,6 +383,7 @@
2021-11-22 09:00:00 +11:00
this.queryThreadGs4.stop();
2019-04-23 12:00:00 +10:00
}
2014-11-26 08:32:16 +11:00
2019-04-23 12:00:00 +10:00
+ System.exit(0); // CraftBukkit
2014-11-26 08:32:16 +11:00
}
2019-04-23 12:00:00 +10:00
@Override
2022-06-08 22:20:16 -07:00
@@ -302,8 +393,8 @@
2024-12-11 22:26:55 +01:00
}
@Override
- public boolean isLevelEnabled(Level world) {
- return world.dimension() == Level.NETHER ? this.getProperties().allowNether : true;
+ public boolean isLevelEnabled(net.minecraft.world.level.Level world) {
+ return world.dimension() == net.minecraft.world.level.Level.NETHER ? this.getProperties().allowNether : true;
}
public void handleConsoleInput(String command, CommandSourceStack commandSource) {
2022-06-08 22:20:16 -07:00
@@ -311,12 +402,22 @@
2013-01-10 00:18:11 -05:00
}
public void handleConsoleInputs() {
+ SpigotTimings.serverCommandTimer.startTiming(); // Spigot
2021-06-11 15:00:00 +10:00
while (!this.consoleInput.isEmpty()) {
2024-12-11 22:26:55 +01:00
ConsoleInput servercommand = (ConsoleInput) this.consoleInput.remove(0);
2014-11-26 08:32:16 +11:00
2022-06-08 02:00:00 +10:00
- this.getCommands().performPrefixedCommand(servercommand.source, servercommand.msg);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit start - ServerCommand for preprocessing
2024-12-11 22:26:55 +01:00
+ ServerCommandEvent event = new ServerCommandEvent(this.console, servercommand.msg);
+ this.server.getPluginManager().callEvent(event);
2016-03-03 16:56:07 +11:00
+ if (event.isCancelled()) continue;
2024-12-11 22:26:55 +01:00
+ servercommand = new ConsoleInput(event.getCommand(), servercommand.source);
2014-11-26 08:32:16 +11:00
+
2022-06-08 02:00:00 +10:00
+ // this.getCommands().performPrefixedCommand(servercommand.source, servercommand.msg); // Called in dispatchServerCommand
2024-12-11 22:26:55 +01:00
+ this.server.dispatchServerCommand(this.console, servercommand);
2014-11-26 08:32:16 +11:00
+ // CraftBukkit end
}
2013-01-10 00:18:11 -05:00
+ SpigotTimings.serverCommandTimer.stopTiming(); // Spigot
2014-11-26 08:32:16 +11:00
}
2013-01-10 00:18:11 -05:00
@Override
2022-06-08 22:20:16 -07:00
@@ -383,7 +484,7 @@
2024-12-11 22:26:55 +01:00
@Override
public boolean isUnderSpawnProtection(ServerLevel world, BlockPos pos, Player player) {
- if (world.dimension() != Level.OVERWORLD) {
+ if (world.dimension() != net.minecraft.world.level.Level.OVERWORLD) {
return false;
} else if (this.getPlayerList().getOps().isEmpty()) {
return false;
2022-06-08 22:20:16 -07:00
@@ -541,16 +642,52 @@
2015-02-26 22:41:06 +00:00
2019-04-23 12:00:00 +10:00
@Override
2021-11-22 09:00:00 +11:00
public String getPluginNames() {
2015-02-26 22:41:06 +00:00
- return "";
+ // CraftBukkit start - Whole method
+ StringBuilder result = new StringBuilder();
2024-12-11 22:26:55 +01:00
+ org.bukkit.plugin.Plugin[] plugins = this.server.getPluginManager().getPlugins();
2015-02-26 22:41:06 +00:00
+
2024-12-11 22:26:55 +01:00
+ result.append(this.server.getName());
2015-02-26 22:41:06 +00:00
+ result.append(" on Bukkit ");
2024-12-11 22:26:55 +01:00
+ result.append(this.server.getBukkitVersion());
2015-02-26 22:41:06 +00:00
+
2024-12-11 22:26:55 +01:00
+ if (plugins.length > 0 && this.server.getQueryPlugins()) {
2015-02-26 22:41:06 +00:00
+ result.append(": ");
+
+ for (int i = 0; i < plugins.length; i++) {
+ if (i > 0) {
+ result.append("; ");
+ }
2018-09-19 18:32:21 +10:00
+
2016-07-15 20:08:04 +10:00
+ result.append(plugins[i].getDescription().getName());
+ result.append(" ");
+ result.append(plugins[i].getDescription().getVersion().replaceAll(";", ","));
+ }
+ }
2018-12-13 11:00:00 +11:00
+
2015-02-26 22:41:06 +00:00
+ return result.toString();
+ // CraftBukkit end
2019-04-23 12:00:00 +10:00
}
@Override
2024-12-11 22:26:55 +01:00
public String runCommand(String command) {
2023-08-26 18:19:22 +10:00
- this.rconConsoleSource.prepareForCommand();
+ // CraftBukkit start - fire RemoteServerCommandEvent
+ throw new UnsupportedOperationException("Not supported - remote source required.");
+ }
+
2024-12-11 22:26:55 +01:00
+ public String runCommand(RconConsoleSource rconConsoleSource, String s) {
2023-08-26 18:19:22 +10:00
+ rconConsoleSource.prepareForCommand();
2021-11-22 09:00:00 +11:00
this.executeBlocking(() -> {
2024-12-11 22:26:55 +01:00
- this.getCommands().performPrefixedCommand(this.rconConsoleSource.createCommandSourceStack(), command);
+ CommandSourceStack wrapper = rconConsoleSource.createCommandSourceStack();
2023-08-26 18:19:22 +10:00
+ RemoteServerCommandEvent event = new RemoteServerCommandEvent(rconConsoleSource.getBukkitSender(wrapper), s);
2024-12-11 22:26:55 +01:00
+ this.server.getPluginManager().callEvent(event);
2019-06-21 20:00:00 +10:00
+ if (event.isCancelled()) {
+ return;
2015-02-26 22:41:06 +00:00
+ }
2024-12-11 22:26:55 +01:00
+ ConsoleInput serverCommand = new ConsoleInput(event.getCommand(), wrapper);
+ this.server.dispatchServerCommand(event.getSender(), serverCommand);
2019-06-21 20:00:00 +10:00
});
2023-08-26 18:19:22 +10:00
- return this.rconConsoleSource.getCommandResponse();
+ return rconConsoleSource.getCommandResponse();
+ // CraftBukkit end
2019-04-23 12:00:00 +10:00
}
2023-08-26 18:19:22 +10:00
2024-12-11 22:26:55 +01:00
public void storeUsingWhiteList(boolean useWhitelist) {
2022-06-08 22:20:16 -07:00
@@ -660,4 +797,15 @@
2024-06-14 01:05:00 +10:00
}
}
2019-04-23 12:00:00 +10:00
}
2016-03-01 08:32:46 +11:00
+
+ // CraftBukkit start
2019-04-23 12:00:00 +10:00
+ public boolean isDebugging() {
2021-11-22 09:00:00 +11:00
+ return this.getProperties().debug;
2019-04-23 12:00:00 +10:00
+ }
+
2018-07-15 10:00:00 +10:00
+ @Override
2024-12-11 22:26:55 +01:00
+ public CommandSender getBukkitSender(CommandSourceStack wrapper) {
+ return this.console;
2019-04-23 12:00:00 +10:00
+ }
2016-03-01 08:32:46 +11:00
+ // CraftBukkit end
}