Search in sources :

Example 1 with User

use of net.luckperms.api.model.user.User in project AuthMeReloaded by AuthMe.

the class LuckPermsHandler method hasPermissionOffline.

@Override
public boolean hasPermissionOffline(String name, PermissionNode node) {
    User user = luckPerms.getUserManager().getUser(name);
    if (user == null) {
        logger.warning("LuckPermsHandler: tried to check permission for offline user " + name + " but it isn't loaded!");
        return false;
    }
    CachedPermissionData permissionData = user.getCachedData().getPermissionData(QueryOptions.builder(QueryMode.CONTEXTUAL).build());
    return permissionData.checkPermission(node.getNode()).asBoolean();
}
Also used : User(net.luckperms.api.model.user.User) CachedPermissionData(net.luckperms.api.cacheddata.CachedPermissionData)

Example 2 with User

use of net.luckperms.api.model.user.User in project AuthMeReloaded by AuthMe.

the class LuckPermsHandler method getGroups.

@Override
public List<UserGroup> getGroups(OfflinePlayer player) {
    String playerName = player.getName();
    if (playerName == null) {
        return Collections.emptyList();
    }
    User user = luckPerms.getUserManager().getUser(playerName);
    if (user == null) {
        logger.warning("LuckPermsHandler: tried to get groups for offline user " + player.getName() + " but it isn't loaded!");
        return Collections.emptyList();
    }
    return user.getDistinctNodes().stream().filter(node -> node instanceof InheritanceNode).map(node -> (InheritanceNode) node).map(node -> {
        Group group = luckPerms.getGroupManager().getGroup(node.getGroupName());
        if (group == null) {
            return null;
        }
        return new LuckPermGroup(group, node.getContexts());
    }).filter(Objects::nonNull).sorted((o1, o2) -> sortGroups(user, o1, o2)).map(g -> new UserGroup(g.getGroup().getName(), g.getContexts().toFlattenedMap())).collect(Collectors.toList());
}
Also used : ConsoleLoggerFactory(fr.xephi.authme.output.ConsoleLoggerFactory) PermissionNode(fr.xephi.authme.permission.PermissionNode) QueryOptions(net.luckperms.api.query.QueryOptions) TimeoutException(java.util.concurrent.TimeoutException) User(net.luckperms.api.model.user.User) UserGroup(fr.xephi.authme.data.limbo.UserGroup) ContextSetFactory(net.luckperms.api.context.ContextSetFactory) CachedPermissionData(net.luckperms.api.cacheddata.CachedPermissionData) ConsoleLogger(fr.xephi.authme.ConsoleLogger) DataMutateResult(net.luckperms.api.model.data.DataMutateResult) InheritanceNode(net.luckperms.api.node.types.InheritanceNode) PermissionsSystemType(fr.xephi.authme.permission.PermissionsSystemType) UUID(java.util.UUID) Group(net.luckperms.api.model.group.Group) QueryMode(net.luckperms.api.query.QueryMode) Collectors(java.util.stream.Collectors) LuckPermsProvider(net.luckperms.api.LuckPermsProvider) OfflinePlayer(org.bukkit.OfflinePlayer) Objects(java.util.Objects) ExecutionException(java.util.concurrent.ExecutionException) TimeUnit(java.util.concurrent.TimeUnit) List(java.util.List) LuckPerms(net.luckperms.api.LuckPerms) NodeEqualityPredicate(net.luckperms.api.node.NodeEqualityPredicate) NotNull(org.jetbrains.annotations.NotNull) Collections(java.util.Collections) UserGroup(fr.xephi.authme.data.limbo.UserGroup) Group(net.luckperms.api.model.group.Group) User(net.luckperms.api.model.user.User) InheritanceNode(net.luckperms.api.node.types.InheritanceNode) UserGroup(fr.xephi.authme.data.limbo.UserGroup)

Example 3 with User

use of net.luckperms.api.model.user.User in project Almura by AlmuraDev.

the class PermissionsManager method onMovePlayerTeleport.

