Compare commits

..

No commits in common. "3e05e6b89d997e5afa2be87965f2d3073ab53fe7" and "c9594fe2483af69848d0811ad7cb2bab2c77947c" have entirely different histories.

5 changed files with 44 additions and 47 deletions

View file

@ -37,9 +37,17 @@ public class SelfCareCommand {
.executes(m -> setSelfCare(m, "cspy")) .executes(m -> setSelfCare(m, "cspy"))
) )
) )
.then(
literal("icu")
.then(
argument("boolean", bool())
.executes(m -> setSelfCare(m, "icu"))
)
)
); );
} }
// setSelfCare is probably not a good name for this
public static int setSelfCare (CommandContext<FabricClientCommandSource> context, String type) { public static int setSelfCare (CommandContext<FabricClientCommandSource> context, String type) {
final FabricClientCommandSource source = context.getSource(); final FabricClientCommandSource source = context.getSource();
final boolean bool = getBool(context, "boolean"); final boolean bool = getBool(context, "boolean");
@ -57,6 +65,10 @@ public class SelfCareCommand {
SelfCare.INSTANCE.cspyEnabled = bool; SelfCare.INSTANCE.cspyEnabled = bool;
source.sendFeedback(Text.literal("The CommandSpy self care is now " + (bool ? "enabled" : "disabled"))); source.sendFeedback(Text.literal("The CommandSpy self care is now " + (bool ? "enabled" : "disabled")));
} }
case "icu" -> {
SelfCare.INSTANCE.icuEnabled = bool;
source.sendFeedback(Text.literal("The iControlU self care is now " + (bool ? "enabled" : "disabled")));
}
} }
return Command.SINGLE_SUCCESS; return Command.SINGLE_SUCCESS;

View file

