You've already forked Arcturus-Morningstar-Extended
mirror of
https://github.com/duckietm/Arcturus-Morningstar-Extended.git
synced 2026-06-20 15:36:17 +00:00
Merge pull request #199 from simoleo89/fix/modtool-sanction-rank-ceilings
fix(modtool): enforce permissions and sanction rank ceilings
This commit is contained in:
@@ -410,12 +410,15 @@ public class ModToolManager {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (target == null || !canModerateTarget(moderator, target.getHabboInfo().getId())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
SupportUserAlertedEvent alertedEvent = new SupportUserAlertedEvent(moderator, target, message, reason);
|
SupportUserAlertedEvent alertedEvent = new SupportUserAlertedEvent(moderator, target, message, reason);
|
||||||
|
|
||||||
if (Emulator.getPluginManager().fireEvent(alertedEvent).isCancelled())
|
if (Emulator.getPluginManager().fireEvent(alertedEvent).isCancelled())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (target != null)
|
|
||||||
alertedEvent.target.getClient().sendResponse(new ModToolIssueHandledComposer(alertedEvent.message));
|
alertedEvent.target.getClient().sendResponse(new ModToolIssueHandledComposer(alertedEvent.message));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -490,6 +493,17 @@ public class ModToolManager {
|
|||||||
return bans;
|
return bans;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean canModerateTarget(Habbo moderator, int targetUserId) {
|
||||||
|
if (moderator == null || targetUserId <= 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
HabboInfo targetInfo = Emulator.getGameEnvironment().getHabboManager().getHabboInfo(targetUserId);
|
||||||
|
if (targetInfo == null)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
return targetInfo.getRank().getId() < moderator.getHabboInfo().getRank().getId();
|
||||||
|
}
|
||||||
|
|
||||||
public void roomAction(Room room, Habbo moderator, boolean kickUsers, boolean lockDoor, boolean changeTitle) {
|
public void roomAction(Room room, Habbo moderator, boolean kickUsers, boolean lockDoor, boolean changeTitle) {
|
||||||
SupportRoomActionEvent roomActionEvent = new SupportRoomActionEvent(moderator, room, kickUsers, lockDoor, changeTitle);
|
SupportRoomActionEvent roomActionEvent = new SupportRoomActionEvent(moderator, room, kickUsers, lockDoor, changeTitle);
|
||||||
Emulator.getPluginManager().fireEvent(roomActionEvent);
|
Emulator.getPluginManager().fireEvent(roomActionEvent);
|
||||||
|
|||||||
+4
@@ -30,6 +30,10 @@ public class ModToolIssueDefaultSanctionEvent extends MessageHandler {
|
|||||||
if (defaultSanction != null) {
|
if (defaultSanction != null) {
|
||||||
Habbo target = Emulator.getGameEnvironment().getHabboManager().getHabbo(issue.reportedId);
|
Habbo target = Emulator.getGameEnvironment().getHabboManager().getHabbo(issue.reportedId);
|
||||||
|
|
||||||
|
if (!ModToolManager.canModerateTarget(this.client.getHabbo(), issue.reportedId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (defaultSanction.banLength > 0) {
|
if (defaultSanction.banLength > 0) {
|
||||||
Emulator.getGameEnvironment().getModToolManager().ban(issue.reportedId, this.client.getHabbo(), defaultSanction.message, defaultSanction.banLength * 86400, ModToolBanType.ACCOUNT, modToolCategory.id);
|
Emulator.getGameEnvironment().getModToolManager().ban(issue.reportedId, this.client.getHabbo(), defaultSanction.message, defaultSanction.banLength * 86400, ModToolBanType.ACCOUNT, modToolCategory.id);
|
||||||
} else if (defaultSanction.muteLength > 0) {
|
} else if (defaultSanction.muteLength > 0) {
|
||||||
|
|||||||
@@ -1,6 +1,8 @@
|
|||||||
package com.eu.habbo.messages.incoming.modtool;
|
package com.eu.habbo.messages.incoming.modtool;
|
||||||
|
|
||||||
import com.eu.habbo.Emulator;
|
import com.eu.habbo.Emulator;
|
||||||
|
import com.eu.habbo.habbohotel.modtool.ScripterManager;
|
||||||
|
import com.eu.habbo.habbohotel.permissions.Permission;
|
||||||
import com.eu.habbo.messages.incoming.MessageHandler;
|
import com.eu.habbo.messages.incoming.MessageHandler;
|
||||||
|
|
||||||
public class ModToolKickEvent extends MessageHandler {
|
public class ModToolKickEvent extends MessageHandler {
|
||||||
@@ -11,6 +13,11 @@ public class ModToolKickEvent extends MessageHandler {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handle() throws Exception {
|
public void handle() throws Exception {
|
||||||
|
if (!this.client.getHabbo().hasPermission(Permission.ACC_SUPPORTTOOL)) {
|
||||||
|
ScripterManager.scripterDetected(this.client, Emulator.getTexts().getValue("scripter.warning.modtools.kick").replace("%username%", this.client.getHabbo().getHabboInfo().getUsername()));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
Emulator.getGameEnvironment().getModToolManager().kick(this.client.getHabbo(), Emulator.getGameEnvironment().getHabboManager().getHabbo(this.packet.readInt()), this.packet.readString());
|
Emulator.getGameEnvironment().getModToolManager().kick(this.client.getHabbo(), Emulator.getGameEnvironment().getHabboManager().getHabbo(this.packet.readInt()), this.packet.readString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
+4
@@ -28,6 +28,10 @@ public class ModToolSanctionAlertEvent extends MessageHandler {
|
|||||||
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
||||||
|
|
||||||
if (habbo != null) {
|
if (habbo != null) {
|
||||||
|
if (!ModToolManager.canModerateTarget(this.client.getHabbo(), userId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
||||||
|
|
||||||
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
||||||
|
|||||||
+4
@@ -30,6 +30,10 @@ public class ModToolSanctionMuteEvent extends MessageHandler {
|
|||||||
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
||||||
|
|
||||||
if (habbo != null) {
|
if (habbo != null) {
|
||||||
|
if (!ModToolManager.canModerateTarget(this.client.getHabbo(), userId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
||||||
|
|
||||||
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
||||||
|
|||||||
+4
@@ -29,6 +29,10 @@ public class ModToolSanctionTradeLockEvent extends MessageHandler {
|
|||||||
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(userId);
|
||||||
|
|
||||||
if (habbo != null) {
|
if (habbo != null) {
|
||||||
|
if (!ModToolManager.canModerateTarget(this.client.getHabbo(), userId)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
ModToolSanctions modToolSanctions = Emulator.getGameEnvironment().getModToolSanctions();
|
||||||
|
|
||||||
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
if (Emulator.getConfig().getBoolean("hotel.sanctions.enabled")) {
|
||||||
|
|||||||
+65
@@ -0,0 +1,65 @@
|
|||||||
|
package com.eu.habbo.messages.incoming.modtool;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import java.nio.file.Files;
|
||||||
|
import java.nio.file.Path;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
|
class ModToolPermissionContractTest {
|
||||||
|
private static final List<String> STAFF_ONLY_HANDLERS = List.of(
|
||||||
|
"ModToolAlertEvent.java",
|
||||||
|
"ModToolChangeRoomSettingsEvent.java",
|
||||||
|
"ModToolCloseTicketEvent.java",
|
||||||
|
"ModToolIssueChangeTopicEvent.java",
|
||||||
|
"ModToolIssueDefaultSanctionEvent.java",
|
||||||
|
"ModToolKickEvent.java",
|
||||||
|
"ModToolPickTicketEvent.java",
|
||||||
|
"ModToolReleaseTicketEvent.java",
|
||||||
|
"ModToolRequestIssueChatlogEvent.java",
|
||||||
|
"ModToolRequestRoomChatlogEvent.java",
|
||||||
|
"ModToolRequestRoomInfoEvent.java",
|
||||||
|
"ModToolRequestRoomUserChatlogEvent.java",
|
||||||
|
"ModToolRequestRoomVisitsEvent.java",
|
||||||
|
"ModToolRequestUserChatlogEvent.java",
|
||||||
|
"ModToolRequestUserInfoEvent.java",
|
||||||
|
"ModToolRoomAlertEvent.java",
|
||||||
|
"ModToolSanctionAlertEvent.java",
|
||||||
|
"ModToolSanctionBanEvent.java",
|
||||||
|
"ModToolSanctionMuteEvent.java",
|
||||||
|
"ModToolSanctionTradeLockEvent.java",
|
||||||
|
"ModToolWarnEvent.java"
|
||||||
|
);
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void staffOnlyModToolHandlersRequireSupportToolPermission() throws Exception {
|
||||||
|
Path base = Path.of("src/main/java/com/eu/habbo/messages/incoming/modtool");
|
||||||
|
|
||||||
|
for (String handler : STAFF_ONLY_HANDLERS) {
|
||||||
|
String source = Files.readString(base.resolve(handler));
|
||||||
|
assertTrue(source.contains("hasPermission(Permission.ACC_SUPPORTTOOL)"),
|
||||||
|
handler + " must require ACC_SUPPORTTOOL before exposing moderator actions or private logs");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void modToolSanctionsCannotTargetSameOrHigherRanks() throws Exception {
|
||||||
|
Path base = Path.of("src/main/java/com/eu/habbo/messages/incoming/modtool");
|
||||||
|
|
||||||
|
for (String handler : List.of(
|
||||||
|
"ModToolSanctionAlertEvent.java",
|
||||||
|
"ModToolSanctionMuteEvent.java",
|
||||||
|
"ModToolSanctionTradeLockEvent.java",
|
||||||
|
"ModToolIssueDefaultSanctionEvent.java")) {
|
||||||
|
String source = Files.readString(base.resolve(handler));
|
||||||
|
assertTrue(source.contains("ModToolManager.canModerateTarget"),
|
||||||
|
handler + " must enforce the modtool target rank ceiling before applying sanctions");
|
||||||
|
}
|
||||||
|
|
||||||
|
String manager = Files.readString(Path.of("src/main/java/com/eu/habbo/habbohotel/modtool/ModToolManager.java"));
|
||||||
|
assertTrue(manager.contains("!canModerateTarget(moderator, target.getHabboInfo().getId())"),
|
||||||
|
"ModToolManager.alert must refuse alerts/warnings against same-or-higher-rank targets");
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user