2020-05-06 11:48:49 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
2019-07-20 06:01:24 +02:00
|
|
|
From: Shane Freeder <theboyetronic@gmail.com>
|
|
|
|
Date: Sun, 11 Nov 2018 21:01:09 +0000
|
|
|
|
Subject: [PATCH] Don't allow digging into unloaded chunks
|
|
|
|
|
|
|
|
|
|
|
|
diff --git a/src/main/java/net/minecraft/server/PlayerConnection.java b/src/main/java/net/minecraft/server/PlayerConnection.java
|
2021-03-02 04:07:12 +01:00
|
|
|
index fa74b0266172bf83339f85a4e739bbf2256e4ccf..a448773cc46889df37d563beb227beaa433d726e 100644
|
2019-07-20 06:01:24 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/PlayerConnection.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PlayerConnection.java
|
2021-02-22 19:24:44 +01:00
|
|
|
@@ -1372,6 +1372,11 @@ public class PlayerConnection implements PacketListenerPlayIn {
|
2019-07-20 06:01:24 +02:00
|
|
|
case START_DESTROY_BLOCK:
|
|
|
|
case ABORT_DESTROY_BLOCK:
|
|
|
|
case STOP_DESTROY_BLOCK:
|
|
|
|
+ // Paper start - Don't allow digging in unloaded chunks
|
|
|
|
+ if (this.player.world.getChunkIfLoadedImmediately(blockposition.getX() >> 4, blockposition.getZ() >> 4) == null) {
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Paper end - Don't allow digging in unloaded chunks
|
|
|
|
this.player.playerInteractManager.a(blockposition, packetplayinblockdig_enumplayerdigtype, packetplayinblockdig.c(), this.minecraftServer.getMaxBuildHeight());
|
|
|
|
return;
|
|
|
|
default:
|
2020-04-13 05:56:29 +02:00
|
|
|
diff --git a/src/main/java/net/minecraft/server/PlayerInteractManager.java b/src/main/java/net/minecraft/server/PlayerInteractManager.java
|
2021-03-09 00:12:31 +01:00
|
|
|
index daeaae8072a12b1d5f0718ba9e5bdd4f9c0e2169..21acea46a288348cbc2d4fa312035d6679987399 100644
|
2020-04-13 05:56:29 +02:00
|
|
|
--- a/src/main/java/net/minecraft/server/PlayerInteractManager.java
|
|
|
|
+++ b/src/main/java/net/minecraft/server/PlayerInteractManager.java
|
2021-03-09 00:12:31 +01:00
|
|
|
@@ -81,8 +81,8 @@ public class PlayerInteractManager {
|
2020-05-23 00:57:48 +02:00
|
|
|
IBlockData iblockdata;
|
|
|
|
|
2020-06-25 16:09:55 +02:00
|
|
|
if (this.j) {
|
|
|
|
- iblockdata = this.world.getType(this.k);
|
2020-05-23 00:57:48 +02:00
|
|
|
- if (iblockdata.isAir()) {
|
2020-06-25 16:09:55 +02:00
|
|
|
+ iblockdata = this.world.getTypeIfLoaded(this.k); // Paper
|
2020-05-23 00:57:48 +02:00
|
|
|
+ if (iblockdata == null || iblockdata.isAir()) { // Paper
|
2020-06-25 16:09:55 +02:00
|
|
|
this.j = false;
|
2020-05-23 00:57:48 +02:00
|
|
|
} else {
|
2020-06-25 16:09:55 +02:00
|
|
|
float f = this.a(iblockdata, this.k, this.l);
|
2021-03-09 00:12:31 +01:00
|
|
|
@@ -93,7 +93,13 @@ public class PlayerInteractManager {
|
2020-05-23 00:57:48 +02:00
|
|
|
}
|
|
|
|
}
|
2020-06-25 16:09:55 +02:00
|
|
|
} else if (this.f) {
|
|
|
|
- iblockdata = this.world.getType(this.h);
|
2020-05-23 00:57:48 +02:00
|
|
|
+ // Paper start - don't want to do same logic as above, return instead
|
2020-06-25 16:09:55 +02:00
|
|
|
+ iblockdata = this.world.getTypeIfLoaded(this.h);
|
2020-05-23 00:57:48 +02:00
|
|
|
+ if (iblockdata == null) {
|
2020-06-25 16:09:55 +02:00
|
|
|
+ this.f = false;
|
2020-05-23 00:57:48 +02:00
|
|
|
+ return;
|
|
|
|
+ }
|
|
|
|
+ // Paper end
|
|
|
|
if (iblockdata.isAir()) {
|
2020-06-25 16:09:55 +02:00
|
|
|
this.world.a(this.player.getId(), this.h, -1);
|
|
|
|
this.m = -1;
|
2021-03-09 00:12:31 +01:00
|
|
|
@@ -257,10 +263,12 @@ public class PlayerInteractManager {
|
2020-04-13 05:56:29 +02:00
|
|
|
this.player.playerConnection.sendPacket(new PacketPlayOutBlockBreak(blockposition, this.world.getType(blockposition), packetplayinblockdig_enumplayerdigtype, true, "stopped destroying"));
|
|
|
|
} else if (packetplayinblockdig_enumplayerdigtype == PacketPlayInBlockDig.EnumPlayerDigType.ABORT_DESTROY_BLOCK) {
|
2020-06-25 16:09:55 +02:00
|
|
|
this.f = false;
|
|
|
|
- if (!Objects.equals(this.h, blockposition)) {
|
|
|
|
+ if (!Objects.equals(this.h, blockposition) && !BlockPosition.ZERO.equals(this.h)) {
|
|
|
|
PlayerInteractManager.LOGGER.debug("Mismatch in destroy block pos: " + this.h + " " + blockposition); // CraftBukkit - SPIGOT-5457 sent by client when interact event cancelled
|
|
|
|
- this.world.a(this.player.getId(), this.h, -1);
|
|
|
|
- this.player.playerConnection.sendPacket(new PacketPlayOutBlockBreak(this.h, this.world.getType(this.h), packetplayinblockdig_enumplayerdigtype, true, "aborted mismatched destroying"));
|
|
|
|
+ IBlockData type = this.world.getTypeIfLoaded(this.h); // Paper - don't load unloaded chunks for stale records here
|
|
|
|
+ if (type != null) this.world.a(this.player.getId(), this.h, -1); // Paper
|
|
|
|
+ if (type != null) this.player.playerConnection.sendPacket(new PacketPlayOutBlockBreak(this.h, type, packetplayinblockdig_enumplayerdigtype, true, "aborted mismatched destroying")); // Paper
|
|
|
|
+ this.h = BlockPosition.ZERO; // Paper
|
2020-04-13 05:56:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
this.world.a(this.player.getId(), blockposition, -1);
|