-
-
Notifications
You must be signed in to change notification settings - Fork 131
/
PermissionsProvider_LuckPerms.java
35 lines (29 loc) · 1.4 KB
/
PermissionsProvider_LuckPerms.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package com.bgsoftware.superiorskyblock.hooks.provider;
import com.bgsoftware.superiorskyblock.SuperiorSkyblockPlugin;
import com.bgsoftware.superiorskyblock.api.hooks.PermissionsProvider;
import net.luckperms.api.LuckPerms;
import net.luckperms.api.cacheddata.CachedDataManager;
import net.luckperms.api.model.user.User;
import org.bukkit.Bukkit;
import org.bukkit.entity.Player;
@SuppressWarnings("unused")
public final class PermissionsProvider_LuckPerms implements PermissionsProvider {
private static LuckPerms luckPerms = null;
public static boolean isCompatible() {
try {
CachedDataManager.class.getMethod("getPermissionData");
luckPerms = Bukkit.getServicesManager().getRegistration(LuckPerms.class).getProvider();
SuperiorSkyblockPlugin.log("Using LuckPerms as a permissions provider.");
return true;
} catch (Throwable ex) {
SuperiorSkyblockPlugin.log("&cYou are using an outdated version of LuckPerms. " +
"It's recommended to update for a more optimized experience (v5.1+).");
return false;
}
}
@Override
public boolean hasPermission(Player player, String permission) {
User user = luckPerms.getUserManager().getUser(player.getUniqueId());
return user != null && user.getCachedData().getPermissionData().getPermissionMap().getOrDefault(permission, false);
}
}