@ -5,10 +5,8 @@ import net.minecraft.text.Text;
public interface Listener { public interface Listener {
default void packetReceived (Packet<?> packet) {} default void packetReceived (Packet<?> packet) {}
default void packetSent (Packet<?> packet) {}
default void chatMessageReceived (Text message) {} default void chatMessageReceived (Text message) {}
default void overlayMessageReceived (Text message) {} default void packetSent (Packet<?> packet) {}
default void coreReady () {} default void coreReady () {}
default void coreMoved () {} default void coreMoved () {}

View file

@ -12,7 +12,6 @@ import net.minecraft.command.CommandSource;
import net.minecraft.network.packet.s2c.play.CommandTreeS2CPacket; import net.minecraft.network.packet.s2c.play.CommandTreeS2CPacket;
import net.minecraft.network.packet.s2c.play.GameJoinS2CPacket; import net.minecraft.network.packet.s2c.play.GameJoinS2CPacket;
import net.minecraft.network.packet.s2c.play.GameMessageS2CPacket; import net.minecraft.network.packet.s2c.play.GameMessageS2CPacket;
import net.minecraft.network.packet.s2c.play.OverlayMessageS2CPacket;
import net.minecraft.registry.DynamicRegistryManager; import net.minecraft.registry.DynamicRegistryManager;
import net.minecraft.resource.featuretoggle.FeatureSet; import net.minecraft.resource.featuretoggle.FeatureSet;
import net.minecraft.text.Text; import net.minecraft.text.Text;
@ -86,24 +85,13 @@ public class ClientPlayNetworkHandlerMixin {
if (message.getSiblings().size() > 1) { if (message.getSiblings().size() > 1) {
final String suggestionId = message.getSiblings().getFirst().getString(); final String suggestionId = message.getSiblings().getFirst().getString();
if (suggestionId.equals(ChomeNSBotCommandSuggestions.REQUEST_SUGGESTIONS_ID)) { if (suggestionId.equals(ChomeNSBotCommandSuggestions.ID)) {
ci.cancel(); ci.cancel();
} }
} }
} catch (Exception ignored) {} } catch (Exception ignored) {}
} }
@Inject(method = "onOverlayMessage", at = @At("TAIL"))
private void onOverlayMessage(OverlayMessageS2CPacket packet, CallbackInfo ci) {
for (Listener listener : ListenerManager.listeners) {
listener.overlayMessageReceived(packet.text());
}
// checking for the bot selector message doesn't really
// do much here since the message is just an empty string,
// so I do not ignore them
}
@Inject(method = "sendChatMessage", at = @At("HEAD"), cancellable = true) @Inject(method = "sendChatMessage", at = @At("HEAD"), cancellable = true)
private void sendChatMessage(String chatText, CallbackInfo ci) { private void sendChatMessage(String chatText, CallbackInfo ci) {
final CommandManager commandManager = CommandManager.INSTANCE; final CommandManager commandManager = CommandManager.INSTANCE;

View file

@ -9,15 +9,13 @@ import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer;
import net.minecraft.client.MinecraftClient; import net.minecraft.client.MinecraftClient;
import net.minecraft.client.network.ClientPlayerEntity; import net.minecraft.client.network.ClientPlayerEntity;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import net.minecraft.text.TranslatableTextContent;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Objects; import java.util.Objects;
public class ChomeNSBotCommandSuggestions implements Listener { public class ChomeNSBotCommandSuggestions implements Listener {
public static final String BOT_SELECTOR_ID = "chomens_bot_selector"; public static final String ID = "chomens_bot_request_command_suggestion";
public static final String REQUEST_SUGGESTIONS_ID = "chomens_bot_request_command_suggestion";
public static ChomeNSBotCommandSuggestions INSTANCE = new ChomeNSBotCommandSuggestions(MinecraftClient.getInstance()); public static ChomeNSBotCommandSuggestions INSTANCE = new ChomeNSBotCommandSuggestions(MinecraftClient.getInstance());
@ -25,8 +23,6 @@ public class ChomeNSBotCommandSuggestions implements Listener {
public boolean receivedSuggestions = false; // can be set through eval public boolean receivedSuggestions = false; // can be set through eval
public String botSelector = null;
public List<ChomeNSBotCommand> commands = new ArrayList<>(); public List<ChomeNSBotCommand> commands = new ArrayList<>();
public ChomeNSBotCommandSuggestions (MinecraftClient client) { public ChomeNSBotCommandSuggestions (MinecraftClient client) {
@ -45,39 +41,17 @@ public class ChomeNSBotCommandSuggestions implements Listener {
public void forceRequest () { public void forceRequest () {
final ClientPlayerEntity player = client.player; final ClientPlayerEntity player = client.player;
if (botSelector == null || player == null) return; if (player == null) return;
final String selector = UUIDUtilities.selector(player.getUuid()); final String selector = UUIDUtilities.selector(player.getUuid());
final Component component = Component final Component component = Component
.text(REQUEST_SUGGESTIONS_ID) .text(ID)
.append(Component.text(selector)); .append(Component.text(selector));
final String serialized = GsonComponentSerializer.gson().serialize(component); final String serialized = GsonComponentSerializer.gson().serialize(component);
// minecraft:tellraw @p[nbt={UUID:[I;6,9,6,9]} {...} CommandCore.INSTANCE.run((KaboomCheck.INSTANCE.isKaboom ? "minecraft:tellraw " : "tellraw ") + "@a[team=chomens_bot] " + serialized);
CommandCore.INSTANCE.run(
String.format(
"%s %s %s",
(KaboomCheck.INSTANCE.isKaboom ? "minecraft:tellraw" : "tellraw"),
botSelector,
serialized
)
);
}
@Override
public void overlayMessageReceived (Text message) {
if (
!(message.getContent() instanceof TranslatableTextContent translatableTextContent)
|| !translatableTextContent.getKey().isEmpty()
|| translatableTextContent.getArgs().length != 2
|| !(translatableTextContent.getArgs()[0] instanceof String id)
|| !id.equals(BOT_SELECTOR_ID)
|| !(translatableTextContent.getArgs()[1] instanceof String selector)
) return;
this.botSelector = selector;
} }
@Override @Override
@ -86,7 +60,7 @@ public class ChomeNSBotCommandSuggestions implements Listener {
if (children.isEmpty()) return; if (children.isEmpty()) return;
final Text textComponent = children.getFirst(); final Text textComponent = children.getFirst();
if (!textComponent.getString().equals(REQUEST_SUGGESTIONS_ID)) return; if (!textComponent.getString().equals(ID)) return;
commands = children.stream() commands = children.stream()
.skip(1) .skip(1)

View file

@ -9,6 +9,7 @@ import net.minecraft.client.network.ClientPlayerEntity;
import net.minecraft.network.packet.Packet; import net.minecraft.network.packet.Packet;
import net.minecraft.network.packet.s2c.play.GameJoinS2CPacket; import net.minecraft.network.packet.s2c.play.GameJoinS2CPacket;
import net.minecraft.network.packet.s2c.play.GameStateChangeS2CPacket; import net.minecraft.network.packet.s2c.play.GameStateChangeS2CPacket;
import net.minecraft.network.packet.s2c.play.PlayerPositionLookS2CPacket;
import net.minecraft.text.Text; import net.minecraft.text.Text;
import java.util.Timer; import java.util.Timer;
@ -24,6 +25,7 @@ public class SelfCare implements Listener {
public boolean opEnabled = true; public boolean opEnabled = true;
public boolean gamemodeEnabled = true; public boolean gamemodeEnabled = true;
public boolean cspyEnabled = true; public boolean cspyEnabled = true;
public boolean icuEnabled = true;
private int gameMode; private int gameMode;
@ -31,10 +33,13 @@ public class SelfCare implements Listener {
private Timer timer; private Timer timer;
private Timer chatTimer; private Timer chatTimer;
private Timer icuTimer;
private boolean cspy = false; private boolean cspy = false;
public boolean hasSkin = false; public boolean hasSkin = false;
private int positionPacketsPerSecond = 0;
public static final SelfCare INSTANCE = new SelfCare(MinecraftClient.getInstance(), 70L, 500L); // make the intervals in config? public static final SelfCare INSTANCE = new SelfCare(MinecraftClient.getInstance(), 70L, 500L); // make the intervals in config?
public SelfCare(MinecraftClient client, long interval, long chatInterval) { public SelfCare(MinecraftClient client, long interval, long chatInterval) {
@ -63,11 +68,20 @@ public class SelfCare implements Listener {
} }
}; };
final TimerTask icuTask = new TimerTask() {
@Override
public void run() {
positionPacketsPerSecond = 0;
}
};
timer = new Timer(); timer = new Timer();
chatTimer = new Timer(); chatTimer = new Timer();
icuTimer = new Timer();
timer.schedule(task, interval, interval); timer.schedule(task, interval, interval);
chatTimer.schedule(chatTask, chatInterval, chatInterval); chatTimer.schedule(chatTask, chatInterval, chatInterval);
icuTimer.schedule(icuTask, 1000L, 1000L);
} }
public void cleanup() { public void cleanup() {
@ -79,6 +93,9 @@ public class SelfCare implements Listener {
chatTimer.cancel(); chatTimer.cancel();
chatTimer.purge(); chatTimer.purge();
icuTimer.cancel();
icuTimer.purge();
gameMode = -1; gameMode = -1;
hasSkin = false; hasSkin = false;
@ -110,6 +127,7 @@ public class SelfCare implements Listener {
if (player != null && !player.hasPermissionLevel(2) && opEnabled && serverHasCommand("op")) networkHandler.sendChatCommand("op @s[type=player]"); if (player != null && !player.hasPermissionLevel(2) && opEnabled && serverHasCommand("op")) networkHandler.sendChatCommand("op @s[type=player]");
else if (gameMode != 1 && gamemodeEnabled) networkHandler.sendChatCommand("gamemode creative"); else if (gameMode != 1 && gamemodeEnabled) networkHandler.sendChatCommand("gamemode creative");
else if (positionPacketsPerSecond >= 10 && icuEnabled) CommandCore.INSTANCE.run("sudo * icu stop");
} }
public void chatTick() { public void chatTick() {
@ -126,6 +144,7 @@ public class SelfCare implements Listener {
public void packetReceived(Packet<?> packet) { public void packetReceived(Packet<?> packet) {
if (packet instanceof GameJoinS2CPacket) packetReceived((GameJoinS2CPacket) packet); if (packet instanceof GameJoinS2CPacket) packetReceived((GameJoinS2CPacket) packet);
else if (packet instanceof GameStateChangeS2CPacket) packetReceived((GameStateChangeS2CPacket) packet); else if (packet instanceof GameStateChangeS2CPacket) packetReceived((GameStateChangeS2CPacket) packet);
else if (packet instanceof PlayerPositionLookS2CPacket) packetReceived((PlayerPositionLookS2CPacket) packet);
} }
public void packetReceived(GameJoinS2CPacket packet) { public void packetReceived(GameJoinS2CPacket packet) {
@ -137,4 +156,10 @@ public class SelfCare implements Listener {
gameMode = (int) packet.getValue(); gameMode = (int) packet.getValue();
} }
public void packetReceived(PlayerPositionLookS2CPacket packet) {
if (timer == null) return;
positionPacketsPerSecond++;
}
} }