mirror of
https://github.com/LuckPerms/LuckPerms.git
synced 2025-01-14 12:11:42 +01:00
Update Forge to MC 1.20.6 (#3883)
This commit is contained in:
parent
484b04c17b
commit
5c1ea5633e
@ -4,8 +4,8 @@ plugins {
|
|||||||
alias(libs.plugins.forgegradle)
|
alias(libs.plugins.forgegradle)
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceCompatibility = 1.8
|
sourceCompatibility = 17
|
||||||
targetCompatibility = 17
|
targetCompatibility = 21
|
||||||
|
|
||||||
blossom {
|
blossom {
|
||||||
replaceTokenIn 'src/main/java/me/lucko/luckperms/forge/LPForgeBootstrap.java'
|
replaceTokenIn 'src/main/java/me/lucko/luckperms/forge/LPForgeBootstrap.java'
|
||||||
@ -23,10 +23,6 @@ dependencies {
|
|||||||
compileOnly project(':forge:forge-api')
|
compileOnly project(':forge:forge-api')
|
||||||
}
|
}
|
||||||
|
|
||||||
reobf {
|
|
||||||
shadowJar {}
|
|
||||||
}
|
|
||||||
|
|
||||||
shadowJar {
|
shadowJar {
|
||||||
archiveFileName = "luckperms-forge.jarinjar"
|
archiveFileName = "luckperms-forge.jarinjar"
|
||||||
|
|
||||||
|
@ -2,8 +2,8 @@ plugins {
|
|||||||
alias(libs.plugins.forgegradle)
|
alias(libs.plugins.forgegradle)
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceCompatibility = 1.8
|
sourceCompatibility = 17
|
||||||
targetCompatibility = 17
|
targetCompatibility = 21
|
||||||
|
|
||||||
minecraft {
|
minecraft {
|
||||||
mappings channel: 'official', version: minecraftVersion
|
mappings channel: 'official', version: minecraftVersion
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
minecraftVersion=1.20.4
|
minecraftVersion=1.20.6
|
||||||
forgeVersion=49.0.3
|
forgeVersion=50.0.9
|
@ -4,8 +4,8 @@ plugins {
|
|||||||
id("java-library")
|
id("java-library")
|
||||||
}
|
}
|
||||||
|
|
||||||
sourceCompatibility = 1.8
|
sourceCompatibility = 17
|
||||||
targetCompatibility = 17
|
targetCompatibility = 21
|
||||||
|
|
||||||
minecraft {
|
minecraft {
|
||||||
mappings channel: 'official', version: minecraftVersion
|
mappings channel: 'official', version: minecraftVersion
|
||||||
@ -43,10 +43,6 @@ processResources {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
reobf {
|
|
||||||
shadowJar {}
|
|
||||||
}
|
|
||||||
|
|
||||||
shadowJar {
|
shadowJar {
|
||||||
archiveFileName = "LuckPerms-Forge-${project.ext.fullVersion}.jar"
|
archiveFileName = "LuckPerms-Forge-${project.ext.fullVersion}.jar"
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@ import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer;
|
|||||||
import net.luckperms.api.util.Tristate;
|
import net.luckperms.api.util.Tristate;
|
||||||
import net.minecraft.commands.CommandSource;
|
import net.minecraft.commands.CommandSource;
|
||||||
import net.minecraft.commands.CommandSourceStack;
|
import net.minecraft.commands.CommandSourceStack;
|
||||||
|
import net.minecraft.core.RegistryAccess;
|
||||||
import net.minecraft.network.chat.Component.Serializer;
|
import net.minecraft.network.chat.Component.Serializer;
|
||||||
import net.minecraft.server.level.ServerPlayer;
|
import net.minecraft.server.level.ServerPlayer;
|
||||||
import net.minecraft.server.rcon.RconConsoleSource;
|
import net.minecraft.server.rcon.RconConsoleSource;
|
||||||
@ -117,7 +118,7 @@ public class ForgeSenderFactory extends SenderFactory<LPForgePlugin, CommandSour
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static net.minecraft.network.chat.Component toNativeText(Component component) {
|
public static net.minecraft.network.chat.Component toNativeText(Component component) {
|
||||||
return Serializer.fromJson(GsonComponentSerializer.gson().serializeToTree(component));
|
return Serializer.fromJson(GsonComponentSerializer.gson().serializeToTree(component), RegistryAccess.EMPTY);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -44,16 +44,14 @@ import java.util.Locale;
|
|||||||
public class UserCapabilityImpl implements UserCapability {
|
public class UserCapabilityImpl implements UserCapability {
|
||||||
|
|
||||||
private static LazyOptional<UserCapability> getCapability(Player player) {
|
private static LazyOptional<UserCapability> getCapability(Player player) {
|
||||||
if (!player.isRemoved()) {
|
LazyOptional<UserCapability> optional = player.getCapability(CAPABILITY);
|
||||||
return player.getCapability(CAPABILITY);
|
if (optional.isPresent()) {
|
||||||
} else {
|
return optional;
|
||||||
player.reviveCaps();
|
|
||||||
try {
|
|
||||||
return player.getCapability(CAPABILITY);
|
|
||||||
} finally {
|
|
||||||
player.invalidateCaps();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// if capability is missing, try to restore them before trying again
|
||||||
|
player.reviveCaps();
|
||||||
|
return player.getCapability(CAPABILITY);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -43,6 +43,7 @@ import net.minecraft.server.level.ServerPlayer;
|
|||||||
import net.minecraft.server.network.ConfigurationTask;
|
import net.minecraft.server.network.ConfigurationTask;
|
||||||
import net.minecraft.server.network.ServerConfigurationPacketListenerImpl;
|
import net.minecraft.server.network.ServerConfigurationPacketListenerImpl;
|
||||||
import net.minecraftforge.event.entity.player.PlayerEvent;
|
import net.minecraftforge.event.entity.player.PlayerEvent;
|
||||||
|
import net.minecraftforge.event.entity.player.PlayerEvent.PlayerLoggedInEvent;
|
||||||
import net.minecraftforge.event.network.GatherLoginConfigurationTasksEvent;
|
import net.minecraftforge.event.network.GatherLoginConfigurationTasksEvent;
|
||||||
import net.minecraftforge.eventbus.api.EventPriority;
|
import net.minecraftforge.eventbus.api.EventPriority;
|
||||||
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
import net.minecraftforge.eventbus.api.SubscribeEvent;
|
||||||
@ -115,7 +116,7 @@ public class ForgeConnectionListener extends AbstractConnectionListener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@SubscribeEvent(priority = EventPriority.HIGHEST)
|
@SubscribeEvent(priority = EventPriority.HIGHEST)
|
||||||
public void onPlayerLoadFromFile(PlayerEvent.LoadFromFile event) {
|
public void onPlayerLoggedIn(PlayerLoggedInEvent event) {
|
||||||
ServerPlayer player = (ServerPlayer) event.getEntity();
|
ServerPlayer player = (ServerPlayer) event.getEntity();
|
||||||
GameProfile profile = player.getGameProfile();
|
GameProfile profile = player.getGameProfile();
|
||||||
|
|
||||||
@ -137,6 +138,7 @@ public class ForgeConnectionListener extends AbstractConnectionListener {
|
|||||||
Component component = TranslationManager.render(Message.LOADING_STATE_ERROR.build(), player.getLanguage());
|
Component component = TranslationManager.render(Message.LOADING_STATE_ERROR.build(), player.getLanguage());
|
||||||
if (this.plugin.getConfiguration().get(ConfigKeys.CANCEL_FAILED_LOGINS)) {
|
if (this.plugin.getConfiguration().get(ConfigKeys.CANCEL_FAILED_LOGINS)) {
|
||||||
player.connection.disconnect(ForgeSenderFactory.toNativeText(component));
|
player.connection.disconnect(ForgeSenderFactory.toNativeText(component));
|
||||||
|
return;
|
||||||
} else {
|
} else {
|
||||||
player.sendSystemMessage(ForgeSenderFactory.toNativeText(component));
|
player.sendSystemMessage(ForgeSenderFactory.toNativeText(component));
|
||||||
}
|
}
|
||||||
@ -154,4 +156,4 @@ public class ForgeConnectionListener extends AbstractConnectionListener {
|
|||||||
handleDisconnect(player.getGameProfile().getId());
|
handleDisconnect(player.getGameProfile().getId());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -33,15 +33,13 @@ import me.lucko.luckperms.forge.LPForgePlugin;
|
|||||||
import net.luckperms.api.messenger.IncomingMessageConsumer;
|
import net.luckperms.api.messenger.IncomingMessageConsumer;
|
||||||
import net.luckperms.api.messenger.Messenger;
|
import net.luckperms.api.messenger.Messenger;
|
||||||
import net.minecraft.network.FriendlyByteBuf;
|
import net.minecraft.network.FriendlyByteBuf;
|
||||||
import net.minecraft.network.protocol.Packet;
|
|
||||||
import net.minecraft.network.protocol.common.ClientboundCustomPayloadPacket;
|
|
||||||
import net.minecraft.resources.ResourceLocation;
|
import net.minecraft.resources.ResourceLocation;
|
||||||
import net.minecraft.server.MinecraftServer;
|
import net.minecraft.server.MinecraftServer;
|
||||||
import net.minecraft.server.level.ServerPlayer;
|
import net.minecraft.server.level.ServerPlayer;
|
||||||
import net.minecraft.server.players.PlayerList;
|
import net.minecraft.server.players.PlayerList;
|
||||||
import net.minecraftforge.network.ChannelBuilder;
|
import net.minecraftforge.network.ChannelBuilder;
|
||||||
import net.minecraftforge.network.EventNetworkChannel;
|
import net.minecraftforge.network.EventNetworkChannel;
|
||||||
import net.minecraftforge.network.NetworkRegistry;
|
import net.minecraftforge.network.PacketDistributor;
|
||||||
|
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
@ -84,10 +82,8 @@ public class PluginMessageMessenger extends AbstractPluginMessageMessenger imple
|
|||||||
|
|
||||||
FriendlyByteBuf byteBuf = new FriendlyByteBuf(Unpooled.buffer());
|
FriendlyByteBuf byteBuf = new FriendlyByteBuf(Unpooled.buffer());
|
||||||
byteBuf.writeBytes(buf);
|
byteBuf.writeBytes(buf);
|
||||||
byteBuf.writeResourceLocation(CHANNEL);
|
|
||||||
Packet<?> packet = new ClientboundCustomPayloadPacket(byteBuf);
|
|
||||||
|
|
||||||
player.connection.send(packet);
|
this.channel.send(byteBuf, PacketDistributor.PLAYER.with(player));
|
||||||
|
|
||||||
SchedulerTask t = taskRef.getAndSet(null);
|
SchedulerTask t = taskRef.getAndSet(null);
|
||||||
if (t != null) {
|
if (t != null) {
|
||||||
|
@ -30,7 +30,8 @@ import com.mojang.brigadier.tree.CommandNode;
|
|||||||
import com.mojang.brigadier.tree.LiteralCommandNode;
|
import com.mojang.brigadier.tree.LiteralCommandNode;
|
||||||
import me.lucko.luckperms.common.graph.Graph;
|
import me.lucko.luckperms.common.graph.Graph;
|
||||||
import me.lucko.luckperms.common.graph.TraversalAlgorithm;
|
import me.lucko.luckperms.common.graph.TraversalAlgorithm;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.model.User;
|
||||||
|
import me.lucko.luckperms.forge.LPForgePlugin;
|
||||||
import me.lucko.luckperms.forge.capabilities.UserCapability;
|
import me.lucko.luckperms.forge.capabilities.UserCapability;
|
||||||
import me.lucko.luckperms.forge.capabilities.UserCapabilityImpl;
|
import me.lucko.luckperms.forge.capabilities.UserCapabilityImpl;
|
||||||
import net.luckperms.api.util.Tristate;
|
import net.luckperms.api.util.Tristate;
|
||||||
@ -68,7 +69,7 @@ public final class BrigadierInjector {
|
|||||||
* @param plugin the plugin
|
* @param plugin the plugin
|
||||||
* @param dispatcher the command dispatcher
|
* @param dispatcher the command dispatcher
|
||||||
*/
|
*/
|
||||||
public static void inject(LuckPermsPlugin plugin, CommandDispatcher<CommandSourceStack> dispatcher) {
|
public static void inject(LPForgePlugin plugin, CommandDispatcher<CommandSourceStack> dispatcher) {
|
||||||
Iterable<CommandNodeWithParent> tree = CommandNodeGraph.INSTANCE.traverse(
|
Iterable<CommandNodeWithParent> tree = CommandNodeGraph.INSTANCE.traverse(
|
||||||
TraversalAlgorithm.DEPTH_FIRST_PRE_ORDER,
|
TraversalAlgorithm.DEPTH_FIRST_PRE_ORDER,
|
||||||
new CommandNodeWithParent(null, dispatcher.getRoot())
|
new CommandNodeWithParent(null, dispatcher.getRoot())
|
||||||
@ -89,7 +90,7 @@ public final class BrigadierInjector {
|
|||||||
|
|
||||||
plugin.getPermissionRegistry().insert(permission);
|
plugin.getPermissionRegistry().insert(permission);
|
||||||
|
|
||||||
InjectedPermissionRequirement newRequirement = new InjectedPermissionRequirement(permission, requirement);
|
InjectedPermissionRequirement newRequirement = new InjectedPermissionRequirement(plugin, permission, requirement);
|
||||||
try {
|
try {
|
||||||
REQUIREMENT_FIELD.set(node.node, newRequirement);
|
REQUIREMENT_FIELD.set(node.node, newRequirement);
|
||||||
} catch (IllegalAccessException e) {
|
} catch (IllegalAccessException e) {
|
||||||
@ -127,10 +128,12 @@ public final class BrigadierInjector {
|
|||||||
* delegating to the existing requirement.
|
* delegating to the existing requirement.
|
||||||
*/
|
*/
|
||||||
private static final class InjectedPermissionRequirement implements Predicate<CommandSourceStack> {
|
private static final class InjectedPermissionRequirement implements Predicate<CommandSourceStack> {
|
||||||
|
private final LPForgePlugin plugin;
|
||||||
private final String permission;
|
private final String permission;
|
||||||
private final Predicate<CommandSourceStack> delegate;
|
private final Predicate<CommandSourceStack> delegate;
|
||||||
|
|
||||||
private InjectedPermissionRequirement(String permission, Predicate<CommandSourceStack> delegate) {
|
private InjectedPermissionRequirement(LPForgePlugin plugin, String permission, Predicate<CommandSourceStack> delegate) {
|
||||||
|
this.plugin = plugin;
|
||||||
this.permission = permission;
|
this.permission = permission;
|
||||||
this.delegate = delegate;
|
this.delegate = delegate;
|
||||||
}
|
}
|
||||||
@ -139,9 +142,19 @@ public final class BrigadierInjector {
|
|||||||
public boolean test(CommandSourceStack source) {
|
public boolean test(CommandSourceStack source) {
|
||||||
if (source.getEntity() instanceof ServerPlayer) {
|
if (source.getEntity() instanceof ServerPlayer) {
|
||||||
ServerPlayer player = (ServerPlayer) source.getEntity();
|
ServerPlayer player = (ServerPlayer) source.getEntity();
|
||||||
|
Tristate state = Tristate.UNDEFINED;
|
||||||
UserCapability user = UserCapabilityImpl.get(player);
|
// If player is still connecting and has not been added to world then check LP user directly
|
||||||
Tristate state = user.checkPermission(this.permission);
|
if (!player.isAddedToWorld()) {
|
||||||
|
User user = this.plugin.getUserManager().getIfLoaded(player.getUUID());
|
||||||
|
if (user == null) {
|
||||||
|
// Should never happen but just in case...
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
state = user.getCachedData().getPermissionData().checkPermission(permission);
|
||||||
|
} else {
|
||||||
|
UserCapability user = UserCapabilityImpl.get(player);
|
||||||
|
state = user.checkPermission(this.permission);
|
||||||
|
}
|
||||||
|
|
||||||
if (state != Tristate.UNDEFINED) {
|
if (state != Tristate.UNDEFINED) {
|
||||||
return state.asBoolean() && this.delegate.test(source.withPermission(4));
|
return state.asBoolean() && this.delegate.test(source.withPermission(4));
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
[versions]
|
[versions]
|
||||||
shadow = "8.1.1"
|
shadow = "8.1.7"
|
||||||
blossom = "1.3.1"
|
blossom = "1.3.1"
|
||||||
forgegradle = "[6.0,6.2)"
|
forgegradle = "[6.0,6.2)"
|
||||||
loom = "1.6-SNAPSHOT"
|
loom = "1.6-SNAPSHOT"
|
||||||
@ -7,7 +7,7 @@ licenser = "0.6.1"
|
|||||||
|
|
||||||
[plugins]
|
[plugins]
|
||||||
blossom = { id = "net.kyori.blossom", version.ref = "blossom" }
|
blossom = { id = "net.kyori.blossom", version.ref = "blossom" }
|
||||||
shadow = { id = "com.github.johnrengelman.shadow", version.ref = "shadow" }
|
shadow = { id = "io.github.goooler.shadow", version.ref = "shadow" }
|
||||||
forgegradle = { id = "net.minecraftforge.gradle", version.ref = "forgegradle" }
|
forgegradle = { id = "net.minecraftforge.gradle", version.ref = "forgegradle" }
|
||||||
loom = { id = "fabric-loom", version.ref = "loom" }
|
loom = { id = "fabric-loom", version.ref = "loom" }
|
||||||
licenser = { id = "org.cadixdev.licenser", version.ref = "licenser" }
|
licenser = { id = "org.cadixdev.licenser", version.ref = "licenser" }
|
Loading…
Reference in New Issue
Block a user