2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Fri, 18 Mar 2016 13:17:38 -0400
|
|
|
|
Subject: [PATCH] Default loading permissions.yml before plugins
|
|
|
|
|
|
|
|
Under previous behavior, plugins were not able to check if a player had a permission
|
|
|
|
if it was defined in permissions.yml. there is no clean way for a plugin to fix that either.
|
|
|
|
|
|
|
|
This will change the order so that by default, permissions.yml loads BEFORE plugins instead of after.
|
|
|
|
|
|
|
|
This gives plugins expected permission checks.
|
|
|
|
|
|
|
|
It also helps improve the expected logic, as servers should set the initial defaults, and then let plugins
|
|
|
|
modify that. Under the previous logic, plugins were unable (cleanly) override permissions.yml.
|
|
|
|
|
|
|
|
A config option has been added for those who depend on the previous behavior, but I don't expect that.
|
|
|
|
|
|
|
|
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
2024-06-13 19:30:39 +02:00
|
|
|
index fd31d0e76d1a953b128e777b1bc27e24b1e03ed7..bce780f491ee12dcd23a4ea5dd3ce6e8f92e6267 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
|
2024-06-13 19:30:39 +02:00
|
|
|
@@ -479,6 +479,7 @@ public final class CraftServer implements Server {
|
2021-06-21 10:41:00 +02:00
|
|
|
if (type == PluginLoadOrder.STARTUP) {
|
|
|
|
this.helpMap.clear();
|
|
|
|
this.helpMap.initializeGeneralTopics();
|
2022-06-09 10:51:45 +02:00
|
|
|
+ if (io.papermc.paper.configuration.GlobalConfiguration.get().misc.loadPermissionsYmlBeforePlugins) loadCustomPermissions(); // Paper
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|
|
|
|
|
2021-06-21 10:41:00 +02:00
|
|
|
Plugin[] plugins = this.pluginManager.getPlugins();
|
2024-06-13 19:30:39 +02:00
|
|
|
@@ -498,7 +499,7 @@ public final class CraftServer implements Server {
|
2021-06-12 02:57:04 +02:00
|
|
|
this.commandMap.registerServerAliases();
|
2021-06-11 14:02:28 +02:00
|
|
|
DefaultPermissions.registerCorePermissions();
|
|
|
|
CraftDefaultPermissions.registerCorePermissions();
|
2021-06-12 02:57:04 +02:00
|
|
|
- this.loadCustomPermissions();
|
2022-06-09 10:51:45 +02:00
|
|
|
+ if (!io.papermc.paper.configuration.GlobalConfiguration.get().misc.loadPermissionsYmlBeforePlugins) this.loadCustomPermissions(); // Paper
|
2021-06-12 02:57:04 +02:00
|
|
|
this.helpMap.initializeCommands();
|
|
|
|
this.syncCommands();
|
2021-06-11 14:02:28 +02:00
|
|
|
}
|