mirror of
https://github.com/TotalFreedomMC/TF-EssentialsX.git
synced 2025-04-26 16:39:45 +00:00
Do not grant any permissions (nort update Bukkit) if the server is in
offline mode and the player has the permission node 'groupmanager.noofflineperms'.
This commit is contained in:
parent
24f56892ad
commit
ad7009c77e
4 changed files with 30 additions and 5 deletions
|
@ -207,3 +207,4 @@ v 2.0:
|
||||||
- Clear our attachment map upon a manload so we correctly reconfigure a players new permissions.
|
- Clear our attachment map upon a manload so we correctly reconfigure a players new permissions.
|
||||||
- Synchronize the raising of GroupManager events to Bukkit.getServer() (should prevent deadlocks).
|
- Synchronize the raising of GroupManager events to Bukkit.getServer() (should prevent deadlocks).
|
||||||
- Synchronize pushing to Bukkit perms to prevent any ConcurrentModificationException.
|
- Synchronize pushing to Bukkit perms to prevent any ConcurrentModificationException.
|
||||||
|
- Do not grant any permissions (nort update Bukkit) if the server is in offline mode and the player has the permission node 'groupmanager.noofflineperms'.
|
|
@ -16,6 +16,7 @@ import org.anjocaido.groupmanager.data.Group;
|
||||||
import org.anjocaido.groupmanager.dataholder.WorldDataHolder;
|
import org.anjocaido.groupmanager.dataholder.WorldDataHolder;
|
||||||
import org.anjocaido.groupmanager.data.User;
|
import org.anjocaido.groupmanager.data.User;
|
||||||
import org.anjocaido.groupmanager.utils.PermissionCheckResult;
|
import org.anjocaido.groupmanager.utils.PermissionCheckResult;
|
||||||
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -785,6 +786,15 @@ public class AnjoPermissionsHandler extends PermissionsReaderInterface {
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Do not push any perms to bukkit if...
|
||||||
|
* We are in offline mode
|
||||||
|
* and the player has the 'groupmanager.noofflineperms' permission.
|
||||||
|
*/
|
||||||
|
if (!Bukkit.getServer().getOnlineMode()
|
||||||
|
&& (checkFullGMPermission(user, "groupmanager.noofflineperms", true).resultType == PermissionCheckResult.Type.FOUND))
|
||||||
|
return result;
|
||||||
|
|
||||||
if (checkBukkit) {
|
if (checkBukkit) {
|
||||||
// Check Bukkit perms to support plugins which add perms via code
|
// Check Bukkit perms to support plugins which add perms via code
|
||||||
// (Heroes).
|
// (Heroes).
|
||||||
|
|
|
@ -31,7 +31,6 @@ import java.util.WeakHashMap;
|
||||||
|
|
||||||
import org.anjocaido.groupmanager.GroupManager;
|
import org.anjocaido.groupmanager.GroupManager;
|
||||||
import org.anjocaido.groupmanager.data.User;
|
import org.anjocaido.groupmanager.data.User;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
|
@ -184,6 +183,18 @@ public class BukkitPermissions {
|
||||||
newPerms.put((value ? permission : permission.substring(1)), value);
|
newPerms.put((value ? permission : permission.substring(1)), value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Do not push any perms to bukkit if...
|
||||||
|
* We are in offline mode
|
||||||
|
* and the player has the 'groupmanager.noofflineperms' permission.
|
||||||
|
*/
|
||||||
|
if (!Bukkit.getServer().getOnlineMode()
|
||||||
|
&& (newPerms.containsKey("groupmanager.noofflineperms") && (newPerms.get("groupmanager.noofflineperms") == true))) {
|
||||||
|
removeAttachment(name);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is put in place until such a time as Bukkit pull 466 is
|
* This is put in place until such a time as Bukkit pull 466 is
|
||||||
* implemented https://github.com/Bukkit/Bukkit/pull/466
|
* implemented https://github.com/Bukkit/Bukkit/pull/466
|
||||||
|
|
|
@ -3,13 +3,16 @@ users:
|
||||||
snowleo:
|
snowleo:
|
||||||
group: Builder
|
group: Builder
|
||||||
subgroups: []
|
subgroups: []
|
||||||
permissions: []
|
permissions:
|
||||||
|
- groupmanager.noofflineperms
|
||||||
KHobbits:
|
KHobbits:
|
||||||
group: Moderator
|
group: Moderator
|
||||||
subgroups: []
|
subgroups: []
|
||||||
permissions: []
|
permissions:
|
||||||
|
- groupmanager.noofflineperms
|
||||||
ElgarL:
|
ElgarL:
|
||||||
group: Moderator
|
group: Moderator
|
||||||
subgroups: []
|
subgroups: []
|
||||||
permissions: []
|
permissions:
|
||||||
|
- groupmanager.noofflineperms
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue