From c6f937f6607d11da1adede171086b50576e55e43 Mon Sep 17 00:00:00 2001 From: Nassim Jahnke Date: Thu, 9 Jun 2022 14:27:48 +0200 Subject: [PATCH] Fix config migration error preventing server startup There's at least two more, but those are less pressing --- patches/server/Add-packet-limiter-config.patch | 2 +- patches/server/Paper-config-files.patch | 10 +++++++++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/patches/server/Add-packet-limiter-config.patch b/patches/server/Add-packet-limiter-config.patch index a0ca4a3871..0a6b78d2df 100644 --- a/patches/server/Add-packet-limiter-config.patch +++ b/patches/server/Add-packet-limiter-config.patch @@ -10,7 +10,7 @@ packet-limiter: all: interval: 7.0 max-packet-rate: 500.0 - PacketPlayInAutoRecipe: + ServerboundPlaceRecipePacket: interval: 4.0 max-packet-rate: 5.0 action: DROP diff --git a/patches/server/Paper-config-files.patch b/patches/server/Paper-config-files.patch index acc6d248c9..14c281e4a6 100644 --- a/patches/server/Paper-config-files.patch +++ b/patches/server/Paper-config-files.patch @@ -1913,6 +1913,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + final String fullClassName = "net.minecraft.network.protocol." + subpackage + "." + obj; + try { + packetClass = Class.forName(fullClassName); ++ break; + } catch (final ClassNotFoundException ex) { + final @Nullable String spigotClassName = MOJANG_TO_OBF.get(fullClassName); + if (spigotClassName != null) { @@ -1930,6 +1931,7 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + + @Override + protected Object serialize(final Class> item, final Predicate> typeSupported) { ++ //TODO always serialize the mapped class name to not break on switching between mapped/unmapped servers + return item.getSimpleName(); + } +} @@ -2851,10 +2853,16 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000 + return new Object[]{"entities", "spawning", "duplicate-uuid", "mode"}; + }); + ++ builder.addAction(path("redstone-implementation"), (path, value) -> { ++ if (value.require(String.class).equalsIgnoreCase("alternate-current")) { ++ value.set("alternate_current"); ++ } ++ return new Object[]{"misc", "redstone-implementation"}; ++ }); ++ + moveToMisc(builder, "light-queue-size"); + moveToMisc(builder, "update-pathfinding-on-block-update"); + moveToMisc(builder, "show-sign-click-command-failure-msgs-to-player"); -+ moveToMisc(builder, "redstone-implementation"); + moveToMisc(builder, "max-leash-distance"); + + return builder.build();