Моды/Vanilla Permissions
Vanilla Permissions

Vanilla Permissions

Adds permission checks into vanilla, to allow for full permission customization

48.3K
115

Vanilla Permissions

This mod adds permission checks into vanilla, to allow for full permission customization.

Permissions

PermissionDescription
minecraft.adminbroadcast.receiveReceive command feedback
minecraft.bypass.spawn-protectionBuild inside spawn protection
minecraft.bypass.force-gamemodeBypass forced gamemode
minecraft.bypass.move-speed.playerBypass "Player moved too fast"
minecraft.bypass.move-speed.vehicle.<entity>Bypass "Player moved too fast", while riding an entity (e.g minecraft.boat)
minecraft.bypass.chat-speedBypass chat kick, when sending messages / commands to quick
minecraft.bypass.whitelistBypass server whitelist
minecraft.bypass.player-limitBypass server player limit
minecraft.command.<command>Command permissions, see commands for more information
minecraft.debug_stick.use.<block>Use debug stick on block (e.g. minecraft.oak_trapdoor)
minecraft.debug_chartView debug chart
minecraft.<query/load>.<entity/block>Place blocks with nbt data and use debug commands
minecraft.operator_block.<command_block/jigsaw/structure_block>.<place/view/edit/break>Place, view, edit and break operator blocks.
minecraft.selectorUse entity selectors in commands
minecraft.selector.entity.<selector>Allow selecting non-player entities using the selector
minecraft.selector.player.<selector>Allow selecting nonself players using the selector
minecraft.selector.self.<selector>Allow selecting self using the selector

Meta

Also sometimes referred to as "options" or "variables".

Incorrect types are considered undefined values.

MetaTypeDescription
minecraft.selector.limit.<selector>IntegerLimit the maximum number of entities that can be selected using the selector
minecraft.selector.weight.<selector>IntegerSelector weight, see selection weight for more infomation

Commands

This mod uses Brigadier's node-based permission system. Each command is made up of multiple nodes, and each node has its own permission.

For example, the /gamemode command:

  • The root command node (/gamemode) requires minecraft.command.gamemode.
  • Sub-nodes like survival, creative, etc., use minecraft.command.gamemode.survival, minecraft.command.gamemode.creative, and so on.

In vanilla Minecraft, only the root node has a permission check (e.g. OP level 2). Once a player has access to that root node, all sub-nodes are considered unlocked by default.

If you want finer control, you can manually restrict sub-nodes by denying their specific permissions.

Example

Allow:
  minecraft.command.gamemode
Deny:
  minecraft.command.gamemode.creative
  minecraft.command.gamemode.spectator

This allows players to use /gamemode but restricts them to only the allowed sub-options (e.g., survival and adventure).

For other commands, see Syntax section of each command's Minecraft Wiki page.

Selectors

Command blocks and datapacks bypass all selector permission checks.

By default, granting minecraft.selector allows players to use any selector in commands they have access to.

Fine-grained permission control operates as follows. Note that this mod restricts based on selection results, not raw selector syntax. Using player names, UUIDs, or selectors like @e are equivalent if they produce identical results.

Value of <selector>

The <selector> string follows the format: <command_name>.<selector_name>.<subsequent_arguments> where:

  • <command_name> is the root command name
  • <selector_name> matches the argument name in the command's Arguments section on Minecraft Wiki
  • <subsequent_arguments> traces the command's argument hierarchy after the selector

For example, in the /teleport command:

  • <targets> and <destination> are valid selector names (they are entity selectors)
  • Subsequent arguments form the remainder of the path

Most selectors are entity selectors, which is supported. For a complete support list, see below.

Example

CommandSyntax (See Minecraft Wiki)Selector to Control<selector> Construction
/teleport @e @steleport <targets> <destination>@eteleport.targets.targets.destination
/teleport @e @steleport <targets> <destination>@steleport.destination.targets.destination
/teleport @e ~ ~ ~teleport <targets> <location>@eteleport.targets.targets.location

Wildcard Support

Selector permissions can be lengthy. Luckily you can use wildcards, like teleport.* to cover all teleport command selectors.

However, Luckperms doesn't support wildcard for metadata. You could install this mod to enable it.

Scope Control

Use these permissions to define selector scope:

  • minecraft.selector.entity.<selector>
  • minecraft.selector.player.<selector>
  • minecraft.selector.self.<selector>

