aboutsummaryrefslogtreecommitdiffhomepage
path: root/patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch
diff options
context:
space:
mode:
Diffstat (limited to 'patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch')
-rw-r--r--patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch35
1 files changed, 35 insertions, 0 deletions
diff --git a/patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch b/patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch
new file mode 100644
index 0000000000..296e4348f3
--- /dev/null
+++ b/patches/server/0068-Allow-Reloading-of-Custom-Permissions.patch
@@ -0,0 +1,35 @@
+From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
+From: William <[email protected]>
+Date: Fri, 18 Mar 2016 03:30:17 -0400
+Subject: [PATCH] Allow Reloading of Custom Permissions
+
+https://github.com/PaperMC/Paper/issues/49
+
+diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+index bce780f491ee12dcd23a4ea5dd3ce6e8f92e6267..f8d2850c35e1b41c1844773c4b0452c17bd72f19 100644
+--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
++++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+@@ -2785,5 +2785,23 @@ public final class CraftServer implements Server {
+ }
+ return this.adventure$audiences;
+ }
++
++ @Override
++ public void reloadPermissions() {
++ pluginManager.clearPermissions();
++ if (io.papermc.paper.configuration.GlobalConfiguration.get().misc.loadPermissionsYmlBeforePlugins) loadCustomPermissions();
++ for (Plugin plugin : pluginManager.getPlugins()) {
++ for (Permission perm : plugin.getDescription().getPermissions()) {
++ try {
++ pluginManager.addPermission(perm);
++ } catch (IllegalArgumentException ex) {
++ getLogger().log(Level.WARNING, "Plugin " + plugin.getDescription().getFullName() + " tried to register permission '" + perm.getName() + "' but it's already registered", ex);
++ }
++ }
++ }
++ if (!io.papermc.paper.configuration.GlobalConfiguration.get().misc.loadPermissionsYmlBeforePlugins) loadCustomPermissions();
++ DefaultPermissions.registerCorePermissions();
++ CraftDefaultPermissions.registerCorePermissions();
++ }
+ // Paper end
+ }