Trust

HuskClaims lets you give users, groups of users, and tags a "Trust Level" in Claims. Trust Levels grant users access to Operation Type flags and Privileges, which grant users respective claim access rights and management privileges. Trust levels are fully configurable and can be customized or changed entirely by editing the trust_levels.yml config file.

Trust Levels

Trust Levels are defined in the trust_levels.yml config file and the default set of trust levels, based on the classic GriefPrevention plugin setup, are detailed below. Each trust level has an associated command (build trust, for instance). Users, groups, or tags can only be in one trust level at a time and trust levels are explicitly defined; they do not inherit granted operation types or privileges from lower levels.

Trust Level Command Description Allowed Operations Allowed Privileges
Manage /permissiontrust Grants full claim management access, letting players trust/untrust other users, toggle operation groups, and create child claims (and all the below).
View list
  • block_interact
  • entity_interact
  • redstone_interact
  • break_vehicle
  • place_vehicle
  • ender_pearl_teleport
  • start_raid
  • container_open
  • block_break
  • block_place
  • farm_block_break
  • farm_block_place
  • farm_block_interact
  • place_hanging_entity
  • break_hanging_entity
  • player_damage_player
  • player_damage_persistent_entity
  • player_damage_monster
  • player_damage_entity
  • fill_bucket
  • empty_bucket
  • use_spawn_egg
View list
  • MANAGE_TRUSTEES
  • MANAGE_CHILD_CLAIMS
  • MANAGE_OPERATION_GROUPS
  • MANAGE_BANS
  • MAKE_PRIVATE
Build /trust Grants access to let users break and place all blocks within the claim (and all the below).
View list
  • block_interact
  • entity_interact
  • redstone_interact
  • break_vehicle
  • place_vehicle
  • ender_pearl_teleport
  • start_raid
  • container_open
  • block_break
  • block_place
  • farm_block_break
  • farm_block_place
  • farm_block_interact
  • place_hanging_entity
  • break_hanging_entity
  • player_damage_player
  • player_damage_persistent_entity
  • player_damage_monster
  • player_damage_entity
  • fill_bucket
  • empty_bucket
  • use_spawn_egg
(None)
Container /containertrust Grants access to let users open containers—such as chests, hoppers, furnaces, etc—and edit the items in them (and all the below).
View list
  • block_interact
  • entity_interact
  • redstone_interact
  • break_vehicle
  • place_vehicle
  • ender_pearl_teleport
  • start_raid
  • container_open
(None)
Access /accesstrust Grants access to let users press buttons, levers, and pressure plates; and open doors, trapdoors, and fence gates.
View list
  • block_interact
  • entity_interact
  • redstone_interact
  • break_vehicle
  • place_vehicle
  • ender_pearl_teleport
  • start_raid
(None)

The owner of a claim, or other users who are trusted at a level with the MANAGE_TRUSTEES privilege can manage the trust of users with a lower trust levels than them through these command. To trust a user, stand in the claim and use the relevant trust command followed by the user/@group/#tag; to revoke trust, do the same but with /untrust. You can trust/untrust multiple parties at once by simply adding more users/@groups/#tags to the end of the command. Finally, to view a list of trusted users, use /trustlist.

Trusting users, groups and tags in a claim

Configuring Trust Levels

Warning:
Removing or changing the IDs of existing trust levels in your config file is a destructive action! Players will lose their trust levels and will need to be re-trusted by claim owners.

Trust levels may be configured in the trust_levels.yml config file. Trust levels are ordered by their weight value; users with access to the MANAGE_TRUSTEES privilege cannot change the trust level of a user/group/tag if their rank is or would be a higher weight than their current trust level.

The default trust levels are defined below:

Trust levels config (trust_levels.yml)
# ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓
# ┃   HuskClaims - Trust Levels  ┃
# ┃    Developed by William278   ┃
# ┣━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛
# ┣╸ List of trust levels users & groups can be assigned to in claims
# ┣╸ Config Help: https://william278.net/docs/huskclaims/trust/
# ┗╸ Documentation: https://william278.net/docs/huskclaims/

