aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLinnea Gräf <nea@nea.moe>2024-07-22 03:13:17 +0200
committerLinnea Gräf <nea@nea.moe>2024-07-22 03:17:29 +0200
commit8ff53b3c451479503deb2477bb88c9492d02fffe (patch)
treef7eb1476f6d192ed06834532f1958a3c69f37e2b
parent0859fa773b2cc3496ae51bcad622bca0a596621b (diff)
downloadFirmament-8ff53b3c451479503deb2477bb88c9492d02fffe.tar.gz
Firmament-8ff53b3c451479503deb2477bb88c9492d02fffe.tar.bz2
Firmament-8ff53b3c451479503deb2477bb88c9492d02fffe.zip
Fix incompatibility with dulkis skin signature patch
-rw-r--r--src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatch.java8
-rw-r--r--src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatchForSession.java29
2 files changed, 37 insertions, 0 deletions
diff --git a/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatch.java b/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatch.java
index 4c1f3be..56f4f16 100644
--- a/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatch.java
+++ b/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatch.java
@@ -1,5 +1,6 @@
/*
* SPDX-FileCopyrightText: 2023 Linnea Gräf <nea@nea.moe>
+ * SPDX-FileCopyrightText: 2024 Linnea Gräf <nea@nea.moe>
*
* SPDX-License-Identifier: GPL-3.0-or-later
*/
@@ -24,6 +25,13 @@ public class PropertySignatureIgnorePatch {
}
}
+ @Inject(method = "signature", cancellable = true, at = @At("HEAD"), remap = false)
+ public void returnEmptySignatureInsteadOfNull(CallbackInfoReturnable<String> cir) {
+ if (Fixes.TConfig.INSTANCE.getFixUnsignedPlayerSkins()) {
+ cir.setReturnValue("");
+ }
+ }
+
@Inject(method = "hasSignature", cancellable = true, at = @At("HEAD"), remap = false)
public void onHasSignature(CallbackInfoReturnable<Boolean> cir) {
if (Fixes.TConfig.INSTANCE.getFixUnsignedPlayerSkins()) {
diff --git a/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatchForSession.java b/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatchForSession.java
new file mode 100644
index 0000000..ed8545a
--- /dev/null
+++ b/src/main/java/moe/nea/firmament/mixins/PropertySignatureIgnorePatchForSession.java
@@ -0,0 +1,29 @@
+/*
+ * SPDX-FileCopyrightText: 2024 Linnea Gräf <nea@nea.moe>
+ *
+ * SPDX-License-Identifier: GPL-3.0-or-later
+ */
+
+package moe.nea.firmament.mixins;
+
+import com.mojang.authlib.SignatureState;
+import com.mojang.authlib.properties.Property;
+import com.mojang.authlib.yggdrasil.YggdrasilMinecraftSessionService;
+import moe.nea.firmament.features.fixes.Fixes;
+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.CallbackInfoReturnable;
+
+@Mixin(value = YggdrasilMinecraftSessionService.class, remap = false)
+public class PropertySignatureIgnorePatchForSession {
+ @Inject(method = "getPropertySignatureState", at = @At("HEAD"), cancellable = true, remap = false)
+ public void markEverythingAsSigned(Property property, CallbackInfoReturnable<SignatureState> cir) {
+ // Due to https://github.com/inglettronald/DulkirMod-Fabric/blob/22a3fc514a080fbe31f76f9ba7e85c36d8d0f67f/src/main/java/com/dulkirfabric/mixin/YggdrasilMinecraftSessionServiceMixin.java
+ // we sadly need to inject here too. Dulkirmod is very eager to early on mark a signature as unsigned
+ // and we want the opposite
+ if (Fixes.TConfig.INSTANCE.getFixUnsignedPlayerSkins()) {
+ cir.setReturnValue(SignatureState.SIGNED);
+ }
+ }
+}