mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-19 14:51:27 +01:00
Fix cmd permission levels for command blocks (#7404)
This commit is contained in:
parent
9940519717
commit
9bfe2bcce9
@ -0,0 +1,90 @@
|
|||||||
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
||||||
|
Date: Mon, 24 Jan 2022 15:32:02 -0800
|
||||||
|
Subject: [PATCH] Fix cmd permission levels for command blocks
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/commands/CommandSourceStack.java b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
||||||
|
+++ b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CommandSourceStack implements ExecutionCommandSource<CommandSourceS
|
||||||
|
return this.permissionLevel >= level;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ // Paper start
|
||||||
|
+ private boolean forceRespectPermissionLevel() {
|
||||||
|
+ return this.source == CommandSource.NULL || (this.source instanceof final net.minecraft.world.level.BaseCommandBlock commandBlock && commandBlock.getLevel().paperConfig().commandBlocks.forceFollowPermLevel);
|
||||||
|
+ }
|
||||||
|
+ // Paper end
|
||||||
|
+
|
||||||
|
// CraftBukkit start
|
||||||
|
public boolean hasPermission(int i, String bukkitPermission) {
|
||||||
|
- // World is null when loading functions
|
||||||
|
- return ((this.getLevel() == null || !this.getLevel().getCraftServer().ignoreVanillaPermissions) && this.permissionLevel >= i) || this.getBukkitSender().hasPermission(bukkitPermission);
|
||||||
|
+ // Paper start
|
||||||
|
+ final java.util.function.BooleanSupplier hasBukkitPerm = () -> this.source == CommandSource.NULL /*treat NULL as having all bukkit perms*/ || this.getBukkitSender().hasPermission(bukkitPermission); // lazily check bukkit perms to the benefit of custom permission setups
|
||||||
|
+ // if the server is null, we must check the vanilla perm level system
|
||||||
|
+ // if ignoreVanillaPermissions is true, we can skip vanilla perms and just run the bukkit perm check
|
||||||
|
+ //noinspection ConstantValue
|
||||||
|
+ if (this.getServer() == null || !this.getServer().server.ignoreVanillaPermissions) { // server & level are null for command function loading
|
||||||
|
+ final boolean hasPermLevel = this.permissionLevel >= i;
|
||||||
|
+ if (this.forceRespectPermissionLevel()) { // NULL CommandSource and command blocks (if setting is enabled) should always pass the vanilla perm check
|
||||||
|
+ return hasPermLevel && hasBukkitPerm.getAsBoolean();
|
||||||
|
+ } else { // otherwise check vanilla perm first then bukkit perm, matching upstream behavior
|
||||||
|
+ return hasPermLevel || hasBukkitPerm.getAsBoolean();
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ return hasBukkitPerm.getAsBoolean();
|
||||||
|
+ // Paper end
|
||||||
|
}
|
||||||
|
// CraftBukkit end
|
||||||
|
|
||||||
|
diff --git a/src/main/java/net/minecraft/commands/Commands.java b/src/main/java/net/minecraft/commands/Commands.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/commands/Commands.java
|
||||||
|
+++ b/src/main/java/net/minecraft/commands/Commands.java
|
||||||
|
@@ -0,0 +0,0 @@ public class Commands {
|
||||||
|
String[] args = command.split(" ");
|
||||||
|
if (args.length == 0) return; // Paper - empty commands shall not be dispatched
|
||||||
|
|
||||||
|
- String cmd = args[0];
|
||||||
|
- if (cmd.startsWith("minecraft:")) cmd = cmd.substring("minecraft:".length());
|
||||||
|
- if (cmd.startsWith("bukkit:")) cmd = cmd.substring("bukkit:".length());
|
||||||
|
-
|
||||||
|
- // Block disallowed commands
|
||||||
|
- if (cmd.equalsIgnoreCase("stop") || cmd.equalsIgnoreCase("kick") || cmd.equalsIgnoreCase("op")
|
||||||
|
- || cmd.equalsIgnoreCase("deop") || cmd.equalsIgnoreCase("ban") || cmd.equalsIgnoreCase("ban-ip")
|
||||||
|
- || cmd.equalsIgnoreCase("pardon") || cmd.equalsIgnoreCase("pardon-ip") || cmd.equalsIgnoreCase("reload")) {
|
||||||
|
- return;
|
||||||
|
- }
|
||||||
|
+ // Paper - use proper permission levels to block these commands
|
||||||
|
|
||||||
|
// Handle vanilla commands;
|
||||||
|
if (sender.getLevel().getCraftServer().getCommandBlockOverride(args[0])) {
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/entity/vehicle/MinecartCommandBlock.java b/src/main/java/net/minecraft/world/entity/vehicle/MinecartCommandBlock.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/entity/vehicle/MinecartCommandBlock.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/entity/vehicle/MinecartCommandBlock.java
|
||||||
|
@@ -0,0 +0,0 @@ public class MinecartCommandBlock extends AbstractMinecart {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public CommandSourceStack createCommandSourceStack() {
|
||||||
|
- return new CommandSourceStack(this, MinecartCommandBlock.this.position(), MinecartCommandBlock.this.getRotationVector(), this.getLevel(), 2, this.getName().getString(), MinecartCommandBlock.this.getDisplayName(), this.getLevel().getServer(), MinecartCommandBlock.this);
|
||||||
|
+ return new CommandSourceStack(this, MinecartCommandBlock.this.position(), MinecartCommandBlock.this.getRotationVector(), this.getLevel(), this.getLevel().paperConfig().commandBlocks.permissionsLevel, this.getName().getString(), MinecartCommandBlock.this.getDisplayName(), this.getLevel().getServer(), MinecartCommandBlock.this); // Paper - configurable command block perm level
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
diff --git a/src/main/java/net/minecraft/world/level/block/entity/CommandBlockEntity.java b/src/main/java/net/minecraft/world/level/block/entity/CommandBlockEntity.java
|
||||||
|
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
||||||
|
--- a/src/main/java/net/minecraft/world/level/block/entity/CommandBlockEntity.java
|
||||||
|
+++ b/src/main/java/net/minecraft/world/level/block/entity/CommandBlockEntity.java
|
||||||
|
@@ -0,0 +0,0 @@ public class CommandBlockEntity extends BlockEntity {
|
||||||
|
public CommandSourceStack createCommandSourceStack() {
|
||||||
|
Direction enumdirection = (Direction) CommandBlockEntity.this.getBlockState().getValue(CommandBlock.FACING);
|
||||||
|
|
||||||
|
- return new CommandSourceStack(this, Vec3.atCenterOf(CommandBlockEntity.this.worldPosition), new Vec2(0.0F, enumdirection.toYRot()), this.getLevel(), 2, this.getName().getString(), this.getName(), this.getLevel().getServer(), (Entity) null);
|
||||||
|
+ return new CommandSourceStack(this, Vec3.atCenterOf(CommandBlockEntity.this.worldPosition), new Vec2(0.0F, enumdirection.toYRot()), this.getLevel(), this.getLevel().paperConfig().commandBlocks.permissionsLevel, this.getName().getString(), this.getName(), this.getLevel().getServer(), (Entity) null); // Paper - configurable command block perm level
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
@ -1,27 +0,0 @@
|
|||||||
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
||||||
From: Jake Potrebic <jake.m.potrebic@gmail.com>
|
|
||||||
Date: Tue, 27 Jun 2023 16:32:39 -0700
|
|
||||||
Subject: [PATCH] Improve command function perm level checks
|
|
||||||
|
|
||||||
|
|
||||||
diff --git a/src/main/java/net/minecraft/commands/CommandSourceStack.java b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
|
||||||
index 0000000000000000000000000000000000000000..0000000000000000000000000000000000000000 100644
|
|
||||||
--- a/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
|
||||||
+++ b/src/main/java/net/minecraft/commands/CommandSourceStack.java
|
|
||||||
@@ -0,0 +0,0 @@ public class CommandSourceStack implements ExecutionCommandSource<CommandSourceS
|
|
||||||
|
|
||||||
// CraftBukkit start
|
|
||||||
public boolean hasPermission(int i, String bukkitPermission) {
|
|
||||||
- // World is null when loading functions
|
|
||||||
- return ((this.getLevel() == null || !this.getLevel().getCraftServer().ignoreVanillaPermissions) && this.permissionLevel >= i) || this.getBukkitSender().hasPermission(bukkitPermission);
|
|
||||||
+ // Paper start
|
|
||||||
+ boolean hasPermissionLevel = this.permissionLevel >= i;
|
|
||||||
+ if (this.source == CommandSource.NULL) {
|
|
||||||
+ return hasPermissionLevel;
|
|
||||||
+ } else {
|
|
||||||
+ return (!this.getLevel().getCraftServer().ignoreVanillaPermissions && hasPermissionLevel) || this.getBukkitSender().hasPermission(bukkitPermission);
|
|
||||||
+ }
|
|
||||||
+ // Paper end
|
|
||||||
}
|
|
||||||
// CraftBukkit end
|
|
||||||
|
|
@ -1917,6 +1917,13 @@ index 0000000000000000000000000000000000000000..00000000000000000000000000000000
|
|||||||
+ }
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+
|
+
|
||||||
|
+ public CommandBlocks commandBlocks;
|
||||||
|
+
|
||||||
|
+ public class CommandBlocks extends ConfigurationPart {
|
||||||
|
+ public int permissionsLevel = 2;
|
||||||
|
+ public boolean forceFollowPermLevel = true;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
+ public Misc misc;
|
+ public Misc misc;
|
||||||
+
|
+
|
||||||
+ public class Misc extends ConfigurationPart {
|
+ public class Misc extends ConfigurationPart {
|
||||||
|
Loading…
Reference in New Issue
Block a user