// This method is for new players getting started at Almura castle, once they leave there it will promose them to Survivor.
@Listener(order = Order.LAST)
public void onMovePlayerTeleport(final MoveEntityEvent.Teleport event, @Getter("getTargetEntity") final Player player) {
    if (this.permApi != null && differentExtent(event.getFromTransform(), event.getToTransform())) {
        final User user = this.permApi.getUserManager().getUser(player.getUniqueId());
        // The purpose of this method is to upgrade people out of the default permissions group once they teleport off of Asgard (starting world).
        if (user != null && user.getPrimaryGroup().equalsIgnoreCase(LUCK_PERMS_DEFAULT_GROUP)) {
            final String command = "lp user " + player.getName() + " promote members";
            this.commandManager.process(Sponge.getServer().getConsole(), command);
        }
    }
}
Also used : User(net.luckperms.api.model.user.User) Listener(org.spongepowered.api.event.Listener)

Example 4 with User

use of net.luckperms.api.model.user.User in project AuthMeReloaded by AuthMe.

the class LuckPermsHandler method setGroup.

@Override
public boolean setGroup(OfflinePlayer player, UserGroup group) {
    String playerName = player.getName();
    if (playerName == null) {
        return false;
    }
    User user = luckPerms.getUserManager().getUser(playerName);
    if (user == null) {
        logger.warning("LuckPermsHandler: tried to set group for offline user " + player.getName() + " but it isn't loaded!");
        return false;
    }
    InheritanceNode groupNode = buildGroupNode(group);
    DataMutateResult result = user.data().add(groupNode);
    if (result == DataMutateResult.FAIL) {
        return false;
    }
    user.data().clear(node -> {
        if (!(node instanceof InheritanceNode)) {
            return false;
        }
        InheritanceNode inheritanceNode = (InheritanceNode) node;
        return !inheritanceNode.equals(groupNode);
    });
    luckPerms.getUserManager().saveUser(user);
    return true;
}
Also used : User(net.luckperms.api.model.user.User) InheritanceNode(net.luckperms.api.node.types.InheritanceNode) DataMutateResult(net.luckperms.api.model.data.DataMutateResult)

Example 5 with User

use of net.luckperms.api.model.user.User in project AuthMeReloaded by AuthMe.

the class LuckPermsHandler method isInGroup.

@Override
public boolean isInGroup(OfflinePlayer player, UserGroup group) {
    String playerName = player.getName();
    if (playerName == null) {
        return false;
    }
    User user = luckPerms.getUserManager().getUser(playerName);
    if (user == null) {
        logger.warning("LuckPermsHandler: tried to check group for offline user " + player.getName() + " but it isn't loaded!");
        return false;
    }
    InheritanceNode inheritanceNode = InheritanceNode.builder(group.getGroupName()).build();
    return user.data().contains(inheritanceNode, NodeEqualityPredicate.EXACT).asBoolean();
}
Also used : User(net.luckperms.api.model.user.User) InheritanceNode(net.luckperms.api.node.types.InheritanceNode)

Aggregations

User (net.luckperms.api.model.user.User)7 InheritanceNode (net.luckperms.api.node.types.InheritanceNode)5 DataMutateResult (net.luckperms.api.model.data.DataMutateResult)3 UserGroup (fr.xephi.authme.data.limbo.UserGroup)2 CachedPermissionData (net.luckperms.api.cacheddata.CachedPermissionData)2 Group (net.luckperms.api.model.group.Group)2 ConsoleLogger (fr.xephi.authme.ConsoleLogger)1 ConsoleLoggerFactory (fr.xephi.authme.output.ConsoleLoggerFactory)1 PermissionNode (fr.xephi.authme.permission.PermissionNode)1 PermissionsSystemType (fr.xephi.authme.permission.PermissionsSystemType)1 Collections (java.util.Collections)1 List (java.util.List)1 Objects (java.util.Objects)1 UUID (java.util.UUID)1 ExecutionException (java.util.concurrent.ExecutionException)1 TimeUnit (java.util.concurrent.TimeUnit)1 TimeoutException (java.util.concurrent.TimeoutException)1 Collectors (java.util.stream.Collectors)1 LuckPerms (net.luckperms.api.LuckPerms)1 LuckPermsProvider (net.luckperms.api.LuckPermsProvider)1