From fd0a8f29ed86a8d5afdec1c30f0215bb405b188b Mon Sep 17 00:00:00 2001
From: moo <48740106+moom0o@users.noreply.github.com>
Date: Sun, 14 Feb 2021 00:54:04 -0500
Subject: [PATCH] Packetfly patch
---
README.md | 13 ++++---
pom.xml | 2 +-
.../me/moomoo/anarchyexploitfixes/Main.java | 34 ++++++++++++++++---
.../anarchyexploitfixes/patches/Elytra.java | 22 ++++++------
src/main/resources/config.yml | 9 +++--
5 files changed, 56 insertions(+), 24 deletions(-)
diff --git a/README.md b/README.md
index 72afbf754..8d3dbb2f0 100644
--- a/README.md
+++ b/README.md
@@ -54,7 +54,6 @@ DisableWithers: false
DisableExplosions: false
FixChatcoIgnoreBug: true
FixWorldStatsCommandBug: true
-PreventGodMode: true
# Attempt to prevent chunk bans/fps lag.
PreventChunkBan: true
MaxEnchantmentTablePerChunk: 16
@@ -62,7 +61,7 @@ MaxEnderchestPerChunk: 64
MaxContainerPerChunk: 1000
MaxSignPerChunk: 100
# Antispam time in seconds
-AntiSpamTime: 3
+AntiSpamTime: 1
AntiSpamWordTime: 60
AntiSpamLinkTime: 300
PreventUnicodeDot: true
@@ -130,6 +129,12 @@ PatchPacketElytraFly: false
# Recommended to not go lower as there could be false positives.
MaxElytraOpensPer10Seconds: 25 # Will only allow players to go about 85km/h on kami blue, and won't even work on rusherhack.
+# Patch future/rusher packet fly
+PatchPacketFly: true
+# Max teleport packets per 10 seconds, this is how the packet fly works, 25 is usually fine, if you go lower players may get stuck.
+MaxTeleportPacketsPer10Seconds: 25
+LogPacketFlyEvents: true
+
# Patch futureclient boat fly exploit
# Note: this also prevents boats on land. Boats in water are fine
BoatflyPatch: true
@@ -190,6 +195,4 @@ FallingBlocks: 19
## Missing features
-* Modified god mode patch - Was removed because the original code was so shit that when reloaded with plugman all the players will get kicked, aswell as breaking support for anything other than 1.12.2. Please use my standalone plugin for this (1.12.2 only): https://github.com/moom0o/AntiGodMode
-## Probably won't fix
-* Packet fly - It's so slow it would be useless to patch. Might as well allow your players to go the same or less speed than walking :^)
+* Modified god mode patch - Was removed because the original code was so shit that when reloaded with plugman all the players will get kicked, aswell as breaking support for anything other than 1.12.2. Please use my standalone plugin for this (1.12.2 only): https://github.com/moom0o/AntiGodMode
\ No newline at end of file
diff --git a/pom.xml b/pom.xml
index c44cf8c2e..737bea347 100644
--- a/pom.xml
+++ b/pom.xml
@@ -6,7 +6,7 @@
me.moomoo
anarchyexploitfixes
- 16.0
+ 17.0
jar
AnarchyExploitFixes
diff --git a/src/main/java/me/moomoo/anarchyexploitfixes/Main.java b/src/main/java/me/moomoo/anarchyexploitfixes/Main.java
index 41fb455e1..4230959fc 100644
--- a/src/main/java/me/moomoo/anarchyexploitfixes/Main.java
+++ b/src/main/java/me/moomoo/anarchyexploitfixes/Main.java
@@ -9,10 +9,7 @@
import me.moomoo.anarchyexploitfixes.misc.*;
import me.moomoo.anarchyexploitfixes.patches.*;
import me.moomoo.anarchyexploitfixes.prevention.*;
-import org.bukkit.Bukkit;
-import org.bukkit.ChatColor;
-import org.bukkit.Chunk;
-import org.bukkit.Material;
+import org.bukkit.*;
import org.bukkit.configuration.file.FileConfiguration;
import org.bukkit.entity.Boat;
import org.bukkit.entity.Player;
@@ -30,6 +27,7 @@ public class Main extends JavaPlugin implements Listener {
static HashSet crafting = new HashSet<>();
public final HashMap newChunks = new HashMap<>();
public final HashMap oldChunks = new HashMap<>();
+ public HashMap levels = new HashMap<>();
public FileConfiguration config = getConfig();
private Logger log;
@@ -78,6 +76,34 @@ public void onPacketReceiving(PacketEvent event) {
}
});
}
+ if (config.getBoolean("PreventPacketFly")) {
+ protocolManager.addPacketListener(
+ new PacketAdapter(this, ListenerPriority.HIGHEST, PacketType.Play.Client.TELEPORT_ACCEPT) {
+ @Override
+ public void onPacketReceiving(PacketEvent event) {
+ Player e = event.getPlayer();
+ Location l = event.getPlayer().getLocation();
+ if (event.getPlayer().getWorld().getBlockAt(l.getBlockX(), l.getBlockY() - 1, l.getBlockZ()).getType() == Material.AIR && !e.isGliding() && !e.isInsideVehicle()) {
+ if (event.getPacketType() == PacketType.Play.Client.TELEPORT_ACCEPT) {
+ if (levels.get(e) != null) {
+ if (levels.get(e) > config.getInt("MaxTeleportPacketsPer10Seconds")) {
+ event.setCancelled(true);
+ if (getConfig().getBoolean("LogPacketFlyEvents")) {
+ plugin.getLogger().warning(e.getName() + " prevented from packetflying");
+ }
+ } else {
+ levels.merge(e, 1, Integer::sum);
+ Bukkit.getServer().getScheduler().runTaskLater(plugin, () -> levels.put(e, levels.get(e) - 1), 200L);
+ }
+ } else {
+ levels.put(e, 1);
+ Bukkit.getServer().getScheduler().runTaskLater(plugin, () -> levels.put(e, levels.get(e) - 1), 200L);
+ }
+ }
+ }
+ }
+ });
+ }
} else {
getLogger().warning("Did not detect ProtocolLib, disabling packet patches");
}
diff --git a/src/main/java/me/moomoo/anarchyexploitfixes/patches/Elytra.java b/src/main/java/me/moomoo/anarchyexploitfixes/patches/Elytra.java
index ddeedafdc..f8e6ee8de 100644
--- a/src/main/java/me/moomoo/anarchyexploitfixes/patches/Elytra.java
+++ b/src/main/java/me/moomoo/anarchyexploitfixes/patches/Elytra.java
@@ -200,22 +200,20 @@ public void onOpen(EntityToggleGlideEvent evt) {
PlayerInventory i = ((Player) evt.getEntity()).getInventory();
if (evt.getEntity() instanceof Player) {
Player e = (Player) evt.getEntity();
- if (evt.getEntity().getName().equals("moom0o")) {
- if (levels.get(e) != null) {
- if (levels.get(e) > plugin.config.getInt("MaxElytraOpensPer10Seconds")) {
- if (i.getChestplate() != null && i.getChestplate().getType().equals(Material.ELYTRA)) {
- ItemStack elytra = i.getChestplate();
- i.setChestplate(null);
- evt.getEntity().getWorld().dropItemNaturally(i.getLocation(), elytra);
- }
- } else {
- levels.merge(e, 1, Integer::sum);
- Bukkit.getServer().getScheduler().runTaskLater(plugin, () -> levels.put(e, levels.get(e) - 1), 200L);
+ if (levels.get(e) != null) {
+ if (levels.get(e) > plugin.config.getInt("MaxElytraOpensPer10Seconds")) {
+ if (i.getChestplate() != null && i.getChestplate().getType().equals(Material.ELYTRA)) {
+ ItemStack elytra = i.getChestplate();
+ i.setChestplate(null);
+ evt.getEntity().getWorld().dropItemNaturally(i.getLocation(), elytra);
}
} else {
- levels.put(e, 1);
+ levels.merge(e, 1, Integer::sum);
Bukkit.getServer().getScheduler().runTaskLater(plugin, () -> levels.put(e, levels.get(e) - 1), 200L);
}
+ } else {
+ levels.put(e, 1);
+ Bukkit.getServer().getScheduler().runTaskLater(plugin, () -> levels.put(e, levels.get(e) - 1), 200L);
}
}
}
diff --git a/src/main/resources/config.yml b/src/main/resources/config.yml
index f48062e24..615342126 100644
--- a/src/main/resources/config.yml
+++ b/src/main/resources/config.yml
@@ -32,7 +32,6 @@ DisableWithers: false
DisableExplosions: false
FixChatcoIgnoreBug: true
FixWorldStatsCommandBug: true
-PreventGodMode: true
# Attempt to prevent chunk bans/fps lag.
PreventChunkBan: true
MaxEnchantmentTablePerChunk: 16
@@ -40,7 +39,7 @@ MaxEnderchestPerChunk: 64
MaxContainerPerChunk: 1000
MaxSignPerChunk: 100
# Antispam time in seconds
-AntiSpamTime: 3
+AntiSpamTime: 1
AntiSpamWordTime: 60
AntiSpamLinkTime: 300
PreventUnicodeDot: true
@@ -108,6 +107,12 @@ PatchPacketElytraFly: false
# Recommended to not go lower as there could be false positives.
MaxElytraOpensPer10Seconds: 25 # Will only allow players to go about 85km/h on kami blue, and won't even work on rusherhack.
+# Patch future/rusher packet fly
+PatchPacketFly: true
+# Max teleport packets per 10 seconds, this is how the packet fly works, 25 is usually fine, if you go lower players may get stuck.
+MaxTeleportPacketsPer10Seconds: 25
+LogPacketFlyEvents: true
+
# Patch futureclient boat fly exploit
# Note: this also prevents boats on land. Boats in water are fine
BoatflyPatch: true