Commands fail if a player attempts to select unauthorized entities. All three scopes (that is, minecraft.selector.*) are allowed by default.

Simple Example

Allow:
  minecraft.command.waypoint
  minecraft.selector
Deny:
  minecraft.selector.player.waypoint.*
  minecraft.selector.entity.waypoint.*

Players modify only their own waypoints.

Complex Example

Allow:
  minecraft.command.teleport # /teleport
  minecraft.selector # All selectors
  minecraft.selector.player.teleport.destination.destination #1
  minecraft.selector.entity.teleport.destination.destination #2
  minecraft.selector.entity.teleport.targets.targets.destination #3
  minecraft.selector.player.teleport.facingEntity.* #4
Deny:
  minecraft.selector.player.teleport.* #6
  minecraft.selector.entity.* #5
  minecraft.selector.self.teleport.facingEntity.* #7

Command Behavior:

CommandSelfNonself PlayersNon-player EntitiesResulting Behavior
/teleport <destination><destination> allowed by default<destination> allowed by #𝟏<destination> allowed by #𝟐Teleport to any entity
/teleport <targets> <destination><targets> allowed by default
<destination> allowed by default
<targets> denied by #𝟓
<destination> denied by #𝟓
<targets> allowed by #𝟑
<destination> denied by #𝟔
Only teleport non-player entities to self
/teleport <location>(No selectors)--Unrestricted position teleport
/teleport <targets> <location><targets> allowed by default<targets> denied by #𝟓<targets> denied by #𝟔Only teleport self to positions
/teleport <targets> <location> facing entity <facingEntity><targets> allowed by default
<facingEntity> denied by #𝟕
<targets> denied by #𝟓
<facingEntity> allowed by #𝟒
<targets> denied by #𝟔
<facingEntity> denied by #𝟔
Teleport self to positions while facing nonself players

Entity Limit

Set meta minecraft.selector.limit.<selector> to restrict the maximum number of entities selectable via a given selector.

No limit is applied if this meta is unset.

Selection Weight

Controlled by meta minecraft.selector.weight.<selector>.

Entities without weight settings can always select any target and be selected by any selector. When both entities have weight values, a selector can only select targets whose weight is less than or equal to its own.

Example

You need to install this mod first.

# Global permissions
Allow:
  minecraft.command.gamemode
  minecraft.selector
# Player-specific metadata
Player1: minecraft.selector.weight.gamemode.* = 7
Player2: minecraft.selector.weight.gamemode.* = -1
Player3: minecraft.selector.weight.gamemode.* = 7
Player4: (no weight set)
PlayerCan modify gamemode ofReason
Player1All playersWeight ($7$) ≥ all others' weights
Player2Only Player2 and Player4Weight ($-1$) < Player1/Player3 ($7$)
No weight restriction for Player4
Player3All playersWeight ($7$) ≥ all others' weights
Player4All playersNo weight restriction → unrestricted access

Status

The following list shows which selectors can use fine-grained permissions:

Quality of Life

Server Side

If the mod is installed server-side, it will make clients think they're OP. This allows players with appropriate permissions to place operator blocks and access the gamemode switcher menu.

Execute Command

  • Includes another condition: /execute if permission <entity> <permission> to allow datapacks to check permissions (e.g. /execute if permission @s group.admin run say I am an admin)
  • Modifiers

    • The feedback modifier /execute feedback [silent | console] or /execute feedback entity <entity> is used to silence, or redirect command feedback (e.g. /execute feedback silent run gamemode creative)
    • The oplevel modifier /execute oplevel <level> or /execute oplevel <targets> can be used to reduce the op permission level of the command source context, this can be useful if you want to run a command as a user (from functions or console), but want bypass permissions to work (e.g. /execute as DrexHD oplevel entity @s run rtp, this will use the op level of the player DrexHD instead of the actual command executor for checking permissions like rtp.bypass)

Client Side

If the mod is installed on the client, the gamemode switcher can also be accessed, if the player has access to the command, but isn't OP (useful for spigot-based servers)!

Совместимость

Minecraft: Java Edition

1.20–1.21.101.18–1.19.41.16–1.17.11.14–1.15.2

Платформы

Поддерживаемые окружения

Сервер

Создатели

Детали

Лицензия:MIT
Опубликован:3 года назад
Обновлён:1 месяц назад
Главная