Refactor PermissionHolder
This commit is contained in:
parent
36bc1553c0
commit
a58cc6bdf3
@ -82,6 +82,28 @@ public abstract class PermissionHolder {
|
|||||||
|
|
||||||
public abstract String getFriendlyName();
|
public abstract String getFriendlyName();
|
||||||
|
|
||||||
|
public Set<Node> getNodes() {
|
||||||
|
Optional<ImmutableSet<Node>> opt = enduringCache.getIfPresent();
|
||||||
|
if (opt.isPresent()) {
|
||||||
|
return opt.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
return enduringCache.get(() -> ImmutableSet.copyOf(nodes));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Node> getTransientNodes() {
|
||||||
|
Optional<ImmutableSet<Node>> opt = transientCache.getIfPresent();
|
||||||
|
if (opt.isPresent()) {
|
||||||
|
return opt.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
synchronized (transientNodes) {
|
||||||
|
return transientCache.get(() -> ImmutableSet.copyOf(transientNodes));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void invalidateCache(boolean enduring) {
|
private void invalidateCache(boolean enduring) {
|
||||||
if (enduring) {
|
if (enduring) {
|
||||||
enduringCache.invalidate();
|
enduringCache.invalidate();
|
||||||
@ -92,219 +114,51 @@ public abstract class PermissionHolder {
|
|||||||
mergedCache.invalidate();
|
mergedCache.invalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Set<Node> getNodes() {
|
|
||||||
synchronized (nodes) {
|
|
||||||
return enduringCache.get(() -> ImmutableSet.copyOf(nodes));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public Set<Node> getTransientNodes() {
|
|
||||||
synchronized (transientNodes) {
|
|
||||||
return transientCache.get(() -> ImmutableSet.copyOf(transientNodes));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setNodes(Set<Node> nodes) {
|
|
||||||
synchronized (this.nodes) {
|
|
||||||
if (!this.nodes.equals(nodes)) {
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.nodes.clear();
|
|
||||||
this.nodes.addAll(nodes);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setTransientNodes(Set<Node> nodes) {
|
|
||||||
synchronized (this.transientNodes) {
|
|
||||||
if (!this.transientNodes.equals(nodes)) {
|
|
||||||
invalidateCache(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.transientNodes.clear();
|
|
||||||
this.transientNodes.addAll(nodes);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Deprecated
|
|
||||||
public void setNodes(Map<String, Boolean> nodes) {
|
|
||||||
synchronized (this.nodes) {
|
|
||||||
if (!this.nodes.equals(nodes)) {
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
this.nodes.clear();
|
|
||||||
this.nodes.addAll(nodes.entrySet().stream()
|
|
||||||
.map(e -> me.lucko.luckperms.common.core.Node.fromSerialisedNode(e.getKey(), e.getValue()))
|
|
||||||
.collect(Collectors.toList()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void addNodeUnchecked(Node node) {
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.add(node);
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Clear all of the holders permission nodes
|
|
||||||
*/
|
|
||||||
public void clearNodes() {
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.clear();
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearNodes(String server) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.getServer().orElse("global").equalsIgnoreCase(finalServer));
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearNodes(String server, String world) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
if (world == null) {
|
|
||||||
world = "null";
|
|
||||||
}
|
|
||||||
String finalWorld = world;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.getServer().orElse("global").equalsIgnoreCase(finalServer) && n.getWorld().orElse("null").equalsIgnoreCase(finalWorld));
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMeta() {
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.isMeta() || n.isPrefix() || n.isSuffix());
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMeta(String server) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> (n.isMeta() || n.isPrefix() || n.isSuffix()) &&
|
|
||||||
n.getServer().orElse("global").equalsIgnoreCase(finalServer)
|
|
||||||
);
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMeta(String server, String world) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
if (world == null) {
|
|
||||||
world = "null";
|
|
||||||
}
|
|
||||||
String finalWorld = world;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> (n.isMeta() || n.isPrefix() || n.isSuffix()) &&
|
|
||||||
(n.getServer().orElse("global").equalsIgnoreCase(finalServer) &&
|
|
||||||
n.getWorld().orElse("null").equalsIgnoreCase(finalWorld))
|
|
||||||
);
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMetaKeys(String key, boolean temp) {
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.isMeta() && (n.isTemporary() == temp) && n.getMeta().getKey().equalsIgnoreCase(key));
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMetaKeys(String key, String server, boolean temp) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.isMeta() && (n.isTemporary() == temp) && n.getMeta().getKey().equalsIgnoreCase(key) &&
|
|
||||||
n.getServer().orElse("global").equalsIgnoreCase(finalServer)
|
|
||||||
);
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearMetaKeys(String key, String server, String world, boolean temp) {
|
|
||||||
if (server == null) {
|
|
||||||
server = "global";
|
|
||||||
}
|
|
||||||
String finalServer = server;
|
|
||||||
|
|
||||||
if (world == null) {
|
|
||||||
world = "null";
|
|
||||||
}
|
|
||||||
String finalWorld = world;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
|
||||||
nodes.removeIf(n -> n.isMeta() && (n.isTemporary() == temp) && n.getMeta().getKey().equalsIgnoreCase(key) &&
|
|
||||||
n.getServer().orElse("global").equalsIgnoreCase(finalServer) &&
|
|
||||||
n.getWorld().orElse("null").equalsIgnoreCase(finalWorld)
|
|
||||||
);
|
|
||||||
invalidateCache(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void clearTransientNodes() {
|
|
||||||
synchronized (transientNodes) {
|
|
||||||
transientNodes.clear();
|
|
||||||
invalidateCache(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Combines and returns this holders nodes in a priority order.
|
* Combines and returns this holders nodes in a priority order.
|
||||||
* @return the holders transient and permanent nodes
|
* @return the holders transient and permanent nodes
|
||||||
*/
|
*/
|
||||||
public SortedSet<LocalizedNode> getPermissions(boolean mergeTemp) {
|
public SortedSet<LocalizedNode> getPermissions(boolean mergeTemp) {
|
||||||
Supplier<ImmutableSortedSet<LocalizedNode>> supplier = () -> {
|
Supplier<ImmutableSortedSet<LocalizedNode>> supplier = () -> {
|
||||||
|
// Create sorted set
|
||||||
TreeSet<LocalizedNode> combined = new TreeSet<>(PriorityComparator.reverse());
|
TreeSet<LocalizedNode> combined = new TreeSet<>(PriorityComparator.reverse());
|
||||||
|
|
||||||
getNodes().stream()
|
// Flatten enduring and transient nodes
|
||||||
.map(n -> me.lucko.luckperms.common.utils.LocalizedNode.of(n, getObjectName()))
|
combined.addAll(getNodes().stream()
|
||||||
.forEach(combined::add);
|
.map(n -> makeLocal(n, getObjectName()))
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
);
|
||||||
|
combined.addAll(getTransientNodes().stream()
|
||||||
|
.map(n -> makeLocal(n, getObjectName()))
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
);
|
||||||
|
|
||||||
getTransientNodes().stream()
|
// Create an iterator over all permissions being considered
|
||||||
.map(n -> me.lucko.luckperms.common.utils.LocalizedNode.of(n, getObjectName()))
|
Iterator<LocalizedNode> it = combined.iterator();
|
||||||
.forEach(combined::add);
|
|
||||||
|
|
||||||
TreeSet<LocalizedNode> permissions = new TreeSet<>(PriorityComparator.reverse());
|
// Temporary set to store high priority values
|
||||||
|
Set<LocalizedNode> higherPriority = new HashSet<>();
|
||||||
|
|
||||||
combined:
|
// Iterate through each node being considered
|
||||||
for (LocalizedNode node : combined) {
|
iterate:
|
||||||
for (LocalizedNode other : permissions) {
|
while (it.hasNext()) {
|
||||||
if (mergeTemp ? node.getNode().equalsIgnoringValueOrTemp(other.getNode()) : node.getNode().almostEquals(other.getNode())) {
|
LocalizedNode entry = it.next();
|
||||||
continue combined;
|
|
||||||
|
// Check through all of the higher priority nodes
|
||||||
|
for (LocalizedNode h : higherPriority) {
|
||||||
|
|
||||||
|
// Check to see if the entry being considered was already processed at a higher priority
|
||||||
|
if (mergeTemp ? entry.getNode().equalsIgnoringValueOrTemp(h.getNode()) : entry.getNode().almostEquals(h.getNode())) {
|
||||||
|
it.remove();
|
||||||
|
continue iterate;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
permissions.add(node);
|
// This entry will be kept.
|
||||||
|
higherPriority.add(entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ImmutableSortedSet.copyOfSorted(permissions);
|
return ImmutableSortedSet.copyOfSorted(combined);
|
||||||
};
|
};
|
||||||
|
|
||||||
return mergeTemp ? mergedCache.get(supplier) : cache.get(supplier);
|
return mergeTemp ? mergedCache.get(supplier) : cache.get(supplier);
|
||||||
@ -316,16 +170,20 @@ public abstract class PermissionHolder {
|
|||||||
*/
|
*/
|
||||||
public boolean auditTemporaryPermissions() {
|
public boolean auditTemporaryPermissions() {
|
||||||
boolean work = false;
|
boolean work = false;
|
||||||
final PermissionHolder instance = this;
|
|
||||||
|
|
||||||
synchronized (nodes) {
|
synchronized (nodes) {
|
||||||
boolean w = nodes.removeIf(node -> {
|
boolean w = false;
|
||||||
if (node.hasExpired()) {
|
|
||||||
plugin.getApiProvider().fireEventAsync(new PermissionNodeExpireEvent(new PermissionHolderLink(instance), node));
|
Iterator<Node> it = nodes.iterator();
|
||||||
return true;
|
while (it.hasNext()) {
|
||||||
|
Node entry = it.next();
|
||||||
|
if (entry.hasExpired()) {
|
||||||
|
plugin.getApiProvider().fireEventAsync(new PermissionNodeExpireEvent(new PermissionHolderLink(this), entry));
|
||||||
|
w = true;
|
||||||
|
it.remove();
|
||||||
}
|
}
|
||||||
return false;
|
}
|
||||||
});
|
|
||||||
if (w) {
|
if (w) {
|
||||||
invalidateCache(true);
|
invalidateCache(true);
|
||||||
work = true;
|
work = true;
|
||||||
@ -333,13 +191,18 @@ public abstract class PermissionHolder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
synchronized (transientNodes) {
|
synchronized (transientNodes) {
|
||||||
boolean w = transientNodes.removeIf(node -> {
|
boolean w = false;
|
||||||
if (node.hasExpired()) {
|
|
||||||
plugin.getApiProvider().fireEventAsync(new PermissionNodeExpireEvent(new PermissionHolderLink(instance), node));
|
Iterator<Node> it = transientNodes.iterator();
|
||||||
return true;
|
while (it.hasNext()) {
|
||||||
|
Node entry = it.next();
|
||||||
|
if (entry.hasExpired()) {
|
||||||
|
plugin.getApiProvider().fireEventAsync(new PermissionNodeExpireEvent(new PermissionHolderLink(this), entry));
|
||||||
|
w = true;
|
||||||
|
it.remove();
|
||||||
}
|
}
|
||||||
return false;
|
}
|
||||||
});
|
|
||||||
if (w) {
|
if (w) {
|
||||||
invalidateCache(false);
|
invalidateCache(false);
|
||||||
work = true;
|
work = true;
|
||||||
@ -366,6 +229,7 @@ public abstract class PermissionHolder {
|
|||||||
|
|
||||||
Set<Node> parents = getPermissions(true).stream()
|
Set<Node> parents = getPermissions(true).stream()
|
||||||
.map(LocalizedNode::getNode)
|
.map(LocalizedNode::getNode)
|
||||||
|
.filter(Node::getValue)
|
||||||
.filter(Node::isGroupNode)
|
.filter(Node::isGroupNode)
|
||||||
.collect(Collectors.toSet());
|
.collect(Collectors.toSet());
|
||||||
|
|
||||||
@ -387,7 +251,7 @@ public abstract class PermissionHolder {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (excludedGroups.contains(group.getObjectName())) {
|
if (excludedGroups.contains(group.getObjectName().toLowerCase())) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -463,16 +327,62 @@ public abstract class PermissionHolder {
|
|||||||
perms.put(lowerCase ? node.getPermission().toLowerCase() : node.getPermission(), node.getValue());
|
perms.put(lowerCase ? node.getPermission().toLowerCase() : node.getPermission(), node.getValue());
|
||||||
|
|
||||||
if (plugin.getConfiguration().isApplyingShorthand()) {
|
if (plugin.getConfiguration().isApplyingShorthand()) {
|
||||||
node.resolveShorthand().stream()
|
List<String> sh = node.resolveShorthand();
|
||||||
.map(s -> lowerCase ? s.toLowerCase() : s)
|
if (!sh.isEmpty()) {
|
||||||
.filter(s -> !perms.containsKey(s))
|
sh.stream().map(s -> lowerCase ? s.toLowerCase() : s)
|
||||||
.forEach(s -> perms.put(s, node.getValue()));
|
.filter(s -> !perms.containsKey(s))
|
||||||
|
.forEach(s -> perms.put(s, node.getValue()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return ImmutableMap.copyOf(perms);
|
return ImmutableMap.copyOf(perms);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setNodes(Set<Node> set) {
|
||||||
|
synchronized (nodes) {
|
||||||
|
if (nodes.equals(set)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
nodes.clear();
|
||||||
|
nodes.addAll(set);
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setTransientNodes(Set<Node> set) {
|
||||||
|
synchronized (transientNodes) {
|
||||||
|
if (transientNodes.equals(set)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
transientNodes.clear();
|
||||||
|
transientNodes.addAll(set);
|
||||||
|
invalidateCache(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
|
public void setNodes(Map<String, Boolean> nodes) {
|
||||||
|
synchronized (this.nodes) {
|
||||||
|
this.nodes.clear();
|
||||||
|
this.nodes.addAll(nodes.entrySet().stream()
|
||||||
|
.map(e -> makeNode(e.getKey(), e.getValue()))
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
);
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addNodeUnchecked(Node node) {
|
||||||
|
synchronized (nodes) {
|
||||||
|
if (nodes.add(node)) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Check if the holder has a permission node
|
* Check if the holder has a permission node
|
||||||
* @param node the node to check
|
* @param node the node to check
|
||||||
@ -785,6 +695,128 @@ public abstract class PermissionHolder {
|
|||||||
unsetPermission("group." + group.getName(), server, world, temporary);
|
unsetPermission("group." + group.getName(), server, world, temporary);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear all of the holders permission nodes
|
||||||
|
*/
|
||||||
|
public void clearNodes() {
|
||||||
|
synchronized (nodes) {
|
||||||
|
nodes.clear();
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearNodes(String server) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n -> n.getServer().orElse("global").equalsIgnoreCase(finalServer));
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearNodes(String server, String world) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
String finalWorld = Optional.ofNullable(world).orElse("null");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n ->
|
||||||
|
n.getServer().orElse("global").equalsIgnoreCase(finalServer) &&
|
||||||
|
n.getWorld().orElse("null").equalsIgnoreCase(finalWorld));
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMeta() {
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n -> n.isMeta() || n.isPrefix() || n.isSuffix());
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMeta(String server) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n ->
|
||||||
|
(n.isMeta() || n.isPrefix() || n.isSuffix()) &&
|
||||||
|
n.getServer().orElse("global").equalsIgnoreCase(finalServer)
|
||||||
|
);
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMeta(String server, String world) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
String finalWorld = Optional.ofNullable(world).orElse("null");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n ->
|
||||||
|
(n.isMeta() || n.isPrefix() || n.isSuffix()) && (
|
||||||
|
n.getServer().orElse("global").equalsIgnoreCase(finalServer) &&
|
||||||
|
n.getWorld().orElse("null").equalsIgnoreCase(finalWorld)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMetaKeys(String key, boolean temp) {
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n -> n.isMeta() && (n.isTemporary() == temp) && n.getMeta().getKey().equalsIgnoreCase(key));
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMetaKeys(String key, String server, boolean temp) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n ->
|
||||||
|
n.isMeta() && (n.isTemporary() == temp) &&
|
||||||
|
n.getMeta().getKey().equalsIgnoreCase(key) &&
|
||||||
|
n.getServer().orElse("global").equalsIgnoreCase(finalServer)
|
||||||
|
);
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearMetaKeys(String key, String server, String world, boolean temp) {
|
||||||
|
String finalServer = Optional.ofNullable(server).orElse("global");
|
||||||
|
String finalWorld = Optional.ofNullable(world).orElse("null");
|
||||||
|
|
||||||
|
synchronized (nodes) {
|
||||||
|
boolean b = nodes.removeIf(n ->
|
||||||
|
n.isMeta() && (n.isTemporary() == temp) && n.getMeta().getKey().equalsIgnoreCase(key) &&
|
||||||
|
n.getServer().orElse("global").equalsIgnoreCase(finalServer) &&
|
||||||
|
n.getWorld().orElse("null").equalsIgnoreCase(finalWorld)
|
||||||
|
);
|
||||||
|
if (b) {
|
||||||
|
invalidateCache(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clearTransientNodes() {
|
||||||
|
synchronized (transientNodes) {
|
||||||
|
transientNodes.clear();
|
||||||
|
invalidateCache(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return The temporary nodes held by the holder
|
* @return The temporary nodes held by the holder
|
||||||
*/
|
*/
|
||||||
@ -849,4 +881,12 @@ public abstract class PermissionHolder {
|
|||||||
private static Node.Builder buildNode(String permission) {
|
private static Node.Builder buildNode(String permission) {
|
||||||
return new me.lucko.luckperms.common.core.Node.Builder(permission);
|
return new me.lucko.luckperms.common.core.Node.Builder(permission);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static me.lucko.luckperms.common.utils.LocalizedNode makeLocal(Node node, String location) {
|
||||||
|
return me.lucko.luckperms.common.utils.LocalizedNode.of(node, location);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Node makeNode(String s, Boolean b) {
|
||||||
|
return me.lucko.luckperms.common.core.Node.fromSerialisedNode(s, b);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
package me.lucko.luckperms.common.utils;
|
package me.lucko.luckperms.common.utils;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.function.Supplier;
|
import java.util.function.Supplier;
|
||||||
|
|
||||||
public class Cache<T> {
|
public class Cache<T> {
|
||||||
@ -36,6 +37,12 @@ public class Cache<T> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Optional<T> getIfPresent() {
|
||||||
|
synchronized (this) {
|
||||||
|
return Optional.ofNullable(t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void invalidate() {
|
public void invalidate() {
|
||||||
synchronized (this) {
|
synchronized (this) {
|
||||||
t = null;
|
t = null;
|
||||||
|
Loading…
Reference in New Issue
Block a user