diff --git a/gradle.properties b/gradle.properties
index 79713c793..e5bedb916 100644
--- a/gradle.properties
+++ b/gradle.properties
@@ -1,5 +1,5 @@
# gradle
-org.gradle.jvmargs=-Xmx8G -XX:+UseG1GC
+org.gradle.jvmargs=-Xmx8G
org.gradle.parallel=true
# minecraft and fabric
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/AbstractChatSession.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/AbstractChatSession.java
deleted file mode 100644
index 5d3c347e8..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/AbstractChatSession.java
+++ /dev/null
@@ -1,45 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures;
-
-import com.viaversion.viaversion.api.connection.StoredObject;
-import com.viaversion.viaversion.api.connection.UserConnection;
-import com.viaversion.viaversion.api.minecraft.ProfileKey;
-
-import java.security.PrivateKey;
-
-public abstract class AbstractChatSession extends StoredObject {
- private final ProfileKey profileKey;
-
- private final MessageSigner signer;
-
- public AbstractChatSession(UserConnection user, final ProfileKey profileKey, final PrivateKey privateKey) {
- super(user);
- this.profileKey = profileKey;
-
- this.signer = MessageSigner.create(privateKey, "SHA256withRSA");
- }
-
- public ProfileKey getProfileKey() {
- return profileKey;
- }
-
- public MessageSigner getSigner() {
- return signer;
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/MessageSigner.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/MessageSigner.java
deleted file mode 100644
index 85217270f..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/MessageSigner.java
+++ /dev/null
@@ -1,47 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures;
-
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.SignatureUpdatableModel;
-
-import java.security.*;
-
-public interface MessageSigner {
-
- byte[] sign(final SignatureUpdatableModel signer);
-
- static MessageSigner create(final PrivateKey privateKey, final String algorithm) {
- return signer -> {
- try {
- final Signature signature = Signature.getInstance(algorithm);
- signature.initSign(privateKey);
-
- signer.update(data -> {
- try {
- signature.update(data);
- } catch (SignatureException e) {
- throw new RuntimeException(e);
- }
- });
- return signature.sign();
- } catch (NoSuchAlgorithmException | InvalidKeyException | SignatureException e) {
- throw new IllegalStateException("Failed to sign message", e);
- }
- };
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/ChatSession1_19_0.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/ChatSession1_19_0.java
deleted file mode 100644
index 1a27b96e1..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/ChatSession1_19_0.java
+++ /dev/null
@@ -1,54 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_0;
-
-import com.viaversion.viaversion.api.connection.UserConnection;
-import com.viaversion.viaversion.api.minecraft.ProfileKey;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.util.JsonHelper;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageMetadataModel;
-import de.florianmichael.viafabricplus.definition.signatures.AbstractChatSession;
-import net.lenni0451.mcstructs.text.components.StringComponent;
-import net.lenni0451.mcstructs.text.serializer.TextComponentSerializer;
-
-import java.nio.ByteBuffer;
-import java.nio.ByteOrder;
-import java.nio.charset.StandardCharsets;
-import java.security.PrivateKey;
-import java.time.Instant;
-import java.util.UUID;
-
-public class ChatSession1_19_0 extends AbstractChatSession {
-
- public ChatSession1_19_0(UserConnection user, ProfileKey profileKey, PrivateKey privateKey) {
- super(user, profileKey, privateKey);
- }
-
- public byte[] sign(final UUID sender, final MessageMetadataModel messageMetadata) {
- return getSigner().sign(updater -> {
- final byte[] data = new byte[32];
- final ByteBuffer buffer = ByteBuffer.wrap(data).order(ByteOrder.BIG_ENDIAN);
-
- buffer.putLong(messageMetadata.salt());
- buffer.putLong(sender.getMostSignificantBits()).putLong(sender.getLeastSignificantBits());
- buffer.putLong(Instant.ofEpochMilli(messageMetadata.timestamp()).getEpochSecond());
-
- updater.update(data);
- updater.update(JsonHelper.toSortedString(TextComponentSerializer.V1_18.serializeJson(new StringComponent(messageMetadata.plain()))).getBytes(StandardCharsets.UTF_8));
- });
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/provider/CommandArgumentsProvider.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/provider/CommandArgumentsProvider.java
deleted file mode 100644
index 8fa3270c8..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/provider/CommandArgumentsProvider.java
+++ /dev/null
@@ -1,30 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_0.provider;
-
-import com.viaversion.viaversion.api.platform.providers.Provider;
-import com.viaversion.viaversion.util.Pair;
-
-import java.util.List;
-
-public class CommandArgumentsProvider implements Provider {
-
- public List> getSignedArguments(final String command) {
- return null;
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/util/JsonHelper.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/util/JsonHelper.java
deleted file mode 100644
index 9e75fcf92..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_0/util/JsonHelper.java
+++ /dev/null
@@ -1,98 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_0.util;
-
-import com.google.gson.JsonElement;
-import com.google.gson.JsonPrimitive;
-import com.google.gson.stream.JsonWriter;
-import org.jetbrains.annotations.Nullable;
-
-import java.io.IOException;
-import java.io.StringWriter;
-import java.util.*;
-
-public class JsonHelper {
-
- public static String toSortedString(JsonElement json) {
- StringWriter stringWriter = new StringWriter();
- JsonWriter jsonWriter = new JsonWriter(stringWriter);
-
- try {
- writeSorted(jsonWriter, json, Comparator.naturalOrder());
- } catch (IOException var4) {
- throw new AssertionError(var4);
- }
-
- return stringWriter.toString();
- }
-
- public static void writeSorted(JsonWriter writer, @Nullable JsonElement json, @Nullable Comparator comparator) throws IOException {
- if (json != null && !json.isJsonNull()) {
- if (json.isJsonPrimitive()) {
- JsonPrimitive jsonPrimitive = json.getAsJsonPrimitive();
- if (jsonPrimitive.isNumber()) {
- writer.value(jsonPrimitive.getAsNumber());
- } else if (jsonPrimitive.isBoolean()) {
- writer.value(jsonPrimitive.getAsBoolean());
- } else {
- writer.value(jsonPrimitive.getAsString());
- }
- } else {
- Iterator var5;
- if (json.isJsonArray()) {
- writer.beginArray();
- var5 = json.getAsJsonArray().iterator();
-
- while(var5.hasNext()) {
- JsonElement jsonElement = (JsonElement)var5.next();
- writeSorted(writer, jsonElement, comparator);
- }
-
- writer.endArray();
- } else {
- if (!json.isJsonObject()) {
- throw new IllegalArgumentException("Couldn't write " + json.getClass());
- }
-
- writer.beginObject();
- var5 = sort(json.getAsJsonObject().entrySet(), comparator).iterator();
-
- while(var5.hasNext()) {
- Map.Entry entry = (Map.Entry)var5.next();
- writer.name((String)entry.getKey());
- writeSorted(writer, (JsonElement)entry.getValue(), comparator);
- }
-
- writer.endObject();
- }
- }
- } else {
- writer.nullValue();
- }
- }
-
- private static Collection> sort(Collection> entries, @Nullable Comparator comparator) {
- if (comparator == null) {
- return entries;
- } else {
- List> list = new ArrayList(entries);
- list.sort(Map.Entry.comparingByKey(comparator));
- return list;
- }
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/ChatSession1_19_2.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/ChatSession1_19_2.java
deleted file mode 100644
index 232133278..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/ChatSession1_19_2.java
+++ /dev/null
@@ -1,49 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2;
-
-import com.viaversion.viaversion.api.connection.UserConnection;
-import com.viaversion.viaversion.api.minecraft.PlayerMessageSignature;
-import com.viaversion.viaversion.api.minecraft.ProfileKey;
-import de.florianmichael.viafabricplus.definition.signatures.AbstractChatSession;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageMetadataModel;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageBodyModel;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageHeaderModel;
-
-import java.security.PrivateKey;
-import java.security.SecureRandom;
-import java.util.UUID;
-
-public class ChatSession1_19_2 extends AbstractChatSession {
- public final static SecureRandom SECURE_RANDOM = new SecureRandom();
-
- private byte[] precedingSignature = null;
-
- public ChatSession1_19_2(UserConnection user, ProfileKey profileKey, PrivateKey privateKey) {
- super(user, profileKey, privateKey);
- }
-
- public byte[] sign(final UUID sender, final MessageMetadataModel messageMetadata, final PlayerMessageSignature[] lastSeenMessages) {
- final MessageHeaderModel header = new MessageHeaderModel(sender, precedingSignature);
- final MessageBodyModel body = new MessageBodyModel(messageMetadata, lastSeenMessages);
-
- precedingSignature = getSigner().sign(updater -> header.updater(body.digestBytes(), updater));
-
- return precedingSignature;
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageBodyModel.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageBodyModel.java
deleted file mode 100644
index 9245b0bc7..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageBodyModel.java
+++ /dev/null
@@ -1,71 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model;
-
-import com.google.common.hash.Hashing;
-import com.google.common.hash.HashingOutputStream;
-import com.viaversion.viaversion.api.minecraft.PlayerMessageSignature;
-
-import java.io.*;
-import java.nio.charset.StandardCharsets;
-import java.time.Instant;
-
-@SuppressWarnings("UnstableApiUsage")
-public class MessageBodyModel {
- private final MessageMetadataModel messageMetadata;
- private final PlayerMessageSignature[] lastSeenMessages;
-
- public MessageBodyModel(MessageMetadataModel messageMetadata, PlayerMessageSignature[] lastSeenMessages) {
- this.messageMetadata = messageMetadata;
- this.lastSeenMessages = lastSeenMessages;
- }
-
- public void writeLastSeenMessage(final DataOutput dataOutput) {
- for (PlayerMessageSignature seenMessage : lastSeenMessages) {
- try {
- dataOutput.writeByte(70);
- dataOutput.writeLong(seenMessage.uuid().getMostSignificantBits());
- dataOutput.writeLong(seenMessage.uuid().getLeastSignificantBits());
- dataOutput.write(seenMessage.signatureBytes());
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
- }
- }
-
- public byte[] digestBytes() {
- final HashingOutputStream hashingOutputStream = new HashingOutputStream(Hashing.sha256(), OutputStream.nullOutputStream());
- final DataOutputStream dataOutputStream = new DataOutputStream(hashingOutputStream);
-
- try {
- dataOutputStream.writeLong(messageMetadata.salt());
- dataOutputStream.writeLong(Instant.ofEpochMilli(messageMetadata.timestamp()).getEpochSecond());
-
- final OutputStreamWriter outputStreamWriter = new OutputStreamWriter(dataOutputStream, StandardCharsets.UTF_8);
- outputStreamWriter.write(messageMetadata.plain());
- outputStreamWriter.flush();
-
- dataOutputStream.write(70);
- writeLastSeenMessage(dataOutputStream);
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
-
- return hashingOutputStream.hash().asBytes();
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageHeaderModel.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageHeaderModel.java
deleted file mode 100644
index cdeef45bd..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageHeaderModel.java
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model;
-
-import java.nio.ByteBuffer;
-import java.nio.ByteOrder;
-import java.util.UUID;
-
-public record MessageHeaderModel(UUID sender, byte[] precedingSignature) {
-
- public byte[] toByteArray(final UUID uuid) {
- final byte[] data = new byte[16];
- final ByteBuffer byteBuffer = ByteBuffer.wrap(data).order(ByteOrder.BIG_ENDIAN);
-
- byteBuffer.putLong(uuid.getMostSignificantBits());
- byteBuffer.putLong(uuid.getLeastSignificantBits());
-
- return data;
- }
-
- public void updater(final byte[] bodyDigest, final SignatureUpdaterModel updater) {
- if (precedingSignature != null) {
- updater.update(precedingSignature);
- }
-
- updater.update(toByteArray(sender()));
- updater.update(bodyDigest);
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageMetadataModel.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageMetadataModel.java
deleted file mode 100644
index a60279e14..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/MessageMetadataModel.java
+++ /dev/null
@@ -1,21 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model;
-
-public record MessageMetadataModel(String plain, long timestamp, long salt) {
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdatableModel.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdatableModel.java
deleted file mode 100644
index 19170763f..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdatableModel.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model;
-
-public interface SignatureUpdatableModel {
-
- void update(final SignatureUpdaterModel updater);
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdaterModel.java b/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdaterModel.java
deleted file mode 100644
index 135be0674..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/definition/signatures/v1_19_2/model/SignatureUpdaterModel.java
+++ /dev/null
@@ -1,23 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model;
-
-public interface SignatureUpdaterModel {
-
- void update(final byte[] data);
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientLoginNetworkHandler.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientLoginNetworkHandler.java
deleted file mode 100644
index 5cee6c8b5..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientLoginNetworkHandler.java
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.injection.mixin.fixes.minecraft.network;
-
-import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
-import net.minecraft.client.network.ClientLoginNetworkHandler;
-import net.minecraft.network.ClientConnection;
-import net.minecraft.network.packet.Packet;
-import net.minecraft.network.packet.c2s.login.EnterConfigurationC2SPacket;
-import net.raphimc.vialoader.util.VersionEnum;
-import org.spongepowered.asm.mixin.Final;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.Shadow;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Redirect;
-
-@Mixin(ClientLoginNetworkHandler.class)
-public class MixinClientLoginNetworkHandler {
-
- @Shadow @Final private ClientConnection connection;
-
- @Redirect(method = "onSuccess", at = @At(value = "INVOKE", target = "Lnet/minecraft/network/ClientConnection;send(Lnet/minecraft/network/packet/Packet;)V"))
- public void sendPackets(ClientConnection instance, Packet> packet) {
- // Minecraft used to send these packets when the join game packet by the server is received
- if (ProtocolHack.getTargetVersion(connection.channel).isOlderThanOrEqualTo(VersionEnum.r1_20tor1_20_1) && !(packet instanceof EnterConfigurationC2SPacket)) return;
-
- instance.send(packet);
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientPlayNetworkHandler.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientPlayNetworkHandler.java
index c118f2a2e..ecdc5c02d 100644
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientPlayNetworkHandler.java
+++ b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/network/MixinClientPlayNetworkHandler.java
@@ -72,17 +72,6 @@ public void fixPlayerListOrdering(MinecraftClient client, ClientConnection clien
}
}
- @Inject(method = "onGameJoin", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/option/GameOptions;setServerViewDistance(I)V", shift = At.Shift.AFTER))
- public void sendBrandAndOptionPackets(GameJoinS2CPacket packet, CallbackInfo ci) {
- // Counterpart from MixinClientLoginNetworkHandler
- if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(VersionEnum.r1_20tor1_20_1)) {
- final var connection = this.getConnection();
-
- connection.send(new ClientOptionsC2SPacket(MinecraftClient.getInstance().options.getSyncedOptions()));
- connection.send(new CustomPayloadC2SPacket(new BrandCustomPayload(ClientBrandRetriever.getClientModName())));
- }
- }
-
@Inject(method = "onChunkLoadDistance", at = @At("RETURN"))
public void emulateSimulationDistance(ChunkLoadDistanceS2CPacket packet, CallbackInfo ci) {
if (ProtocolHack.getTargetVersion().isOlderThanOrEqualTo(VersionEnum.r1_17_1)) {
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/screen/MixinConnectScreen_1.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/screen/MixinConnectScreen_1.java
index c28d70397..29e5d1bcd 100644
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/screen/MixinConnectScreen_1.java
+++ b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/minecraft/screen/MixinConnectScreen_1.java
@@ -19,14 +19,14 @@
import com.viaversion.viaversion.api.connection.UserConnection;
import com.viaversion.viaversion.api.minecraft.ProfileKey;
+import com.viaversion.viaversion.api.minecraft.signature.storage.ChatSession1_19_0;
+import com.viaversion.viaversion.api.minecraft.signature.storage.ChatSession1_19_1;
import net.raphimc.mcauth.util.MicrosoftConstants;
import net.raphimc.vialoader.util.VersionEnum;
import de.florianmichael.viafabricplus.ViaFabricPlus;
import de.florianmichael.viafabricplus.definition.account.BedrockAccountHandler;
import de.florianmichael.viafabricplus.definition.account.ClassiCubeAccountHandler;
import de.florianmichael.viafabricplus.injection.access.IPublicKeyData;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.ChatSession1_19_0;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.ChatSession1_19_2;
import de.florianmichael.viafabricplus.protocolhack.ProtocolHack;
import de.florianmichael.viafabricplus.protocolhack.provider.vialegacy.ViaFabricPlusClassicMPPassProvider;
import de.florianmichael.viafabricplus.base.settings.groups.AuthenticationSettings;
@@ -49,7 +49,6 @@
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
import java.net.InetSocketAddress;
-import java.util.Optional;
import java.util.UUID;
@Mixin(targets = "net.minecraft.client.gui.screen.ConnectScreen$1")
@@ -120,20 +119,24 @@ public void setupConnectionSessions(CallbackInfo ci) {
return; // This disables the chat session emulation for all versions <= 1.18.2
}
if (targetVersion.isOlderThanOrEqualTo(VersionEnum.r1_19_1tor1_19_2)) {
- MinecraftClient.getInstance().getProfileKeys().fetchKeyPair().thenAcceptAsync(optional -> optional.ifPresentOrElse(playerKeyPair -> {
- final PlayerPublicKey.PublicKeyData publicKeyData = playerKeyPair.publicKey().data();
+ final var profile = MinecraftClient.getInstance().getProfileKeys().fetchKeyPair().join().orElse(null);
+ if (profile != null) {
+ final PlayerPublicKey.PublicKeyData publicKeyData = profile.publicKey().data();
- userConnection.put(new ChatSession1_19_2(userConnection, new ProfileKey(publicKeyData.expiresAt().toEpochMilli(), publicKeyData.key().getEncoded(), publicKeyData.keySignature()), playerKeyPair.privateKey()));
+ final UUID playerUuid = MinecraftClient.getInstance().getSession().getUuidOrNull();
+ userConnection.put(new ChatSession1_19_1(playerUuid, profile.privateKey(), new ProfileKey(publicKeyData.expiresAt().toEpochMilli(), publicKeyData.key().getEncoded(), publicKeyData.keySignature())));
if (targetVersion == VersionEnum.r1_19) {
final var legacyKey = ((IPublicKeyData) (Object) publicKeyData).viafabricplus_getV1Key();
if (legacyKey != null) {
- userConnection.put(new ChatSession1_19_0(userConnection, new ProfileKey(publicKeyData.expiresAt().toEpochMilli(), publicKeyData.key().getEncoded(), legacyKey.array()), playerKeyPair.privateKey()));
+ userConnection.put(new ChatSession1_19_0(playerUuid, profile.privateKey(), new ProfileKey(publicKeyData.expiresAt().toEpochMilli(), publicKeyData.key().getEncoded(), legacyKey.array())));
} else {
- ViaFabricPlus.LOGGER.error("Failed to get v1 key, can't setup ChatSession_0");
+ ViaFabricPlus.LOGGER.error("Failed to fetch legacy key, can't setup ChatSession");
}
}
- }, () -> ViaFabricPlus.LOGGER.error("Failed to fetch keyPair, can't setup ChatSession")));
+ } else {
+ ViaFabricPlus.LOGGER.error("Failed to fetch keyPair, can't setup ChatSession");
+ }
}
}
}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_14to1_13_2/MixinInventoryPackets_2.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_14to1_13_2/MixinInventoryPackets_2.java
deleted file mode 100644
index b177fd02b..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_14to1_13_2/MixinInventoryPackets_2.java
+++ /dev/null
@@ -1,33 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.injection.mixin.fixes.viaversion.protocol1_14to1_13_2;
-
-import com.viaversion.viaversion.api.protocol.packet.PacketWrapper;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
-
-@Mixin(targets = "com.viaversion.viaversion.protocols.protocol1_14to1_13_2.packets.InventoryPackets$2", remap = false)
-public class MixinInventoryPackets_2 {
-
- @Inject(method = "lambda$register$0", at = @At(value = "FIELD", target = "Lcom/viaversion/viaversion/api/type/Type;BOOLEAN:Lcom/viaversion/viaversion/api/type/types/BooleanType;", ordinal = 2, shift = At.Shift.BEFORE))
- public void removeWrongData(PacketWrapper wrapper, CallbackInfo ci) {
- wrapper.clearInputBuffer();
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_1to1_19/MixinProtocol1_19_1To1_19.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_1to1_19/MixinProtocol1_19_1To1_19.java
deleted file mode 100644
index e65bbeac1..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_1to1_19/MixinProtocol1_19_1To1_19.java
+++ /dev/null
@@ -1,132 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.injection.mixin.fixes.viaversion.protocol1_19_1to1_19;
-
-import com.viaversion.viaversion.api.Via;
-import com.viaversion.viaversion.api.protocol.AbstractProtocol;
-import com.viaversion.viaversion.api.protocol.packet.State;
-import com.viaversion.viaversion.api.protocol.remapper.PacketHandlers;
-import com.viaversion.viaversion.api.type.Type;
-import com.viaversion.viaversion.protocols.base.ClientboundLoginPackets;
-import com.viaversion.viaversion.protocols.base.ServerboundLoginPackets;
-import com.viaversion.viaversion.protocols.protocol1_19_1to1_19.ClientboundPackets1_19_1;
-import com.viaversion.viaversion.protocols.protocol1_19_1to1_19.Protocol1_19_1To1_19;
-import com.viaversion.viaversion.protocols.protocol1_19_1to1_19.ServerboundPackets1_19_1;
-import com.viaversion.viaversion.protocols.protocol1_19to1_18_2.ClientboundPackets1_19;
-import com.viaversion.viaversion.protocols.protocol1_19to1_18_2.ServerboundPackets1_19;
-import com.viaversion.viaversion.util.Pair;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageMetadataModel;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.provider.CommandArgumentsProvider;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.ChatSession1_19_0;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
-
-import java.util.UUID;
-
-@Mixin(Protocol1_19_1To1_19.class)
-public class MixinProtocol1_19_1To1_19 extends AbstractProtocol {
-
- @Inject(method = "registerPackets", at = @At("RETURN"), remap = false)
- public void injectRegisterPackets(CallbackInfo ci) {
- this.registerServerbound(State.LOGIN, ServerboundLoginPackets.HELLO.getId(), ServerboundLoginPackets.HELLO.getId(), new PacketHandlers() {
- public void register() {
- map(Type.STRING);
- read(Type.OPTIONAL_PROFILE_KEY);
- handler(wrapper -> {
- final ChatSession1_19_0 chatSession1190 = wrapper.user().get(ChatSession1_19_0.class);
-
- wrapper.write(Type.OPTIONAL_PROFILE_KEY, chatSession1190 == null ? null : chatSession1190.getProfileKey());
- });
- read(Type.OPTIONAL_UUID);
- }
- }, true);
- this.registerClientbound(State.LOGIN, ClientboundLoginPackets.HELLO.getId(), ClientboundLoginPackets.HELLO.getId(), new PacketHandlers() {
- public void register() {
- }
- }, true);
- this.registerServerbound(State.LOGIN, ServerboundLoginPackets.ENCRYPTION_KEY.getId(), ServerboundLoginPackets.ENCRYPTION_KEY.getId(), new PacketHandlers() {
- public void register() {
- }
- }, true);
- this.registerServerbound(ServerboundPackets1_19_1.CHAT_MESSAGE, ServerboundPackets1_19.CHAT_MESSAGE, new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Message
- map(Type.LONG); // Timestamp
- map(Type.LONG); // Salt
- map(Type.BYTE_ARRAY_PRIMITIVE); // Signature
- handler(wrapper -> {
- final UUID sender = wrapper.user().getProtocolInfo().getUuid();
- final String message = wrapper.get(Type.STRING, 0);
- final long timestamp = wrapper.get(Type.LONG, 0);
- final long salt = wrapper.get(Type.LONG, 1);
-
- final ChatSession1_19_0 chatSession1190 = wrapper.user().get(ChatSession1_19_0.class);
- if (chatSession1190 != null) {
- wrapper.set(Type.BYTE_ARRAY_PRIMITIVE, 0, chatSession1190.sign(sender, new MessageMetadataModel(message, timestamp, salt)));
- }
- });
- map(Type.BOOLEAN); // Signed preview
- read(Type.PLAYER_MESSAGE_SIGNATURE_ARRAY); // Last seen messages
- read(Type.OPTIONAL_PLAYER_MESSAGE_SIGNATURE); // Last received message
- }
- }, true);
- this.registerServerbound(ServerboundPackets1_19_1.CHAT_COMMAND, ServerboundPackets1_19.CHAT_COMMAND, new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Command
- map(Type.LONG); // Timestamp
- map(Type.LONG); // Salt
- map(Type.VAR_INT); // Signatures
-
- // Emulating old signatures
- handler(wrapper -> {
- final UUID sender = wrapper.user().getProtocolInfo().getUuid();
- final String command = wrapper.get(Type.STRING, 0);
- final long timestamp = wrapper.get(Type.LONG, 0);
- final long salt = wrapper.get(Type.LONG, 1);
-
- final ChatSession1_19_0 chatSession1190 = wrapper.user().get(ChatSession1_19_0.class);
- final CommandArgumentsProvider commandArgumentsProvider = Via.getManager().getProviders().get(CommandArgumentsProvider.class);
-
- if (chatSession1190 != null) {
- if (commandArgumentsProvider != null) {
- final int signatures = wrapper.get(Type.VAR_INT, 0);
- for (int i = 0; i < signatures; i++) {
- wrapper.read(Type.STRING); // Argument name
- wrapper.read(Type.BYTE_ARRAY_PRIMITIVE); // Signature
- }
-
- for (Pair argument : commandArgumentsProvider.getSignedArguments(command)) {
- final byte[] signature = chatSession1190.sign(sender, new MessageMetadataModel(argument.value(), timestamp, salt));
-
- wrapper.write(Type.STRING, argument.key());
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, signature);
- }
- }
- }
- });
- map(Type.BOOLEAN); // Signed preview
- read(Type.PLAYER_MESSAGE_SIGNATURE_ARRAY); // Last seen messages
- read(Type.OPTIONAL_PLAYER_MESSAGE_SIGNATURE); // Last received message
- }
- }, true);
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_3to1_19_1/MixinProtocol1_19_3To1_19_1.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_3to1_19_1/MixinProtocol1_19_3To1_19_1.java
deleted file mode 100644
index a877f59f2..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_19_3to1_19_1/MixinProtocol1_19_3To1_19_1.java
+++ /dev/null
@@ -1,196 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.injection.mixin.fixes.viaversion.protocol1_19_3to1_19_1;
-
-import com.google.common.primitives.Longs;
-import com.viaversion.viabackwards.protocol.protocol1_19_1to1_19_3.storage.NonceStorage;
-import com.viaversion.viaversion.api.Via;
-import com.viaversion.viaversion.api.protocol.AbstractProtocol;
-import com.viaversion.viaversion.api.protocol.packet.State;
-import com.viaversion.viaversion.api.protocol.remapper.PacketHandlers;
-import com.viaversion.viaversion.api.type.Type;
-import com.viaversion.viaversion.api.type.types.BitSetType;
-import com.viaversion.viaversion.api.type.types.ByteArrayType;
-import com.viaversion.viaversion.protocols.base.ClientboundLoginPackets;
-import com.viaversion.viaversion.protocols.base.ServerboundLoginPackets;
-import com.viaversion.viaversion.protocols.protocol1_19_1to1_19.ClientboundPackets1_19_1;
-import com.viaversion.viaversion.protocols.protocol1_19_1to1_19.ServerboundPackets1_19_1;
-import com.viaversion.viaversion.protocols.protocol1_19_3to1_19_1.ClientboundPackets1_19_3;
-import com.viaversion.viaversion.protocols.protocol1_19_3to1_19_1.Protocol1_19_3To1_19_1;
-import com.viaversion.viaversion.protocols.protocol1_19_3to1_19_1.ServerboundPackets1_19_3;
-import com.viaversion.viaversion.protocols.protocol1_19_3to1_19_1.storage.ReceivedMessagesStorage;
-import com.viaversion.viaversion.util.Pair;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.model.MessageMetadataModel;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.provider.CommandArgumentsProvider;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_2.ChatSession1_19_2;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.Unique;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
-
-import java.util.UUID;
-
-@Mixin(value = Protocol1_19_3To1_19_1.class, remap = false)
-public class MixinProtocol1_19_3To1_19_1 extends AbstractProtocol {
-
- @Unique
- private final static BitSetType ACKNOWLEDGED_BIT_SET_TYPE = new BitSetType(20);
-
- @Inject(method = "registerPackets", at = @At("RETURN"))
- public void fixKeys(CallbackInfo ci) {
- this.registerClientbound(State.LOGIN, ClientboundLoginPackets.HELLO.getId(), ClientboundLoginPackets.HELLO.getId(), new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Server-ID
- map(Type.BYTE_ARRAY_PRIMITIVE); // Public Key
- map(Type.BYTE_ARRAY_PRIMITIVE); // Nonce
- handler(wrapper -> wrapper.user().put(new NonceStorage(wrapper.get(Type.BYTE_ARRAY_PRIMITIVE, 1))));
- }
- }, true);
- this.registerServerbound(State.LOGIN, ServerboundLoginPackets.HELLO.getId(), ServerboundLoginPackets.HELLO.getId(), new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Name
- handler(wrapper -> {
- final ChatSession1_19_2 chatSession1192 = wrapper.user().get(ChatSession1_19_2.class);
- wrapper.write(Type.OPTIONAL_PROFILE_KEY, chatSession1192 != null ? chatSession1192.getProfileKey() : null); // Profile Key
- });
- map(Type.OPTIONAL_UUID); // UUID
- }
- }, true);
-
- this.registerServerbound(State.LOGIN, ServerboundLoginPackets.ENCRYPTION_KEY.getId(), ServerboundLoginPackets.ENCRYPTION_KEY.getId(), new PacketHandlers() {
- @Override
- public void register() {
- map(Type.BYTE_ARRAY_PRIMITIVE); // Keys
-
- handler(wrapper -> {
- final ChatSession1_19_2 chatSession1192 = wrapper.user().get(ChatSession1_19_2.class);
- final byte[] encryptedNonce = wrapper.read(Type.BYTE_ARRAY_PRIMITIVE);
-
- wrapper.write(Type.BOOLEAN, chatSession1192 == null);
- if (chatSession1192 != null) {
- final long salt = ChatSession1_19_2.SECURE_RANDOM.nextLong();
- final byte[] signedNonce = chatSession1192.getSigner().sign(updater -> {
- updater.update(wrapper.user().get(NonceStorage.class).nonce());
- updater.update(Longs.toByteArray(salt));
- });
-
- wrapper.write(Type.LONG, salt);
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, signedNonce);
- } else {
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, encryptedNonce);
- }
- });
- }
- }, true);
-
- registerServerbound(ServerboundPackets1_19_3.CHAT_COMMAND, ServerboundPackets1_19_1.CHAT_COMMAND, new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Command
- map(Type.LONG); // Timestamp
- map(Type.LONG); // Salt
- map(Type.VAR_INT); // Signatures
- handler(wrapper -> {
- final int signatures = wrapper.get(Type.VAR_INT, 0);
-
- final ChatSession1_19_2 chatSession1192 = wrapper.user().get(ChatSession1_19_2.class);
- final CommandArgumentsProvider commandArgumentsProvider = Via.getManager().getProviders().get(CommandArgumentsProvider.class);
-
- final boolean signingEnabled = chatSession1192 != null && commandArgumentsProvider != null;
-
- for (int i = 0; i < signatures; i++) {
- if (signingEnabled) {
- wrapper.read(Type.STRING); // Argument name
- wrapper.read(Type.SIGNATURE_BYTES); // Signature
- } else {
- wrapper.passthrough(Type.STRING); // Argument name
-
- // Signature
- wrapper.read(Type.SIGNATURE_BYTES);
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, new byte[0]);
- }
- }
-
- if (chatSession1192 != null) {
- final UUID sender = wrapper.user().getProtocolInfo().getUuid();
- final String command = wrapper.get(Type.STRING, 0);
- final long timestamp = wrapper.get(Type.LONG, 0);
- final long salt = wrapper.get(Type.LONG, 1);
-
- final ReceivedMessagesStorage messagesStorage = wrapper.user().get(ReceivedMessagesStorage.class);
-
- for (Pair argument : commandArgumentsProvider.getSignedArguments(command)) {
- final byte[] signature = chatSession1192.sign(sender, new MessageMetadataModel(argument.value(), timestamp, salt), messagesStorage.lastSignatures());
-
- wrapper.write(Type.STRING, argument.key());
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, signature);
- }
- }
-
- wrapper.write(Type.BOOLEAN, false); // No signed preview
-
- final ReceivedMessagesStorage messagesStorage = wrapper.user().get(ReceivedMessagesStorage.class);
- messagesStorage.resetUnacknowledgedCount();
- wrapper.write(Type.PLAYER_MESSAGE_SIGNATURE_ARRAY, messagesStorage.lastSignatures());
- wrapper.write(Type.OPTIONAL_PLAYER_MESSAGE_SIGNATURE, null);
- });
-
- read(Type.VAR_INT); // Offset
- read(ACKNOWLEDGED_BIT_SET_TYPE); // Acknowledged
- }
- }, true);
- registerServerbound(ServerboundPackets1_19_3.CHAT_MESSAGE, ServerboundPackets1_19_1.CHAT_MESSAGE, new PacketHandlers() {
- @Override
- public void register() {
- map(Type.STRING); // Command
- map(Type.LONG); // Timestamp
- map(Type.LONG); // Salt
- read(Type.OPTIONAL_SIGNATURE_BYTES); // Signature
- handler(wrapper -> {
- final ChatSession1_19_2 chatSession1192 = wrapper.user().get(ChatSession1_19_2.class);
- final ReceivedMessagesStorage messagesStorage = wrapper.user().get(ReceivedMessagesStorage.class);
-
- if (chatSession1192 != null) {
- final UUID sender = wrapper.user().getProtocolInfo().getUuid();
- final String message = wrapper.get(Type.STRING, 0);
- final long timestamp = wrapper.get(Type.LONG, 0);
- final long salt = wrapper.get(Type.LONG, 1);
-
- final byte[] signature = chatSession1192.sign(sender, new MessageMetadataModel(message, timestamp, salt), messagesStorage.lastSignatures());
-
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, signature);
- wrapper.write(Type.BOOLEAN, false); // Signed Preview - not implemented yet, but I could do it
- } else {
- wrapper.write(Type.BYTE_ARRAY_PRIMITIVE, new byte[0]); // Signature
- wrapper.write(Type.BOOLEAN, false); // No signed preview
- }
-
- messagesStorage.resetUnacknowledgedCount();
- wrapper.write(Type.PLAYER_MESSAGE_SIGNATURE_ARRAY, messagesStorage.lastSignatures());
- wrapper.write(Type.OPTIONAL_PLAYER_MESSAGE_SIGNATURE, null);
- });
-
- read(Type.VAR_INT); // Offset
- read(ACKNOWLEDGED_BIT_SET_TYPE); // Acknowledged
- }
- }, true);
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_9_1to1_9/MixinProtocol1_9_1To1_9.java b/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_9_1to1_9/MixinProtocol1_9_1To1_9.java
deleted file mode 100644
index 211f39f08..000000000
--- a/src/main/java/de/florianmichael/viafabricplus/injection/mixin/fixes/viaversion/protocol1_9_1to1_9/MixinProtocol1_9_1To1_9.java
+++ /dev/null
@@ -1,41 +0,0 @@
-/*
- * This file is part of ViaFabricPlus - https://github.com/FlorianMichael/ViaFabricPlus
- * Copyright (C) 2021-2023 FlorianMichael/EnZaXD and contributors
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU General Public License as published by
- * the Free Software Foundation, either version 3 of the License, or
- * (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU General Public License for more details.
- *
- * You should have received a copy of the GNU General Public License
- * along with this program. If not, see .
- */
-package de.florianmichael.viafabricplus.injection.mixin.fixes.viaversion.protocol1_9_1to1_9;
-
-import com.viaversion.viaversion.api.minecraft.ClientWorld;
-import com.viaversion.viaversion.api.protocol.AbstractProtocol;
-import com.viaversion.viaversion.api.type.types.chunk.ChunkType1_9_1;
-import com.viaversion.viaversion.protocols.protocol1_9_1to1_9.Protocol1_9_1To1_9;
-import com.viaversion.viaversion.protocols.protocol1_9to1_8.ClientboundPackets1_9;
-import com.viaversion.viaversion.protocols.protocol1_9to1_8.ServerboundPackets1_9;
-import org.spongepowered.asm.mixin.Mixin;
-import org.spongepowered.asm.mixin.injection.At;
-import org.spongepowered.asm.mixin.injection.Inject;
-import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
-
-@Mixin(value = Protocol1_9_1To1_9.class, remap = false)
-public class MixinProtocol1_9_1To1_9 extends AbstractProtocol {
-
- @Inject(method = "registerPackets", at = @At("RETURN"))
- public void clearInputBuffer(CallbackInfo ci) {
- registerClientbound(ClientboundPackets1_9.CHUNK_DATA, wrapper -> {
- wrapper.passthrough(ChunkType1_9_1.forEnvironment(wrapper.user().get(ClientWorld.class).getEnvironment()));
- wrapper.clearInputBuffer();
- });
- }
-}
diff --git a/src/main/java/de/florianmichael/viafabricplus/protocolhack/impl/ViaFabricPlusVLLoader.java b/src/main/java/de/florianmichael/viafabricplus/protocolhack/impl/ViaFabricPlusVLLoader.java
index 3dbda640f..7dd7001bf 100644
--- a/src/main/java/de/florianmichael/viafabricplus/protocolhack/impl/ViaFabricPlusVLLoader.java
+++ b/src/main/java/de/florianmichael/viafabricplus/protocolhack/impl/ViaFabricPlusVLLoader.java
@@ -18,23 +18,18 @@
package de.florianmichael.viafabricplus.protocolhack.impl;
import com.viaversion.viaversion.api.Via;
+import com.viaversion.viaversion.api.minecraft.signature.SignableCommandArgumentsProvider;
import com.viaversion.viaversion.api.platform.providers.ViaProviders;
import com.viaversion.viaversion.api.protocol.version.VersionProvider;
import com.viaversion.viaversion.protocols.protocol1_13to1_12_2.providers.PlayerLookTargetProvider;
import com.viaversion.viaversion.protocols.protocol1_16to1_15_2.provider.PlayerAbilitiesProvider;
import com.viaversion.viaversion.protocols.protocol1_9to1_8.providers.HandItemProvider;
import com.viaversion.viaversion.protocols.protocol1_9to1_8.providers.MovementTransmitterProvider;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.provider.CommandArgumentsProvider;
-import de.florianmichael.viafabricplus.protocolhack.provider.ViaFabricPlusCommandArgumentsProvider;
import de.florianmichael.viafabricplus.protocolhack.provider.viabedrock.ViaFabricPlusBlobCacheProvider;
import de.florianmichael.viafabricplus.protocolhack.provider.viabedrock.ViaFabricPlusNettyPipelineProvider;
import de.florianmichael.viafabricplus.protocolhack.provider.viabedrock.ViaFabricPlusTransferProvider;
import de.florianmichael.viafabricplus.protocolhack.provider.vialegacy.*;
-import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusBaseVersionProvider;
-import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusHandItemProvider;
-import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusMovementTransmitterProvider;
-import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusPlayerAbilitiesProvider;
-import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.ViaFabricPlusPlayerLookTargetProvider;
+import de.florianmichael.viafabricplus.protocolhack.provider.viaversion.*;
import net.raphimc.viabedrock.protocol.providers.BlobCacheProvider;
import net.raphimc.viabedrock.protocol.providers.NettyPipelineProvider;
import net.raphimc.viabedrock.protocol.providers.TransferProvider;
@@ -60,8 +55,7 @@ public void load() {
providers.use(HandItemProvider.class, new ViaFabricPlusHandItemProvider());
providers.use(PlayerLookTargetProvider.class, new ViaFabricPlusPlayerLookTargetProvider());
providers.use(PlayerAbilitiesProvider.class, new ViaFabricPlusPlayerAbilitiesProvider());
-
- providers.use(CommandArgumentsProvider.class, new ViaFabricPlusCommandArgumentsProvider());
+ providers.use(SignableCommandArgumentsProvider.class, new ViaFabricPlusCommandArgumentsProvider());
providers.use(OldAuthProvider.class, new ViaFabricPlusOldAuthProvider());
providers.use(ClassicWorldHeightProvider.class, new ViaFabricPlusClassicWorldHeightProvider());
diff --git a/src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/ViaFabricPlusCommandArgumentsProvider.java b/src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/viaversion/ViaFabricPlusCommandArgumentsProvider.java
similarity index 54%
rename from src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/ViaFabricPlusCommandArgumentsProvider.java
rename to src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/viaversion/ViaFabricPlusCommandArgumentsProvider.java
index 49c28de5e..833406b90 100644
--- a/src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/ViaFabricPlusCommandArgumentsProvider.java
+++ b/src/main/java/de/florianmichael/viafabricplus/protocolhack/provider/viaversion/ViaFabricPlusCommandArgumentsProvider.java
@@ -15,25 +15,29 @@
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
-package de.florianmichael.viafabricplus.protocolhack.provider;
+package de.florianmichael.viafabricplus.protocolhack.provider.viaversion;
+import com.viaversion.viaversion.api.minecraft.signature.SignableCommandArgumentsProvider;
import com.viaversion.viaversion.util.Pair;
-import de.florianmichael.viafabricplus.definition.signatures.v1_19_0.provider.CommandArgumentsProvider;
import net.minecraft.client.MinecraftClient;
-import net.minecraft.client.network.ClientPlayNetworkHandler;
import net.minecraft.command.argument.SignedArgumentList;
+import java.util.Collections;
import java.util.List;
-public class ViaFabricPlusCommandArgumentsProvider extends CommandArgumentsProvider {
+public class ViaFabricPlusCommandArgumentsProvider extends SignableCommandArgumentsProvider {
@Override
- public List> getSignedArguments(String command) {
- final ClientPlayNetworkHandler clientPlayNetworkHandler = MinecraftClient.getInstance().getNetworkHandler();
+ public List> getSignableArguments(String command) {
+ final var network = MinecraftClient.getInstance().getNetworkHandler();
+ if (network != null) {
+ return SignedArgumentList.of(
+ network.getCommandDispatcher().parse(command, network.getCommandSource())).
+ arguments().stream().
+ map(function -> new Pair<>(function.getNodeName(), function.value())).
+ toList();
- if (clientPlayNetworkHandler != null) {
- return SignedArgumentList.of(clientPlayNetworkHandler.getCommandDispatcher().parse(command, clientPlayNetworkHandler.getCommandSource())).arguments().stream().map(function -> new Pair<>(function.getNodeName(), function.value())).toList();
}
- return super.getSignedArguments(command);
+ return Collections.emptyList();
}
}
diff --git a/src/main/resources/viafabricplus.mixins.json b/src/main/resources/viafabricplus.mixins.json
index b43c30867..5c99f455e 100644
--- a/src/main/resources/viafabricplus.mixins.json
+++ b/src/main/resources/viafabricplus.mixins.json
@@ -115,7 +115,6 @@
"fixes.minecraft.item.MixinShovelItem",
"fixes.minecraft.item.MixinSwordItem",
"fixes.minecraft.network.MixinClientCommonNetworkHandler",
- "fixes.minecraft.network.MixinClientLoginNetworkHandler",
"fixes.minecraft.network.MixinClientPlayNetworkHandler",
"fixes.minecraft.packet.MixinChatMessageC2SPacket",
"fixes.minecraft.packet.MixinPacketByteBuf",
@@ -157,16 +156,12 @@
"fixes.viaversion.protocol1_13to1_12_2.MixinSkullHandler",
"fixes.viaversion.protocol1_13to1_12_2.MixinWorldPackets1_13",
"fixes.viaversion.protocol1_14to1_13_2.MixinInventoryPackets",
- "fixes.viaversion.protocol1_14to1_13_2.MixinInventoryPackets_2",
"fixes.viaversion.protocol1_15to1_14_4.MixinMetadataRewriter1_15To1_14_4",
"fixes.viaversion.protocol1_16_2to1_16_1.MixinWorldPackets_2",
"fixes.viaversion.protocol1_17to1_16_4.MixinEntityPackets1_17",
"fixes.viaversion.protocol1_17to1_16_4.MixinInventoryAcknowledgements",
"fixes.viaversion.protocol1_17to1_16_4.MixinWorldPackets1_17",
- "fixes.viaversion.protocol1_19_1to1_19.MixinProtocol1_19_1To1_19",
- "fixes.viaversion.protocol1_19_3to1_19_1.MixinProtocol1_19_3To1_19_1",
"fixes.viaversion.protocol1_19to1_18_2.MixinWorldPackets",
- "fixes.viaversion.protocol1_9_1to1_9.MixinProtocol1_9_1To1_9",
"fixes.viaversion.protocol1_9to1_8.MixinChunkType1_8",
"fixes.viaversion.protocol1_9to1_8.MixinCommandBlockProvider",
"fixes.viaversion.protocol1_9to1_8.MixinEntityPackets_6_1",