diff --git a/common/src/main/java/me/lucko/luckperms/common/managers/user/AbstractUserManager.java b/common/src/main/java/me/lucko/luckperms/common/managers/user/AbstractUserManager.java index 75ef8ff4..566afd81 100644 --- a/common/src/main/java/me/lucko/luckperms/common/managers/user/AbstractUserManager.java +++ b/common/src/main/java/me/lucko/luckperms/common/managers/user/AbstractUserManager.java @@ -124,7 +124,7 @@ public abstract class AbstractUserManager extends AbstractManage if (!hasGroup) { user.getPrimaryGroup().setStoredValue(NodeFactory.DEFAULT_GROUP_NAME); - user.setPermission(NodeFactory.buildGroupNode(NodeFactory.DEFAULT_GROUP_NAME).build()); + user.setPermission(NodeFactory.buildGroupNode(NodeFactory.DEFAULT_GROUP_NAME).build(), false); work = true; } diff --git a/common/src/main/java/me/lucko/luckperms/common/model/PermissionHolder.java b/common/src/main/java/me/lucko/luckperms/common/model/PermissionHolder.java index 84ef2490..c2577524 100644 --- a/common/src/main/java/me/lucko/luckperms/common/model/PermissionHolder.java +++ b/common/src/main/java/me/lucko/luckperms/common/model/PermissionHolder.java @@ -536,6 +536,10 @@ public abstract class PermissionHolder { * @param node the node to set */ public DataMutateResult setPermission(Node node) { + return setPermission(node, true); + } + + public DataMutateResult setPermission(Node node, boolean callEvent) { if (hasPermission(NodeMapType.ENDURING, node, StandardNodeEquality.IGNORE_EXPIRY_TIME_AND_VALUE) != Tristate.UNDEFINED) { return DataMutateResult.ALREADY_HAS; } @@ -545,7 +549,9 @@ public abstract class PermissionHolder { invalidateCache(); ImmutableCollection after = enduringData().immutable().values(); - this.plugin.getEventFactory().handleNodeAdd(node, this, before, after); + if (callEvent) { + this.plugin.getEventFactory().handleNodeAdd(node, this, before, after); + } return DataMutateResult.SUCCESS; }