Enum Class TemporaryNodeMergeStrategy

java.lang.Object
java.lang.Enum<TemporaryNodeMergeStrategy>
net.luckperms.api.model.data.TemporaryNodeMergeStrategy
All Implemented Interfaces:
Serializable, Comparable<TemporaryNodeMergeStrategy>, java.lang.constant.Constable

public enum TemporaryNodeMergeStrategy extends Enum<TemporaryNodeMergeStrategy>
Controls how the implementation should behave when new temporary nodes are set that would otherwise conflict with existing entries.

The default behaviour of NodeMap.add(Node) is to return a result of DataMutateResult.FAIL_ALREADY_HAS when an equivalent node is found. This can be replicated using NONE.

However, the NodeMap.add(Node, TemporaryNodeMergeStrategy) method allows this behaviour to be customized for temporary permissions.

  • Enum Constant Details

    • ADD_NEW_DURATION_TO_EXISTING

      public static final TemporaryNodeMergeStrategy ADD_NEW_DURATION_TO_EXISTING
      Expiry durations will be added to the existing expiry time of a permission.
    • REPLACE_EXISTING_IF_DURATION_LONGER

      public static final TemporaryNodeMergeStrategy REPLACE_EXISTING_IF_DURATION_LONGER
      Expiry durations will be replaced if the new duration is longer than the current one.
    • NONE

      public static final TemporaryNodeMergeStrategy NONE
      The operation will fail if an existing temporary node is present.
  • Method Details

    • values

      public static TemporaryNodeMergeStrategy[] values()
      Returns an array containing the constants of this enum class, in the order they are declared.
      Returns:
      an array containing the constants of this enum class, in the order they are declared
    • valueOf

      public static TemporaryNodeMergeStrategy valueOf(String name)
      Returns the enum constant of this class with the specified name. The string must match exactly an identifier used to declare an enum constant in this class. (Extraneous whitespace characters are not permitted.)
      Parameters:
      name - the name of the enum constant to be returned.
      Returns:
      the enum constant with the specified name
      Throws:
      IllegalArgumentException - if this enum class has no constant with the specified name
      NullPointerException - if the argument is null