aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0660-Add-Unix-domain-socket-support.patch
diff options
context:
space:
mode:
authorOwen <[email protected]>2022-03-11 15:13:46 -0500
committerGitHub <[email protected]>2022-03-11 21:13:46 +0100
commitea1efef1164aa7653119eb4be000749930e5b4da (patch)
tree104968ec407cf897e14388b14d2bf397844c8279 /patches/server/0660-Add-Unix-domain-socket-support.patch
parent1790528a6104c7c801e02a6f6d2ec0dda70e2af9 (diff)
downloadPaper-ea1efef1164aa7653119eb4be000749930e5b4da.tar.gz
Paper-ea1efef1164aa7653119eb4be000749930e5b4da.zip
Remove Patches (#7541)
Diffstat (limited to 'patches/server/0660-Add-Unix-domain-socket-support.patch')
-rw-r--r--patches/server/0660-Add-Unix-domain-socket-support.patch141
1 files changed, 0 insertions, 141 deletions
diff --git a/patches/server/0660-Add-Unix-domain-socket-support.patch b/patches/server/0660-Add-Unix-domain-socket-support.patch
deleted file mode 100644
index 85d133844f..0000000000
--- a/patches/server/0660-Add-Unix-domain-socket-support.patch
+++ /dev/null
@@ -1,141 +0,0 @@
-From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
-From: Andrew Steinborn <[email protected]>
-Date: Tue, 11 May 2021 17:39:22 -0400
-Subject: [PATCH] Add Unix domain socket support
-
-For Windows and ARM support, JEP-380 is required:
-https://inside.java/2021/02/03/jep380-unix-domain-sockets-channels/
-This will be possible as of the Minecraft 1.17 Java version bump.
-
-Tested-by: Mariell Hoversholm <[email protected]>
-Reviewed-by: Mariell Hoversholm <[email protected]>
-
-diff --git a/src/main/java/net/minecraft/network/Connection.java b/src/main/java/net/minecraft/network/Connection.java
-index 932b494ea2a5e849b233c73bd2472d5c85f5ba52..8536dd544876e245a611379a7ed1446b0ed06eac 100644
---- a/src/main/java/net/minecraft/network/Connection.java
-+++ b/src/main/java/net/minecraft/network/Connection.java
-@@ -626,6 +626,11 @@ public class Connection extends SimpleChannelInboundHandler<Packet<?>> {
- // Spigot Start
- public SocketAddress getRawAddress()
- {
-+ // Paper start - this can be nullable in the case of a Unix domain socket, so if it is, fake something
-+ if (this.channel.remoteAddress() == null) {
-+ return new java.net.InetSocketAddress(java.net.InetAddress.getLoopbackAddress(), 0);
-+ }
-+ // Paper end
- return this.channel.remoteAddress();
- }
- // Spigot End
-diff --git a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
-index fa6adf12e8272c90c3376bc93350dc57eb1cd461..939745227346e6d23e50f942eb48ab97c4ab6190 100644
---- a/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
-+++ b/src/main/java/net/minecraft/server/dedicated/DedicatedServer.java
-@@ -234,6 +234,20 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
- this.setEnforceWhitelist(dedicatedserverproperties.enforceWhitelist);
- // this.worldData.setGameType(dedicatedserverproperties.gamemode); // CraftBukkit - moved to world loading
- DedicatedServer.LOGGER.info("Default game type: {}", dedicatedserverproperties.gamemode);
-+ // Paper start - Unix domain socket support
-+ java.net.SocketAddress bindAddress;
-+ if (this.getLocalIp().startsWith("unix:")) {
-+ if (!io.netty.channel.epoll.Epoll.isAvailable()) {
-+ DedicatedServer.LOGGER.error("**** INVALID CONFIGURATION!");
-+ DedicatedServer.LOGGER.error("You are trying to use a Unix domain socket but you're not on a supported OS.");
-+ return false;
-+ } else if (!com.destroystokyo.paper.PaperConfig.velocitySupport && !org.spigotmc.SpigotConfig.bungee) {
-+ DedicatedServer.LOGGER.error("**** INVALID CONFIGURATION!");
-+ DedicatedServer.LOGGER.error("Unix domain sockets require IPs to be forwarded from a proxy.");
-+ return false;
-+ }
-+ bindAddress = new io.netty.channel.unix.DomainSocketAddress(this.getLocalIp().substring("unix:".length()));
-+ } else {
- InetAddress inetaddress = null;
-
- if (!this.getLocalIp().isEmpty()) {
-@@ -243,12 +257,15 @@ public class DedicatedServer extends MinecraftServer implements ServerInterface
- if (this.getPort() < 0) {
- this.setPort(dedicatedserverproperties.serverPort);
- }
-+ bindAddress = new java.net.InetSocketAddress(inetaddress, this.getPort());
-+ }
-+ // Paper end
-
- this.initializeKeyPair();
- DedicatedServer.LOGGER.info("Starting Minecraft server on {}:{}", this.getLocalIp().isEmpty() ? "*" : this.getLocalIp(), this.getPort());
-
- try {
-- this.getConnection().startTcpServerListener(inetaddress, this.getPort());
-+ this.getConnection().bind(bindAddress); // Paper - Unix domain socket support
- } catch (IOException ioexception) {
- DedicatedServer.LOGGER.warn("**** FAILED TO BIND TO PORT!");
- DedicatedServer.LOGGER.warn("The exception was: {}", ioexception.toString());
-diff --git a/src/main/java/net/minecraft/server/network/ServerConnectionListener.java b/src/main/java/net/minecraft/server/network/ServerConnectionListener.java
-index c36089ead51d2e7dc3369d5f9a1869f58ff5391c..bfa519b9335c960a5baec50b0da95d95cd5ee958 100644
---- a/src/main/java/net/minecraft/server/network/ServerConnectionListener.java
-+++ b/src/main/java/net/minecraft/server/network/ServerConnectionListener.java
-@@ -78,7 +78,12 @@ public class ServerConnectionListener {
- this.running = true;
- }
-
-+ // Paper start
- public void startTcpServerListener(@Nullable InetAddress address, int port) throws IOException {
-+ bind(new java.net.InetSocketAddress(address, port));
-+ }
-+ public void bind(java.net.SocketAddress address) throws IOException {
-+ // Paper end
- List list = this.channels;
-
- synchronized (this.channels) {
-@@ -86,7 +91,11 @@ public class ServerConnectionListener {
- LazyLoadedValue lazyinitvar;
-
- if (Epoll.isAvailable() && this.server.isEpollEnabled()) {
-+ if (address instanceof io.netty.channel.unix.DomainSocketAddress) {
-+ oclass = io.netty.channel.epoll.EpollServerDomainSocketChannel.class;
-+ } else {
- oclass = EpollServerSocketChannel.class;
-+ }
- lazyinitvar = ServerConnectionListener.SERVER_EPOLL_EVENT_GROUP;
- ServerConnectionListener.LOGGER.info("Using epoll channel type");
- } else {
-@@ -114,7 +123,7 @@ public class ServerConnectionListener {
- ((Connection) object).setListener(new ServerHandshakePacketListenerImpl(ServerConnectionListener.this.server, (Connection) object));
- io.papermc.paper.network.ChannelInitializeListenerHolder.callListeners(channel); // Paper
- }
-- }).group((EventLoopGroup) lazyinitvar.get()).localAddress(address, port)).option(ChannelOption.AUTO_READ, false).bind().syncUninterruptibly()); // CraftBukkit
-+ }).group((EventLoopGroup) lazyinitvar.get()).localAddress(address)).option(ChannelOption.AUTO_READ, false).bind().syncUninterruptibly()); // CraftBukkit // Paper
- }
- }
-
-diff --git a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
-index f74b6d2110e51c76eeb1aea7665153509b6e6371..e76b9670213de966ee275e624e7ee5f673d3f210 100644
---- a/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
-+++ b/src/main/java/net/minecraft/server/network/ServerHandshakePacketListenerImpl.java
-@@ -44,6 +44,7 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
- this.connection.setProtocol(ConnectionProtocol.LOGIN);
- // CraftBukkit start - Connection throttle
- try {
-+ if (!(this.connection.channel.localAddress() instanceof io.netty.channel.unix.DomainSocketAddress)) { // Paper - the connection throttle is useless when you have a Unix domain socket
- long currentTime = System.currentTimeMillis();
- long connectionThrottle = this.server.server.getConnectionThrottle();
- InetAddress address = ((java.net.InetSocketAddress) this.connection.getRemoteAddress()).getAddress();
-@@ -72,6 +73,7 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
- }
- }
- }
-+ } // Paper - add closing bracket for if check above
- } catch (Throwable t) {
- org.apache.logging.log4j.LogManager.getLogger().debug("Failed to check connection throttle", t);
- }
-@@ -120,8 +122,11 @@ public class ServerHandshakePacketListenerImpl implements ServerHandshakePacketL
- // Paper end
- // if (org.spigotmc.SpigotConfig.bungee) { // Paper - comment out, we check above!
- if ( ( split.length == 3 || split.length == 4 ) && ( ServerHandshakePacketListenerImpl.BYPASS_HOSTCHECK || ServerHandshakePacketListenerImpl.HOST_PATTERN.matcher( split[1] ).matches() ) ) { // Paper
-+ // Paper start - Unix domain socket support
-+ java.net.SocketAddress socketAddress = connection.getRemoteAddress();
- packet.hostName = split[0];
-- connection.address = new java.net.InetSocketAddress(split[1], ((java.net.InetSocketAddress) this.connection.getRemoteAddress()).getPort());
-+ connection.address = new java.net.InetSocketAddress(split[1], socketAddress instanceof java.net.InetSocketAddress ? ((java.net.InetSocketAddress) socketAddress).getPort() : 0);
-+ // Paper end
- connection.spoofedUUID = com.mojang.util.UUIDTypeAdapter.fromString( split[2] );
- } else
- {