trust_levels:
  - id: manage
    display_name: Manage
    description: Allows users to manage trustees & make child claims
    color: '#fc4e03'
    command_aliases:
      - permissiontrust
      - managetrust
    flags:
      - block_interact
      - entity_interact
      - redstone_interact
      - place_vehicle
      - break_vehicle
      - ender_pearl_teleport
      - start_raid
      - container_open
      - block_break
      - block_place
      - farm_block_break
      - farm_block_place
      - farm_block_interact
      - place_hanging_entity
      - break_hanging_entity
      - player_damage_player
      - player_damage_persistent_entity
      - player_damage_monster
      - player_damage_entity
      - fill_bucket
      - empty_bucket
      - use_spawn_egg
    privileges:
      - MANAGE_TRUSTEES
      - MANAGE_CHILD_CLAIMS
      - MANAGE_OPERATION_GROUPS
      - MANAGE_BANS
      - MAKE_PRIVATE
    weight: 400
  - id: build
    display_name: Build
    description: Allows users to build in the claim
    color: '#fcd303'
    command_aliases:
      - trust
      - buildtrust
    flags:
      - block_interact
      - entity_interact
      - redstone_interact
      - place_vehicle
      - break_vehicle
      - ender_pearl_teleport
      - start_raid
      - container_open
      - block_break
      - block_place
      - farm_block_break
      - farm_block_place
      - farm_block_interact
      - place_hanging_entity
      - break_hanging_entity
      - player_damage_player
      - player_damage_persistent_entity
      - player_damage_monster
      - player_damage_entity
      - fill_bucket
      - empty_bucket
      - use_spawn_egg
    privileges: []
    weight: 300
  - id: container
    display_name: Container
    description: Allows users to open chests & other containers
    color: '#5efc03'
    command_aliases:
      - containertrust
    flags:
      - block_interact
      - entity_interact
      - redstone_interact
      - place_vehicle
      - break_vehicle
      - ender_pearl_teleport
      - start_raid
      - container_open
    privileges: []
    weight: 200
  - id: access
    display_name: Access
    description: Allows users to use doors, buttons, levers, etc.
    color: '#36e4ff'
    command_aliases:
      - accesstrust
    flags:
      - block_interact
      - entity_interact
      - redstone_interact
      - place_vehicle
      - break_vehicle
      - ender_pearl_teleport
      - start_raid
    privileges: []
    weight: 100
# The operation types that the claim owner can perform in their own claim
allowed_owner_operations:
  - start_raid
  - player_damage_monster
  - break_hanging_entity
  - farm_block_place
  - player_damage_persistent_entity
  - empty_bucket
  - block_place
  - ender_pearl_teleport
  - block_interact
  - redstone_interact
  - use_spawn_egg
  - fill_bucket
  - player_damage_player
  - player_damage_entity
  - place_hanging_entity
  - entity_interact
  - farm_block_interact
  - container_open
  - break_vehicle
  - block_break
  - place_vehicle
  - farm_block_break

Users, Groups & Tags

Users, user groups, and tags can be trusted at a trust level.

Users

To trust a user in a claim, stand in the claim and type the trust level command followed by their username.

User Groups

User groups are a way of managing the trust of multiple groups of users at once, handy for large projects. User groups belong to the claim owner; note you cannot trust groups in admin claims for this reason. Below is an example of a claim owner managing a user group on their claim:

CommandResult
/usergroup awesome_people add Steve AlexCreates a user group named awesome_people and adds the players Steve and Alex.
/trust @awesome_peopleTrusts the group awesome_people in the claim you are in (effectively giving Steve and Alex access)
/usergroup awesome_people add William278Adds William278 to the group awesome_people, giving William278 access to the claim too.
/usergroup awesome_people add SteveRemoves Steve from the group awesome_people, effectively revoking their access to the claim.
/usergroup awesome_people deleteDeletes the group awesome_people. Alex and William278 will lose access to the claim.

Note that deleting a user group won't remove it from the claim; it will remain trusted but greyed out. If the claim owner re-creates the group with new members, the group will be re-enabled.

Trust Tags

Trust tags are an abstract way of representing a set of users, and can be provided by other plugins through the API or through special built-in hooks. Below are the list of built-in tags.

TagDescription
#publicGrant public access to a claim.
#role/(name)Grant access to a LuckPerms permission group in a claim. Requires LuckPerms installed and the hook enabled.

Please note that the use of trust tags can be restricted by Permissions; by default, users cannot trust LuckPerms roles.

Trustable calculation order

The effective trust level of a user is calculated in the order described below if a user belongs to multiple trustable parties, they will receive the most explicit trust level defined for them:

  1. User — If the user has an explicit permission in a claim, they are trusted at that level.
  2. User Group — If the user is the member of one of the claim owner's groups, they are trusted at that level.
  3. Trust Tag — If the user meets the criteria of a trust tag, they are trusted at that level.

Example: The owner of a claim has trusted the tag #public at the "Manage" trust level, granting everyone management access. The owner has also explicitly trusted the user Steve at the "Build" trust level. Since "Steve" is trusted as a User (a higher priority trustable type than a Trust Tag), their effective trust level is "Build Trust," not "Manage Trust."

Owner allowed permissions

The owner has access to all permissions in their claim, regardless of their trust level. You can remove certain permissions from the owner by editing the allowed_owner_operations section in the trust_levels.yml file. This could be useful for removing the ability for the owner to pvp in their claim, for example.