Move Track methods away from checked exceptions, refactor ContextManager & primary group holders
This commit is contained in:
parent
de4c6b384c
commit
9c505e4402
@ -25,8 +25,6 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.bukkit.contexts;
|
package me.lucko.luckperms.bukkit.contexts;
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
||||||
import me.lucko.luckperms.bukkit.LPBukkitPlugin;
|
import me.lucko.luckperms.bukkit.LPBukkitPlugin;
|
||||||
@ -35,9 +33,10 @@ import me.lucko.luckperms.common.contexts.AbstractContextManager;
|
|||||||
|
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
|
||||||
public class BukkitContextManager extends AbstractContextManager<Player> {
|
public class BukkitContextManager extends AbstractContextManager<Player> {
|
||||||
private final LPBukkitPlugin plugin;
|
public BukkitContextManager(LPBukkitPlugin plugin) {
|
||||||
|
super(plugin);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Contexts formContexts(Player subject, ImmutableContextSet contextSet) {
|
public Contexts formContexts(Player subject, ImmutableContextSet contextSet) {
|
||||||
|
@ -25,8 +25,6 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.bungee.contexts;
|
package me.lucko.luckperms.bungee.contexts;
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
||||||
import me.lucko.luckperms.bungee.LPBungeePlugin;
|
import me.lucko.luckperms.bungee.LPBungeePlugin;
|
||||||
@ -35,9 +33,10 @@ import me.lucko.luckperms.common.contexts.AbstractContextManager;
|
|||||||
|
|
||||||
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
|
||||||
public class BungeeContextManager extends AbstractContextManager<ProxiedPlayer> {
|
public class BungeeContextManager extends AbstractContextManager<ProxiedPlayer> {
|
||||||
private final LPBungeePlugin plugin;
|
public BungeeContextManager(LPBungeePlugin plugin) {
|
||||||
|
super(plugin);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Contexts formContexts(ProxiedPlayer subject, ImmutableContextSet contextSet) {
|
public Contexts formContexts(ProxiedPlayer subject, ImmutableContextSet contextSet) {
|
||||||
|
@ -188,10 +188,10 @@ public final class GroupDelegate extends PermissionHolderDelegate implements Gro
|
|||||||
if (!(o instanceof GroupDelegate)) return false;
|
if (!(o instanceof GroupDelegate)) return false;
|
||||||
|
|
||||||
GroupDelegate other = (GroupDelegate) o;
|
GroupDelegate other = (GroupDelegate) o;
|
||||||
return this.getName().equals(other.getName());
|
return handle.equals(other.handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return this.getName().hashCode();
|
return handle.hashCode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -438,12 +438,12 @@ public class PermissionHolderDelegate implements PermissionHolder {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<LocalizedNode> resolveInheritances(Contexts contexts) {
|
public List<LocalizedNode> resolveInheritances(Contexts contexts) {
|
||||||
return null;
|
return handle.resolveInheritances(ExtractedContexts.generate(contexts));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public List<LocalizedNode> resolveInheritances() {
|
public List<LocalizedNode> resolveInheritances() {
|
||||||
return null;
|
return handle.resolveInheritances();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -69,32 +69,40 @@ public final class TrackDelegate implements Track {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getNext(@NonNull Group current) throws ObjectLacksException {
|
public String getNext(@NonNull Group current) throws ObjectLacksException {
|
||||||
return handle.getNext(GroupDelegate.cast(current));
|
try {
|
||||||
|
return handle.getNext(GroupDelegate.cast(current));
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
throw new ObjectLacksException();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getPrevious(@NonNull Group current) throws ObjectLacksException {
|
public String getPrevious(@NonNull Group current) throws ObjectLacksException {
|
||||||
return handle.getPrevious(GroupDelegate.cast(current));
|
try {
|
||||||
|
return handle.getPrevious(GroupDelegate.cast(current));
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
throw new ObjectLacksException();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void appendGroup(@NonNull Group group) throws ObjectAlreadyHasException {
|
public void appendGroup(@NonNull Group group) throws ObjectAlreadyHasException {
|
||||||
handle.appendGroup(GroupDelegate.cast(group));
|
handle.appendGroup(GroupDelegate.cast(group)).throwException();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void insertGroup(@NonNull Group group, @NonNull int position) throws ObjectAlreadyHasException, IndexOutOfBoundsException {
|
public void insertGroup(@NonNull Group group, @NonNull int position) throws ObjectAlreadyHasException, IndexOutOfBoundsException {
|
||||||
handle.insertGroup(GroupDelegate.cast(group), position);
|
handle.insertGroup(GroupDelegate.cast(group), position).throwException();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeGroup(@NonNull Group group) throws ObjectLacksException {
|
public void removeGroup(@NonNull Group group) throws ObjectLacksException {
|
||||||
handle.removeGroup(GroupDelegate.cast(group));
|
handle.removeGroup(GroupDelegate.cast(group)).throwException();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void removeGroup(@NonNull String group) throws ObjectLacksException {
|
public void removeGroup(@NonNull String group) throws ObjectLacksException {
|
||||||
handle.removeGroup(group);
|
handle.removeGroup(group).throwException();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -117,10 +125,10 @@ public final class TrackDelegate implements Track {
|
|||||||
if (!(o instanceof TrackDelegate)) return false;
|
if (!(o instanceof TrackDelegate)) return false;
|
||||||
|
|
||||||
TrackDelegate other = (TrackDelegate) o;
|
TrackDelegate other = (TrackDelegate) o;
|
||||||
return this.getName().equals(other.getName());
|
return handle.equals(other.handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return this.getName().hashCode();
|
return handle.hashCode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -228,10 +228,10 @@ public final class UserDelegate extends PermissionHolderDelegate implements User
|
|||||||
if (!(o instanceof UserDelegate)) return false;
|
if (!(o instanceof UserDelegate)) return false;
|
||||||
|
|
||||||
UserDelegate other = (UserDelegate) o;
|
UserDelegate other = (UserDelegate) o;
|
||||||
return this.getUuid().equals(other.getUuid());
|
return handle.equals(other.handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int hashCode() {
|
public int hashCode() {
|
||||||
return this.getUuid().hashCode();
|
return handle.hashCode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,37 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of LuckPerms, licensed under the MIT License.
|
||||||
|
*
|
||||||
|
* Copyright (c) lucko (Luck) <luck@lucko.me>
|
||||||
|
* Copyright (c) contributors
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all
|
||||||
|
* copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
* SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package me.lucko.luckperms.common.caching.handlers;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.common.model.PermissionHolder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents an object which is notified when the state of a {@link PermissionHolder} changes.
|
||||||
|
*/
|
||||||
|
public interface StateListener {
|
||||||
|
|
||||||
|
void onStateChange();
|
||||||
|
|
||||||
|
}
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.commands.impl.track;
|
package me.lucko.luckperms.common.commands.impl.track;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.api.DataMutateResult;
|
||||||
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
||||||
import me.lucko.luckperms.common.commands.CommandException;
|
import me.lucko.luckperms.common.commands.CommandException;
|
||||||
import me.lucko.luckperms.common.commands.CommandResult;
|
import me.lucko.luckperms.common.commands.CommandResult;
|
||||||
@ -40,7 +41,6 @@ import me.lucko.luckperms.common.model.Group;
|
|||||||
import me.lucko.luckperms.common.model.Track;
|
import me.lucko.luckperms.common.model.Track;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectAlreadyHasException;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -68,8 +68,9 @@ public class TrackAppend extends SubCommand<Track> {
|
|||||||
return CommandResult.LOADING_ERROR;
|
return CommandResult.LOADING_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
DataMutateResult result = track.appendGroup(group);
|
||||||
track.appendGroup(group);
|
|
||||||
|
if (result.asBoolean()) {
|
||||||
Message.TRACK_APPEND_SUCCESS.send(sender, group.getName(), track.getName());
|
Message.TRACK_APPEND_SUCCESS.send(sender, group.getName(), track.getName());
|
||||||
if (track.getGroups().size() > 1) {
|
if (track.getGroups().size() > 1) {
|
||||||
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups(), group.getName()));
|
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups(), group.getName()));
|
||||||
@ -79,7 +80,7 @@ public class TrackAppend extends SubCommand<Track> {
|
|||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
save(track, sender, plugin);
|
save(track, sender, plugin);
|
||||||
return CommandResult.SUCCESS;
|
return CommandResult.SUCCESS;
|
||||||
} catch (ObjectAlreadyHasException e) {
|
} else {
|
||||||
Message.TRACK_ALREADY_CONTAINS.send(sender, track.getName(), group.getName());
|
Message.TRACK_ALREADY_CONTAINS.send(sender, track.getName(), group.getName());
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.commands.impl.track;
|
package me.lucko.luckperms.common.commands.impl.track;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.api.DataMutateResult;
|
||||||
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
||||||
import me.lucko.luckperms.common.commands.CommandException;
|
import me.lucko.luckperms.common.commands.CommandException;
|
||||||
import me.lucko.luckperms.common.commands.CommandResult;
|
import me.lucko.luckperms.common.commands.CommandResult;
|
||||||
@ -40,7 +41,6 @@ import me.lucko.luckperms.common.model.Group;
|
|||||||
import me.lucko.luckperms.common.model.Track;
|
import me.lucko.luckperms.common.model.Track;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectAlreadyHasException;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -77,19 +77,23 @@ public class TrackInsert extends SubCommand<Track> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
track.insertGroup(group, pos - 1);
|
DataMutateResult result = track.insertGroup(group, pos - 1);
|
||||||
Message.TRACK_INSERT_SUCCESS.send(sender, group.getName(), track.getName(), pos);
|
|
||||||
if (track.getGroups().size() > 1) {
|
if (result.asBoolean()) {
|
||||||
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups(), group.getName()));
|
Message.TRACK_INSERT_SUCCESS.send(sender, group.getName(), track.getName(), pos);
|
||||||
|
if (track.getGroups().size() > 1) {
|
||||||
|
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups(), group.getName()));
|
||||||
|
}
|
||||||
|
ExtendedLogEntry.build().actor(sender).acted(track)
|
||||||
|
.action("insert " + group.getName() + " " + pos)
|
||||||
|
.build().submit(plugin, sender);
|
||||||
|
save(track, sender, plugin);
|
||||||
|
return CommandResult.SUCCESS;
|
||||||
|
} else {
|
||||||
|
Message.TRACK_ALREADY_CONTAINS.send(sender, track.getName(), group.getName());
|
||||||
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
ExtendedLogEntry.build().actor(sender).acted(track)
|
|
||||||
.action("insert " + group.getName() + " " + pos)
|
|
||||||
.build().submit(plugin, sender);
|
|
||||||
save(track, sender, plugin);
|
|
||||||
return CommandResult.SUCCESS;
|
|
||||||
} catch (ObjectAlreadyHasException e) {
|
|
||||||
Message.TRACK_ALREADY_CONTAINS.send(sender, track.getName(), group.getName());
|
|
||||||
return CommandResult.STATE_ERROR;
|
|
||||||
} catch (IndexOutOfBoundsException e) {
|
} catch (IndexOutOfBoundsException e) {
|
||||||
Message.TRACK_INSERT_ERROR_INVALID_POS.send(sender, pos);
|
Message.TRACK_INSERT_ERROR_INVALID_POS.send(sender, pos);
|
||||||
return CommandResult.INVALID_ARGS;
|
return CommandResult.INVALID_ARGS;
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.commands.impl.track;
|
package me.lucko.luckperms.common.commands.impl.track;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.api.DataMutateResult;
|
||||||
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
import me.lucko.luckperms.common.actionlog.ExtendedLogEntry;
|
||||||
import me.lucko.luckperms.common.commands.CommandException;
|
import me.lucko.luckperms.common.commands.CommandException;
|
||||||
import me.lucko.luckperms.common.commands.CommandResult;
|
import me.lucko.luckperms.common.commands.CommandResult;
|
||||||
@ -39,7 +40,6 @@ import me.lucko.luckperms.common.locale.Message;
|
|||||||
import me.lucko.luckperms.common.model.Track;
|
import me.lucko.luckperms.common.model.Track;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectLacksException;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
@ -56,8 +56,9 @@ public class TrackRemove extends SubCommand<Track> {
|
|||||||
return CommandResult.INVALID_ARGS;
|
return CommandResult.INVALID_ARGS;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
DataMutateResult result = track.removeGroup(groupName);
|
||||||
track.removeGroup(groupName);
|
|
||||||
|
if (result.asBoolean()) {
|
||||||
Message.TRACK_REMOVE_SUCCESS.send(sender, groupName, track.getName());
|
Message.TRACK_REMOVE_SUCCESS.send(sender, groupName, track.getName());
|
||||||
if (track.getGroups().size() > 1) {
|
if (track.getGroups().size() > 1) {
|
||||||
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups()));
|
Message.EMPTY.send(sender, Util.listToArrowSep(track.getGroups()));
|
||||||
@ -67,7 +68,7 @@ public class TrackRemove extends SubCommand<Track> {
|
|||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
save(track, sender, plugin);
|
save(track, sender, plugin);
|
||||||
return CommandResult.SUCCESS;
|
return CommandResult.SUCCESS;
|
||||||
} catch (ObjectLacksException e) {
|
} else {
|
||||||
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), groupName);
|
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), groupName);
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -48,7 +48,6 @@ import me.lucko.luckperms.common.model.User;
|
|||||||
import me.lucko.luckperms.common.node.NodeFactory;
|
import me.lucko.luckperms.common.node.NodeFactory;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectLacksException;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -120,7 +119,7 @@ public class UserDemote extends SubCommand<User> {
|
|||||||
final String previous;
|
final String previous;
|
||||||
try {
|
try {
|
||||||
previous = track.getPrevious(old);
|
previous = track.getPrevious(old);
|
||||||
} catch (ObjectLacksException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), old);
|
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), old);
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
@ -131,17 +130,15 @@ public class UserDemote extends SubCommand<User> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (previous == null) {
|
if (previous == null) {
|
||||||
|
|
||||||
user.unsetPermission(oldNode);
|
user.unsetPermission(oldNode);
|
||||||
|
|
||||||
Message.USER_DEMOTE_ENDOFTRACK.send(sender, track.getName(), user.getFriendlyName(), old);
|
Message.USER_DEMOTE_ENDOFTRACK.send(sender, track.getName(), user.getFriendlyName(), old);
|
||||||
|
|
||||||
ExtendedLogEntry.build().actor(sender).acted(user)
|
ExtendedLogEntry.build().actor(sender).acted(user)
|
||||||
.action("demote " + args.stream().collect(Collectors.joining(" ")))
|
.action("demote " + args.stream().collect(Collectors.joining(" ")))
|
||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
|
|
||||||
save(user, sender, plugin);
|
save(user, sender, plugin);
|
||||||
plugin.getApiProvider().getEventFactory().handleUserDemote(user, track, old, null);
|
plugin.getApiProvider().getEventFactory().handleUserDemote(user, track, old, null);
|
||||||
|
|
||||||
return CommandResult.SUCCESS;
|
return CommandResult.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,7 +46,6 @@ import me.lucko.luckperms.common.model.User;
|
|||||||
import me.lucko.luckperms.common.node.NodeFactory;
|
import me.lucko.luckperms.common.node.NodeFactory;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectLacksException;
|
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
@ -123,6 +122,7 @@ public class UserPromote extends SubCommand<User> {
|
|||||||
ExtendedLogEntry.build().actor(sender).acted(user)
|
ExtendedLogEntry.build().actor(sender).acted(user)
|
||||||
.action("promote " + args.stream().collect(Collectors.joining(" ")))
|
.action("promote " + args.stream().collect(Collectors.joining(" ")))
|
||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
|
|
||||||
save(user, sender, plugin);
|
save(user, sender, plugin);
|
||||||
plugin.getApiProvider().getEventFactory().handleUserPromote(user, track, null, first);
|
plugin.getApiProvider().getEventFactory().handleUserPromote(user, track, null, first);
|
||||||
return CommandResult.SUCCESS;
|
return CommandResult.SUCCESS;
|
||||||
@ -138,7 +138,7 @@ public class UserPromote extends SubCommand<User> {
|
|||||||
final String next;
|
final String next;
|
||||||
try {
|
try {
|
||||||
next = track.getNext(old);
|
next = track.getNext(old);
|
||||||
} catch (ObjectLacksException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), old);
|
Message.TRACK_DOES_NOT_CONTAIN.send(sender, track.getName(), old);
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,8 @@ import me.lucko.luckperms.api.Contexts;
|
|||||||
import me.lucko.luckperms.api.context.ContextCalculator;
|
import me.lucko.luckperms.api.context.ContextCalculator;
|
||||||
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
||||||
import me.lucko.luckperms.api.context.MutableContextSet;
|
import me.lucko.luckperms.api.context.MutableContextSet;
|
||||||
|
import me.lucko.luckperms.common.config.ConfigKeys;
|
||||||
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
@ -47,6 +49,7 @@ import java.util.concurrent.TimeUnit;
|
|||||||
*/
|
*/
|
||||||
public abstract class AbstractContextManager<T> implements ContextManager<T> {
|
public abstract class AbstractContextManager<T> implements ContextManager<T> {
|
||||||
|
|
||||||
|
protected final LuckPermsPlugin plugin;
|
||||||
private final List<ContextCalculator<T>> calculators = new CopyOnWriteArrayList<>();
|
private final List<ContextCalculator<T>> calculators = new CopyOnWriteArrayList<>();
|
||||||
private final List<ContextCalculator<?>> staticCalculators = new CopyOnWriteArrayList<>();
|
private final List<ContextCalculator<?>> staticCalculators = new CopyOnWriteArrayList<>();
|
||||||
|
|
||||||
@ -56,9 +59,14 @@ public abstract class AbstractContextManager<T> implements ContextManager<T> {
|
|||||||
.expireAfterWrite(50L, TimeUnit.MILLISECONDS) // expire roughly every tick
|
.expireAfterWrite(50L, TimeUnit.MILLISECONDS) // expire roughly every tick
|
||||||
.build(new Loader());
|
.build(new Loader());
|
||||||
|
|
||||||
|
protected AbstractContextManager(LuckPermsPlugin plugin) {
|
||||||
|
this.plugin = plugin;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ImmutableContextSet getApplicableContext(@NonNull T subject) {
|
public ImmutableContextSet getApplicableContext(@NonNull T subject) {
|
||||||
// this is actually already immutable, but the Contexts method signature returns the interface.
|
// this is actually already immutable, but the Contexts method signature returns the interface.
|
||||||
|
// using the makeImmutable method is faster than casting
|
||||||
return getApplicableContexts(subject).getContexts().makeImmutable();
|
return getApplicableContexts(subject).getContexts().makeImmutable();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,8 +76,30 @@ public abstract class AbstractContextManager<T> implements ContextManager<T> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void registerCalculator(ContextCalculator<T> calculator) {
|
public ImmutableContextSet getStaticContext() {
|
||||||
registerCalculator(calculator, false);
|
MutableContextSet accumulator = MutableContextSet.create();
|
||||||
|
for (ContextCalculator<?> calculator : staticCalculators) {
|
||||||
|
calculator.giveApplicableContext(null, accumulator);
|
||||||
|
}
|
||||||
|
return accumulator.makeImmutable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Contexts getStaticContexts() {
|
||||||
|
return formContexts(getStaticContext());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Contexts formContexts(ImmutableContextSet contextSet) {
|
||||||
|
return new Contexts(
|
||||||
|
contextSet,
|
||||||
|
plugin.getConfiguration().get(ConfigKeys.INCLUDING_GLOBAL_PERMS),
|
||||||
|
plugin.getConfiguration().get(ConfigKeys.INCLUDING_GLOBAL_WORLD_PERMS),
|
||||||
|
true,
|
||||||
|
plugin.getConfiguration().get(ConfigKeys.APPLYING_GLOBAL_GROUPS),
|
||||||
|
plugin.getConfiguration().get(ConfigKeys.APPLYING_GLOBAL_WORLD_GROUPS),
|
||||||
|
false
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -82,15 +112,6 @@ public abstract class AbstractContextManager<T> implements ContextManager<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public ImmutableContextSet getStaticContexts() {
|
|
||||||
MutableContextSet accumulator = MutableContextSet.create();
|
|
||||||
for (ContextCalculator<?> calculator : staticCalculators) {
|
|
||||||
calculator.giveApplicableContext(null, accumulator);
|
|
||||||
}
|
|
||||||
return accumulator.makeImmutable();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void invalidateCache(@NonNull T subject){
|
public void invalidateCache(@NonNull T subject){
|
||||||
lookupCache.invalidate(subject);
|
lookupCache.invalidate(subject);
|
||||||
|
@ -55,6 +55,20 @@ public interface ContextManager<T> {
|
|||||||
*/
|
*/
|
||||||
Contexts getApplicableContexts(@NonNull T subject);
|
Contexts getApplicableContexts(@NonNull T subject);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the contexts from the static calculators in this manager.
|
||||||
|
*
|
||||||
|
* @return the current active static contexts
|
||||||
|
*/
|
||||||
|
ImmutableContextSet getStaticContext();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the contexts from the static calculators in this manager.
|
||||||
|
*
|
||||||
|
* @return the current active static contexts
|
||||||
|
*/
|
||||||
|
Contexts getStaticContexts();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Forms a {@link Contexts} instance from an {@link ImmutableContextSet}.
|
* Forms a {@link Contexts} instance from an {@link ImmutableContextSet}.
|
||||||
*
|
*
|
||||||
@ -64,12 +78,22 @@ public interface ContextManager<T> {
|
|||||||
*/
|
*/
|
||||||
Contexts formContexts(T subject, ImmutableContextSet contextSet);
|
Contexts formContexts(T subject, ImmutableContextSet contextSet);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Forms a {@link Contexts} instance from an {@link ImmutableContextSet}.
|
||||||
|
*
|
||||||
|
* @param contextSet the context set
|
||||||
|
* @return a contexts instance
|
||||||
|
*/
|
||||||
|
Contexts formContexts(ImmutableContextSet contextSet);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a context calculator with the manager.
|
* Registers a context calculator with the manager.
|
||||||
*
|
*
|
||||||
* @param calculator the calculator
|
* @param calculator the calculator
|
||||||
*/
|
*/
|
||||||
void registerCalculator(ContextCalculator<T> calculator);
|
default void registerCalculator(ContextCalculator<T> calculator) {
|
||||||
|
registerCalculator(calculator, false);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers a context calculator with the manager.
|
* Registers a context calculator with the manager.
|
||||||
@ -79,13 +103,6 @@ public interface ContextManager<T> {
|
|||||||
*/
|
*/
|
||||||
void registerCalculator(ContextCalculator<T> calculator, boolean isStatic);
|
void registerCalculator(ContextCalculator<T> calculator, boolean isStatic);
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the contexts from the static calculators in this manager.
|
|
||||||
*
|
|
||||||
* @return the current active static contexts
|
|
||||||
*/
|
|
||||||
ImmutableContextSet getStaticContexts();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Invalidates the lookup cache for a given subject
|
* Invalidates the lookup cache for a given subject
|
||||||
*
|
*
|
||||||
|
@ -48,6 +48,7 @@ import me.lucko.luckperms.api.context.ImmutableContextSet;
|
|||||||
import me.lucko.luckperms.common.api.delegates.PermissionHolderDelegate;
|
import me.lucko.luckperms.common.api.delegates.PermissionHolderDelegate;
|
||||||
import me.lucko.luckperms.common.buffers.Cache;
|
import me.lucko.luckperms.common.buffers.Cache;
|
||||||
import me.lucko.luckperms.common.caching.MetaAccumulator;
|
import me.lucko.luckperms.common.caching.MetaAccumulator;
|
||||||
|
import me.lucko.luckperms.common.caching.handlers.StateListener;
|
||||||
import me.lucko.luckperms.common.config.ConfigKeys;
|
import me.lucko.luckperms.common.config.ConfigKeys;
|
||||||
import me.lucko.luckperms.common.contexts.ContextSetComparator;
|
import me.lucko.luckperms.common.contexts.ContextSetComparator;
|
||||||
import me.lucko.luckperms.common.contexts.ExtractedContexts;
|
import me.lucko.luckperms.common.contexts.ExtractedContexts;
|
||||||
@ -208,7 +209,7 @@ public abstract class PermissionHolder {
|
|||||||
* A set of runnables which are called when this objects state changes.
|
* A set of runnables which are called when this objects state changes.
|
||||||
*/
|
*/
|
||||||
@Getter
|
@Getter
|
||||||
private final Set<Runnable> stateListeners = ConcurrentHashMap.newKeySet();
|
private final Set<StateListener> stateListeners = ConcurrentHashMap.newKeySet();
|
||||||
|
|
||||||
private void invalidateCache() {
|
private void invalidateCache() {
|
||||||
nodesCopy.invalidate();
|
nodesCopy.invalidate();
|
||||||
@ -216,9 +217,9 @@ public abstract class PermissionHolder {
|
|||||||
weightCache.invalidate();
|
weightCache.invalidate();
|
||||||
|
|
||||||
// Invalidate listeners
|
// Invalidate listeners
|
||||||
for (Runnable r : stateListeners) {
|
for (StateListener listener : stateListeners) {
|
||||||
try {
|
try {
|
||||||
r.run();
|
listener.onStateChange();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
|
@ -32,11 +32,10 @@ import lombok.ToString;
|
|||||||
|
|
||||||
import com.google.common.collect.ImmutableList;
|
import com.google.common.collect.ImmutableList;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.api.DataMutateResult;
|
||||||
import me.lucko.luckperms.common.api.delegates.TrackDelegate;
|
import me.lucko.luckperms.common.api.delegates.TrackDelegate;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.references.Identifiable;
|
import me.lucko.luckperms.common.references.Identifiable;
|
||||||
import me.lucko.luckperms.exceptions.ObjectAlreadyHasException;
|
|
||||||
import me.lucko.luckperms.exceptions.ObjectLacksException;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
@ -101,9 +100,9 @@ public class Track implements Identifiable<String> {
|
|||||||
*
|
*
|
||||||
* @param current the group before the group being requested
|
* @param current the group before the group being requested
|
||||||
* @return the group name, or null if the end of the track has been reached
|
* @return the group name, or null if the end of the track has been reached
|
||||||
* @throws ObjectLacksException if the track does not contain the group given
|
* @throws IllegalArgumentException if the track does not contain the group given
|
||||||
*/
|
*/
|
||||||
public String getNext(Group current) throws ObjectLacksException {
|
public String getNext(Group current) throws IllegalArgumentException {
|
||||||
return getNext(current.getName());
|
return getNext(current.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -112,9 +111,9 @@ public class Track implements Identifiable<String> {
|
|||||||
*
|
*
|
||||||
* @param current the group after the group being requested
|
* @param current the group after the group being requested
|
||||||
* @return the group name, or null if the start of the track has been reached
|
* @return the group name, or null if the start of the track has been reached
|
||||||
* @throws ObjectLacksException if the track does not contain the group given
|
* @throws IllegalArgumentException if the track does not contain the group given
|
||||||
*/
|
*/
|
||||||
public String getPrevious(Group current) throws ObjectLacksException {
|
public String getPrevious(Group current) throws IllegalArgumentException {
|
||||||
return getPrevious(current.getName());
|
return getPrevious(current.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -123,10 +122,12 @@ public class Track implements Identifiable<String> {
|
|||||||
*
|
*
|
||||||
* @param current the group before the group being requested
|
* @param current the group before the group being requested
|
||||||
* @return the group name, or null if the end of the track has been reached
|
* @return the group name, or null if the end of the track has been reached
|
||||||
* @throws ObjectLacksException if the track does not contain the group given
|
* @throws IllegalArgumentException if the track does not contain the group given
|
||||||
*/
|
*/
|
||||||
public String getNext(String current) throws ObjectLacksException {
|
public String getNext(String current) throws IllegalArgumentException {
|
||||||
assertContains(current);
|
if (!containsGroup(current)) {
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
|
||||||
if (groups.indexOf(current) == groups.size() - 1) {
|
if (groups.indexOf(current) == groups.size() - 1) {
|
||||||
return null;
|
return null;
|
||||||
@ -140,10 +141,12 @@ public class Track implements Identifiable<String> {
|
|||||||
*
|
*
|
||||||
* @param current the group after the group being requested
|
* @param current the group after the group being requested
|
||||||
* @return the group name, or null if the start of the track has been reached
|
* @return the group name, or null if the start of the track has been reached
|
||||||
* @throws ObjectLacksException if the track does not contain the group given
|
* @throws IllegalArgumentException if the track does not contain the group given
|
||||||
*/
|
*/
|
||||||
public String getPrevious(String current) throws ObjectLacksException {
|
public String getPrevious(String current) throws IllegalArgumentException {
|
||||||
assertContains(current);
|
if (!containsGroup(current)) {
|
||||||
|
throw new IllegalArgumentException();
|
||||||
|
}
|
||||||
|
|
||||||
if (groups.indexOf(current) == 0) {
|
if (groups.indexOf(current) == 0) {
|
||||||
return null;
|
return null;
|
||||||
@ -156,16 +159,19 @@ public class Track implements Identifiable<String> {
|
|||||||
* Appends a group to the end of this track
|
* Appends a group to the end of this track
|
||||||
*
|
*
|
||||||
* @param group the group to append
|
* @param group the group to append
|
||||||
* @throws ObjectAlreadyHasException if the group is already on this track somewhere
|
* @return the result of the operation
|
||||||
*/
|
*/
|
||||||
public void appendGroup(Group group) throws ObjectAlreadyHasException {
|
public DataMutateResult appendGroup(Group group) {
|
||||||
|
if (containsGroup(group)) {
|
||||||
|
return DataMutateResult.ALREADY_HAS;
|
||||||
|
}
|
||||||
|
|
||||||
List<String> before = ImmutableList.copyOf(groups);
|
List<String> before = ImmutableList.copyOf(groups);
|
||||||
|
|
||||||
assertNotContains(group);
|
|
||||||
groups.add(group.getName());
|
groups.add(group.getName());
|
||||||
|
|
||||||
List<String> after = ImmutableList.copyOf(groups);
|
List<String> after = ImmutableList.copyOf(groups);
|
||||||
|
|
||||||
plugin.getApiProvider().getEventFactory().handleTrackAddGroup(this, group.getName(), before, after);
|
plugin.getApiProvider().getEventFactory().handleTrackAddGroup(this, group.getName(), before, after);
|
||||||
|
return DataMutateResult.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -173,42 +179,49 @@ public class Track implements Identifiable<String> {
|
|||||||
*
|
*
|
||||||
* @param group the group to be inserted
|
* @param group the group to be inserted
|
||||||
* @param position the index position (a value of 0 inserts at the start)
|
* @param position the index position (a value of 0 inserts at the start)
|
||||||
* @throws ObjectAlreadyHasException if the group is already on this track somewhere
|
|
||||||
* @throws IndexOutOfBoundsException if the position is less than 0 or greater than the size of the track
|
* @throws IndexOutOfBoundsException if the position is less than 0 or greater than the size of the track
|
||||||
|
* @return the result of the operation
|
||||||
*/
|
*/
|
||||||
public void insertGroup(Group group, int position) throws ObjectAlreadyHasException, IndexOutOfBoundsException {
|
public DataMutateResult insertGroup(Group group, int position) throws IndexOutOfBoundsException {
|
||||||
List<String> before = ImmutableList.copyOf(groups);
|
if (containsGroup(group)) {
|
||||||
|
return DataMutateResult.ALREADY_HAS;
|
||||||
|
}
|
||||||
|
|
||||||
assertNotContains(group);
|
List<String> before = ImmutableList.copyOf(groups);
|
||||||
groups.add(position, group.getName());
|
groups.add(position, group.getName());
|
||||||
|
|
||||||
List<String> after = ImmutableList.copyOf(groups);
|
List<String> after = ImmutableList.copyOf(groups);
|
||||||
|
|
||||||
plugin.getApiProvider().getEventFactory().handleTrackAddGroup(this, group.getName(), before, after);
|
plugin.getApiProvider().getEventFactory().handleTrackAddGroup(this, group.getName(), before, after);
|
||||||
|
return DataMutateResult.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes a group from this track
|
* Removes a group from this track
|
||||||
*
|
*
|
||||||
* @param group the group to remove
|
* @param group the group to remove
|
||||||
* @throws ObjectLacksException if the group is not on this track
|
* @return the result of the operation
|
||||||
*/
|
*/
|
||||||
public void removeGroup(Group group) throws ObjectLacksException {
|
public DataMutateResult removeGroup(Group group) {
|
||||||
removeGroup(group.getName());
|
return removeGroup(group.getName());
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes a group from this track
|
* Removes a group from this track
|
||||||
*
|
*
|
||||||
* @param group the group to remove
|
* @param group the group to remove
|
||||||
* @throws ObjectLacksException if the group is not on this track
|
* @return the result of the operation
|
||||||
*/
|
*/
|
||||||
public void removeGroup(String group) throws ObjectLacksException {
|
public DataMutateResult removeGroup(String group) {
|
||||||
|
if (!containsGroup(group)) {
|
||||||
|
return DataMutateResult.LACKS;
|
||||||
|
}
|
||||||
|
|
||||||
List<String> before = ImmutableList.copyOf(groups);
|
List<String> before = ImmutableList.copyOf(groups);
|
||||||
assertContains(group);
|
|
||||||
groups.remove(group);
|
groups.remove(group);
|
||||||
|
|
||||||
List<String> after = ImmutableList.copyOf(groups);
|
List<String> after = ImmutableList.copyOf(groups);
|
||||||
|
|
||||||
plugin.getApiProvider().getEventFactory().handleTrackRemoveGroup(this, group, before, after);
|
plugin.getApiProvider().getEventFactory().handleTrackRemoveGroup(this, group, before, after);
|
||||||
|
return DataMutateResult.SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -239,16 +252,4 @@ public class Track implements Identifiable<String> {
|
|||||||
groups.clear();
|
groups.clear();
|
||||||
plugin.getApiProvider().getEventFactory().handleTrackClear(this, before);
|
plugin.getApiProvider().getEventFactory().handleTrackClear(this, before);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertNotContains(Group g) throws ObjectAlreadyHasException {
|
|
||||||
if (containsGroup(g)) {
|
|
||||||
throw new ObjectAlreadyHasException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void assertContains(String g) throws ObjectLacksException {
|
|
||||||
if (!containsGroup(g)) {
|
|
||||||
throw new ObjectLacksException();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -25,51 +25,31 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.primarygroup;
|
package me.lucko.luckperms.common.primarygroup;
|
||||||
|
|
||||||
import lombok.NonNull;
|
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.common.config.ConfigKeys;
|
|
||||||
import me.lucko.luckperms.common.contexts.ExtractedContexts;
|
import me.lucko.luckperms.common.contexts.ExtractedContexts;
|
||||||
import me.lucko.luckperms.common.model.Group;
|
import me.lucko.luckperms.common.model.Group;
|
||||||
import me.lucko.luckperms.common.model.User;
|
import me.lucko.luckperms.common.model.User;
|
||||||
|
|
||||||
import java.util.AbstractList;
|
import java.util.AbstractList;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashSet;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
public class AllParentsByWeightHolder extends StoredHolder {
|
public class AllParentsByWeightHolder extends CachedPrimaryGroupHolder {
|
||||||
|
public AllParentsByWeightHolder(User user) {
|
||||||
private String cachedValue = null;
|
|
||||||
private boolean useCached = false;
|
|
||||||
|
|
||||||
public AllParentsByWeightHolder(@NonNull User user) {
|
|
||||||
super(user);
|
super(user);
|
||||||
user.getStateListeners().add(() -> useCached = false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getValue() {
|
protected String calculateValue() {
|
||||||
if (useCached) {
|
|
||||||
return cachedValue;
|
|
||||||
}
|
|
||||||
|
|
||||||
Contexts contexts = user.getPlugin().getContextForUser(user);
|
Contexts contexts = user.getPlugin().getContextForUser(user);
|
||||||
if (contexts == null) {
|
if (contexts == null) {
|
||||||
contexts = new Contexts(
|
contexts = user.getPlugin().getContextManager().getStaticContexts();
|
||||||
user.getPlugin().getContextManager().getStaticContexts(),
|
|
||||||
user.getPlugin().getConfiguration().get(ConfigKeys.INCLUDING_GLOBAL_PERMS),
|
|
||||||
user.getPlugin().getConfiguration().get(ConfigKeys.INCLUDING_GLOBAL_WORLD_PERMS),
|
|
||||||
true,
|
|
||||||
user.getPlugin().getConfiguration().get(ConfigKeys.APPLYING_GLOBAL_GROUPS),
|
|
||||||
user.getPlugin().getConfiguration().get(ConfigKeys.APPLYING_GLOBAL_WORLD_GROUPS),
|
|
||||||
false
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// hack to get a list of groups the holder is inheriting from
|
// hack to get a list of groups the holder is inheriting from
|
||||||
Set<String> groupNames = new HashSet<>();
|
Set<String> groupNames = new LinkedHashSet<>();
|
||||||
user.resolveInheritances(new NoopList<>(), groupNames, ExtractedContexts.generate(contexts));
|
user.resolveInheritances(new NoopList<>(), groupNames, ExtractedContexts.generate(contexts));
|
||||||
|
|
||||||
List<Group> groups = new ArrayList<>();
|
List<Group> groups = new ArrayList<>();
|
||||||
@ -93,9 +73,7 @@ public class AllParentsByWeightHolder extends StoredHolder {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cachedValue = bestGroup == null ? null : bestGroup.getName();
|
return bestGroup == null ? null : bestGroup.getName();
|
||||||
useCached = true;
|
|
||||||
return cachedValue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class NoopList<E> extends AbstractList<E> implements List<E> {
|
private static final class NoopList<E> extends AbstractList<E> implements List<E> {
|
||||||
|
@ -0,0 +1,63 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of LuckPerms, licensed under the MIT License.
|
||||||
|
*
|
||||||
|
* Copyright (c) lucko (Luck) <luck@lucko.me>
|
||||||
|
* Copyright (c) contributors
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in all
|
||||||
|
* copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||||
|
* SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package me.lucko.luckperms.common.primarygroup;
|
||||||
|
|
||||||
|
import me.lucko.luckperms.common.buffers.Cache;
|
||||||
|
import me.lucko.luckperms.common.caching.handlers.StateListener;
|
||||||
|
import me.lucko.luckperms.common.model.User;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract implementation of {@link StateListener} which caches all lookups.
|
||||||
|
*/
|
||||||
|
public abstract class CachedPrimaryGroupHolder extends StoredHolder implements StateListener {
|
||||||
|
|
||||||
|
// cache lookups
|
||||||
|
private final Cache<String> cache = new Cache<String>() {
|
||||||
|
@Override
|
||||||
|
protected String supply() {
|
||||||
|
return calculateValue();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public CachedPrimaryGroupHolder(User user) {
|
||||||
|
super(user);
|
||||||
|
user.getStateListeners().add(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract String calculateValue();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String getValue() {
|
||||||
|
String s = cache.get();
|
||||||
|
return s != null ? s : getStoredValue();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onStateChange() {
|
||||||
|
cache.invalidate();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -25,38 +25,28 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.primarygroup;
|
package me.lucko.luckperms.common.primarygroup;
|
||||||
|
|
||||||
import lombok.NonNull;
|
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.api.Node;
|
import me.lucko.luckperms.api.Node;
|
||||||
import me.lucko.luckperms.api.context.ContextSet;
|
|
||||||
import me.lucko.luckperms.common.model.Group;
|
import me.lucko.luckperms.common.model.Group;
|
||||||
import me.lucko.luckperms.common.model.User;
|
import me.lucko.luckperms.common.model.User;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.LinkedHashSet;
|
||||||
import java.util.List;
|
import java.util.Set;
|
||||||
|
|
||||||
public class ParentsByWeightHolder extends StoredHolder {
|
public class ParentsByWeightHolder extends CachedPrimaryGroupHolder {
|
||||||
|
public ParentsByWeightHolder(User user) {
|
||||||
private String cachedValue = null;
|
|
||||||
private boolean useCached = false;
|
|
||||||
|
|
||||||
public ParentsByWeightHolder(@NonNull User user) {
|
|
||||||
super(user);
|
super(user);
|
||||||
user.getStateListeners().add(() -> useCached = false);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getValue() {
|
protected String calculateValue() {
|
||||||
if (useCached) {
|
Contexts contexts = user.getPlugin().getContextForUser(user);
|
||||||
return cachedValue;
|
if (contexts == null) {
|
||||||
|
contexts = user.getPlugin().getContextManager().getStaticContexts();
|
||||||
}
|
}
|
||||||
|
|
||||||
Contexts contexts = user.getPlugin().getContextForUser(user);
|
Set<Group> groups = new LinkedHashSet<>();
|
||||||
ContextSet contextSet = contexts != null ? contexts.getContexts() : user.getPlugin().getContextManager().getStaticContexts();
|
for (Node node : user.filterNodes(contexts.getContexts())) {
|
||||||
|
|
||||||
List<Group> groups = new ArrayList<>();
|
|
||||||
for (Node node : user.filterNodes(contextSet)) {
|
|
||||||
if (!node.getValuePrimitive() || !node.isGroupNode()) {
|
if (!node.getValuePrimitive() || !node.isGroupNode()) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
@ -80,8 +70,6 @@ public class ParentsByWeightHolder extends StoredHolder {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cachedValue = bestGroup == null ? null : bestGroup.getName();
|
return bestGroup == null ? null : bestGroup.getName();
|
||||||
useCached = true;
|
|
||||||
return cachedValue;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -26,12 +26,14 @@
|
|||||||
package me.lucko.luckperms.common.primarygroup;
|
package me.lucko.luckperms.common.primarygroup;
|
||||||
|
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.RequiredArgsConstructor;
|
import lombok.NonNull;
|
||||||
import lombok.Setter;
|
import lombok.Setter;
|
||||||
|
|
||||||
import me.lucko.luckperms.common.model.User;
|
import me.lucko.luckperms.common.model.User;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
/**
|
||||||
|
* Simple implementation of {@link PrimaryGroupHolder}, which just returns the stored value.
|
||||||
|
*/
|
||||||
public class StoredHolder implements PrimaryGroupHolder {
|
public class StoredHolder implements PrimaryGroupHolder {
|
||||||
|
|
||||||
protected final User user;
|
protected final User user;
|
||||||
@ -40,6 +42,10 @@ public class StoredHolder implements PrimaryGroupHolder {
|
|||||||
@Setter
|
@Setter
|
||||||
private String storedValue = null;
|
private String storedValue = null;
|
||||||
|
|
||||||
|
public StoredHolder(@NonNull User user) {
|
||||||
|
this.user = user;
|
||||||
|
}
|
||||||
|
|
||||||
public String getValue() {
|
public String getValue() {
|
||||||
return storedValue;
|
return storedValue;
|
||||||
}
|
}
|
||||||
|
@ -52,25 +52,29 @@ public class UuidCache {
|
|||||||
private final UuidCacheDelegate delegate = new UuidCacheDelegate(this);
|
private final UuidCacheDelegate delegate = new UuidCacheDelegate(this);
|
||||||
|
|
||||||
public UUID getUUID(UUID external) {
|
public UUID getUUID(UUID external) {
|
||||||
return plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS) ? external : cache.getOrDefault(external, external);
|
return inUse() ? external : cache.getOrDefault(external, external);
|
||||||
}
|
}
|
||||||
|
|
||||||
public UUID getExternalUUID(UUID internal) {
|
public UUID getExternalUUID(UUID internal) {
|
||||||
return plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS) ? internal : cache.inverse().getOrDefault(internal, internal);
|
return inUse() ? internal : cache.inverse().getOrDefault(internal, internal);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addToCache(UUID external, UUID internal) {
|
public void addToCache(UUID external, UUID internal) {
|
||||||
if (plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS)) return;
|
if (inUse()) return;
|
||||||
cache.forcePut(external, internal);
|
cache.forcePut(external, internal);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clearCache(UUID external) {
|
public void clearCache(UUID external) {
|
||||||
if (plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS)) return;
|
if (inUse()) return;
|
||||||
cache.remove(external);
|
cache.remove(external);
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getSize() {
|
public int getSize() {
|
||||||
return plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS) ? 0 : cache.size();
|
return inUse() ? 0 : cache.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean inUse() {
|
||||||
|
return plugin.getConfiguration().get(ConfigKeys.USE_SERVER_UUIDS);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -25,8 +25,6 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.sponge.contexts;
|
package me.lucko.luckperms.sponge.contexts;
|
||||||
|
|
||||||
import lombok.RequiredArgsConstructor;
|
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
||||||
import me.lucko.luckperms.common.config.ConfigKeys;
|
import me.lucko.luckperms.common.config.ConfigKeys;
|
||||||
@ -35,9 +33,10 @@ import me.lucko.luckperms.sponge.LPSpongePlugin;
|
|||||||
|
|
||||||
import org.spongepowered.api.service.permission.Subject;
|
import org.spongepowered.api.service.permission.Subject;
|
||||||
|
|
||||||
@RequiredArgsConstructor
|
|
||||||
public class SpongeContextManager extends AbstractContextManager<Subject> {
|
public class SpongeContextManager extends AbstractContextManager<Subject> {
|
||||||
private final LPSpongePlugin plugin;
|
public SpongeContextManager(LPSpongePlugin plugin) {
|
||||||
|
super(plugin);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Contexts formContexts(Subject subject, ImmutableContextSet contextSet) {
|
public Contexts formContexts(Subject subject, ImmutableContextSet contextSet) {
|
||||||
|
@ -41,7 +41,6 @@ import me.lucko.luckperms.common.model.Track;
|
|||||||
import me.lucko.luckperms.common.model.User;
|
import me.lucko.luckperms.common.model.User;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
import me.lucko.luckperms.common.utils.Predicates;
|
import me.lucko.luckperms.common.utils.Predicates;
|
||||||
import me.lucko.luckperms.exceptions.ObjectAlreadyHasException;
|
|
||||||
import me.lucko.luckperms.sponge.LPSpongePlugin;
|
import me.lucko.luckperms.sponge.LPSpongePlugin;
|
||||||
import me.lucko.luckperms.sponge.service.LuckPermsService;
|
import me.lucko.luckperms.sponge.service.LuckPermsService;
|
||||||
|
|
||||||
@ -161,9 +160,7 @@ public class MigrationPermissionsEx extends SubCommand<Object> {
|
|||||||
for (String groupName : e.getValue().values()) {
|
for (String groupName : e.getValue().values()) {
|
||||||
Group group = plugin.getGroupManager().getIfLoaded(groupName);
|
Group group = plugin.getGroupManager().getIfLoaded(groupName);
|
||||||
if (group != null) {
|
if (group != null) {
|
||||||
try {
|
track.appendGroup(group);
|
||||||
track.appendGroup(group);
|
|
||||||
} catch (ObjectAlreadyHasException ignored) {}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user