mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-19 14:41:34 +01:00
Added some FakePlayerController features
This commit is contained in:
parent
30053c507b
commit
9a7c07af65
@ -8,6 +8,7 @@ import net.minestom.server.benchmark.ThreadResult;
|
|||||||
import net.minestom.server.entity.*;
|
import net.minestom.server.entity.*;
|
||||||
import net.minestom.server.entity.damage.DamageType;
|
import net.minestom.server.entity.damage.DamageType;
|
||||||
import net.minestom.server.entity.fakeplayer.FakePlayer;
|
import net.minestom.server.entity.fakeplayer.FakePlayer;
|
||||||
|
import net.minestom.server.entity.fakeplayer.FakePlayerController;
|
||||||
import net.minestom.server.event.entity.EntityAttackEvent;
|
import net.minestom.server.event.entity.EntityAttackEvent;
|
||||||
import net.minestom.server.event.item.ItemDropEvent;
|
import net.minestom.server.event.item.ItemDropEvent;
|
||||||
import net.minestom.server.event.item.ItemUpdateStateEvent;
|
import net.minestom.server.event.item.ItemUpdateStateEvent;
|
||||||
@ -154,6 +155,8 @@ public class PlayerInit {
|
|||||||
//chickenCreature.setInstance(player.getInstance());
|
//chickenCreature.setInstance(player.getInstance());
|
||||||
|
|
||||||
FakePlayer fakePlayer = new FakePlayer(UUID.randomUUID(), "test");
|
FakePlayer fakePlayer = new FakePlayer(UUID.randomUUID(), "test");
|
||||||
|
FakePlayerController controller = fakePlayer.getController();
|
||||||
|
controller.sendChatMessage("I am a bot!");
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -126,6 +126,9 @@ public class Player extends LivingEntity {
|
|||||||
|
|
||||||
setRespawnPoint(new Position(0, 0, 0));
|
setRespawnPoint(new Position(0, 0, 0));
|
||||||
|
|
||||||
|
// FakePlayer init its connection there
|
||||||
|
playerConnectionInit();
|
||||||
|
|
||||||
init();
|
init();
|
||||||
|
|
||||||
// Some client update
|
// Some client update
|
||||||
@ -178,6 +181,7 @@ public class Player extends LivingEntity {
|
|||||||
spawnPositionPacket.z = 0;
|
spawnPositionPacket.z = 0;
|
||||||
playerConnection.sendPacket(spawnPositionPacket);
|
playerConnection.sendPacket(spawnPositionPacket);
|
||||||
|
|
||||||
|
// Add player to list
|
||||||
String property = "eyJ0aW1lc3RhbXAiOjE1NjU0ODMwODQwOTYsInByb2ZpbGVJZCI6ImFiNzBlY2I0MjM0NjRjMTRhNTJkN2EwOTE1MDdjMjRlIiwicHJvZmlsZU5hbWUiOiJUaGVNb2RlOTExIiwidGV4dHVyZXMiOnsiU0tJTiI6eyJ1cmwiOiJodHRwOi8vdGV4dHVyZXMubWluZWNyYWZ0Lm5ldC90ZXh0dXJlL2RkOTE2NzJiNTE0MmJhN2Y3MjA2ZTRjN2IwOTBkNzhlM2Y1ZDc2NDdiNWFmZDIyNjFhZDk4OGM0MWI2ZjcwYTEifX19";
|
String property = "eyJ0aW1lc3RhbXAiOjE1NjU0ODMwODQwOTYsInByb2ZpbGVJZCI6ImFiNzBlY2I0MjM0NjRjMTRhNTJkN2EwOTE1MDdjMjRlIiwicHJvZmlsZU5hbWUiOiJUaGVNb2RlOTExIiwidGV4dHVyZXMiOnsiU0tJTiI6eyJ1cmwiOiJodHRwOi8vdGV4dHVyZXMubWluZWNyYWZ0Lm5ldC90ZXh0dXJlL2RkOTE2NzJiNTE0MmJhN2Y3MjA2ZTRjN2IwOTBkNzhlM2Y1ZDc2NDdiNWFmZDIyNjFhZDk4OGM0MWI2ZjcwYTEifX19";
|
||||||
PlayerInfoPacket playerInfoPacket = new PlayerInfoPacket(PlayerInfoPacket.Action.ADD_PLAYER);
|
PlayerInfoPacket playerInfoPacket = new PlayerInfoPacket(PlayerInfoPacket.Action.ADD_PLAYER);
|
||||||
PlayerInfoPacket.AddPlayer addPlayer = new PlayerInfoPacket.AddPlayer(getUuid(), username, getGameMode(), 10);
|
PlayerInfoPacket.AddPlayer addPlayer = new PlayerInfoPacket.AddPlayer(getUuid(), username, getGameMode(), 10);
|
||||||
@ -186,18 +190,22 @@ public class Player extends LivingEntity {
|
|||||||
playerInfoPacket.playerInfos.add(addPlayer);
|
playerInfoPacket.playerInfos.add(addPlayer);
|
||||||
playerConnection.sendPacket(playerInfoPacket);
|
playerConnection.sendPacket(playerInfoPacket);
|
||||||
|
|
||||||
|
// Init player
|
||||||
for (Consumer<Player> playerInitialization : MinecraftServer.getConnectionManager().getPlayerInitializations()) {
|
for (Consumer<Player> playerInitialization : MinecraftServer.getConnectionManager().getPlayerInitializations()) {
|
||||||
playerInitialization.accept(this);
|
playerInitialization.accept(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Commands start
|
||||||
{
|
{
|
||||||
CommandManager commandManager = MinecraftServer.getCommandManager();
|
CommandManager commandManager = MinecraftServer.getCommandManager();
|
||||||
DeclareCommandsPacket declareCommandsPacket = commandManager.createDeclareCommandsPacket(this);
|
DeclareCommandsPacket declareCommandsPacket = commandManager.createDeclareCommandsPacket(this);
|
||||||
|
|
||||||
playerConnection.sendPacket(declareCommandsPacket);
|
playerConnection.sendPacket(declareCommandsPacket);
|
||||||
}
|
}
|
||||||
|
// Commands end
|
||||||
|
|
||||||
|
|
||||||
|
// Recipes start
|
||||||
{
|
{
|
||||||
RecipeManager recipeManager = MinecraftServer.getRecipeManager();
|
RecipeManager recipeManager = MinecraftServer.getRecipeManager();
|
||||||
DeclareRecipesPacket declareRecipesPacket = recipeManager.getDeclareRecipesPacket();
|
DeclareRecipesPacket declareRecipesPacket = recipeManager.getDeclareRecipesPacket();
|
||||||
@ -221,6 +229,10 @@ public class Player extends LivingEntity {
|
|||||||
playerConnection.sendPacket(unlockRecipesPacket);
|
playerConnection.sendPacket(unlockRecipesPacket);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Recipes end
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void playerConnectionInit() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -11,9 +11,12 @@ public class FakePlayer extends Player {
|
|||||||
|
|
||||||
public FakePlayer(UUID uuid, String username) {
|
public FakePlayer(UUID uuid, String username) {
|
||||||
super(uuid, username, new FakePlayerConnection());
|
super(uuid, username, new FakePlayerConnection());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void playerConnectionInit() {
|
||||||
FakePlayerConnection playerConnection = (FakePlayerConnection) getPlayerConnection();
|
FakePlayerConnection playerConnection = (FakePlayerConnection) getPlayerConnection();
|
||||||
playerConnection.setFakePlayer(this);
|
playerConnection.setFakePlayer(this);
|
||||||
|
|
||||||
this.fakePlayerController = new FakePlayerController(this);
|
this.fakePlayerController = new FakePlayerController(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,16 +1,100 @@
|
|||||||
package net.minestom.server.entity.fakeplayer;
|
package net.minestom.server.entity.fakeplayer;
|
||||||
|
|
||||||
import net.minestom.server.network.player.PlayerConnection;
|
import net.minestom.server.entity.Entity;
|
||||||
|
import net.minestom.server.inventory.Inventory;
|
||||||
|
import net.minestom.server.inventory.InventoryModifier;
|
||||||
|
import net.minestom.server.inventory.PlayerInventory;
|
||||||
|
import net.minestom.server.item.ItemStack;
|
||||||
|
import net.minestom.server.network.packet.client.ClientPlayPacket;
|
||||||
|
import net.minestom.server.network.packet.client.play.*;
|
||||||
|
import net.minestom.server.network.packet.server.ServerPacket;
|
||||||
|
import net.minestom.server.network.packet.server.play.KeepAlivePacket;
|
||||||
|
import net.minestom.server.network.packet.server.play.PlayerPositionAndLookPacket;
|
||||||
|
import net.minestom.server.utils.inventory.PlayerInventoryUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class act as a client controller for {@link FakePlayer}
|
||||||
|
*/
|
||||||
public class FakePlayerController {
|
public class FakePlayerController {
|
||||||
|
|
||||||
private FakePlayer fakePlayer;
|
private FakePlayer fakePlayer;
|
||||||
private PlayerConnection playerConnection;
|
|
||||||
|
|
||||||
public FakePlayerController(FakePlayer fakePlayer) {
|
public FakePlayerController(FakePlayer fakePlayer) {
|
||||||
this.fakePlayer = fakePlayer;
|
this.fakePlayer = fakePlayer;
|
||||||
this.playerConnection = fakePlayer.getPlayerConnection();
|
}
|
||||||
|
|
||||||
fakePlayer.setHeldItemSlot((short) 1);
|
/**
|
||||||
|
* Make the player write a message
|
||||||
|
*
|
||||||
|
* @param message the message to write
|
||||||
|
*/
|
||||||
|
public void sendChatMessage(String message) {
|
||||||
|
ClientChatMessagePacket chatMessagePacket = new ClientChatMessagePacket();
|
||||||
|
chatMessagePacket.message = message;
|
||||||
|
addToQueue(chatMessagePacket);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clickWindow(boolean playerInventory, short slot, byte button, short action, int mode) {
|
||||||
|
Inventory inventory = playerInventory ? null : fakePlayer.getOpenInventory();
|
||||||
|
InventoryModifier inventoryModifier = inventory == null ? fakePlayer.getInventory() : inventory;
|
||||||
|
playerInventory = inventoryModifier instanceof PlayerInventory;
|
||||||
|
|
||||||
|
slot = playerInventory ? (short) PlayerInventoryUtils.convertToPacketSlot(slot) : slot;
|
||||||
|
|
||||||
|
ItemStack itemStack = inventoryModifier.getItemStack(slot);
|
||||||
|
|
||||||
|
ClientClickWindowPacket clickWindowPacket = new ClientClickWindowPacket();
|
||||||
|
clickWindowPacket.windowId = playerInventory ? 0 : inventory.getWindowId();
|
||||||
|
clickWindowPacket.slot = slot;
|
||||||
|
clickWindowPacket.button = button;
|
||||||
|
clickWindowPacket.actionNumber = action;
|
||||||
|
clickWindowPacket.mode = mode;
|
||||||
|
clickWindowPacket.item = itemStack;
|
||||||
|
addToQueue(clickWindowPacket);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void closeWindow() {
|
||||||
|
Inventory openInventory = fakePlayer.getOpenInventory();
|
||||||
|
|
||||||
|
ClientCloseWindow closeWindow = new ClientCloseWindow();
|
||||||
|
closeWindow.windowId = openInventory == null ? 0 : openInventory.getWindowId();
|
||||||
|
addToQueue(closeWindow);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void sendPluginMessage(String channel, byte[] message) {
|
||||||
|
ClientPluginMessagePacket pluginMessagePacket = new ClientPluginMessagePacket();
|
||||||
|
pluginMessagePacket.channel = channel;
|
||||||
|
pluginMessagePacket.data = message;
|
||||||
|
addToQueue(pluginMessagePacket);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void attackEntity(Entity entity) {
|
||||||
|
ClientInteractEntityPacket interactEntityPacket = new ClientInteractEntityPacket();
|
||||||
|
interactEntityPacket.targetId = entity.getEntityId();
|
||||||
|
interactEntityPacket.type = ClientInteractEntityPacket.Type.ATTACK;
|
||||||
|
addToQueue(interactEntityPacket);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make the player receives a packet
|
||||||
|
* WARNING: pretty much unsafe, used internally to redirect packets here,
|
||||||
|
* you should instead use {@link net.minestom.server.network.player.PlayerConnection#sendPacket(ServerPacket)}
|
||||||
|
*
|
||||||
|
* @param serverPacket the packet to consume
|
||||||
|
*/
|
||||||
|
public void consumePacket(ServerPacket serverPacket) {
|
||||||
|
if (serverPacket instanceof PlayerPositionAndLookPacket) {
|
||||||
|
ClientTeleportConfirmPacket teleportConfirmPacket = new ClientTeleportConfirmPacket();
|
||||||
|
teleportConfirmPacket.teleportId = ((PlayerPositionAndLookPacket) serverPacket).teleportId;
|
||||||
|
addToQueue(teleportConfirmPacket);
|
||||||
|
} else if (serverPacket instanceof KeepAlivePacket) {
|
||||||
|
ClientKeepAlivePacket keepAlivePacket = new ClientKeepAlivePacket();
|
||||||
|
keepAlivePacket.id = ((KeepAlivePacket) serverPacket).id;
|
||||||
|
addToQueue(keepAlivePacket);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addToQueue(ClientPlayPacket clientPlayPacket) {
|
||||||
|
this.fakePlayer.addPacketToQueue(clientPlayPacket);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,7 @@ import net.minestom.server.network.packet.client.play.ClientPluginMessagePacket;
|
|||||||
public class PluginMessageListener {
|
public class PluginMessageListener {
|
||||||
|
|
||||||
public static void listener(ClientPluginMessagePacket packet, Player player) {
|
public static void listener(ClientPluginMessagePacket packet, Player player) {
|
||||||
PlayerPluginMessageEvent pluginMessageEvent = new PlayerPluginMessageEvent(packet.identifier, packet.data);
|
PlayerPluginMessageEvent pluginMessageEvent = new PlayerPluginMessageEvent(packet.channel, packet.data);
|
||||||
player.callEvent(PlayerPluginMessageEvent.class, pluginMessageEvent);
|
player.callEvent(PlayerPluginMessageEvent.class, pluginMessageEvent);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -14,12 +14,17 @@ import net.minestom.server.network.packet.server.play.WindowConfirmationPacket;
|
|||||||
public class WindowListener {
|
public class WindowListener {
|
||||||
|
|
||||||
public static void clickWindowListener(ClientClickWindowPacket packet, Player player) {
|
public static void clickWindowListener(ClientClickWindowPacket packet, Player player) {
|
||||||
InventoryClickHandler clickHandler = player.getOpenInventory();
|
Inventory inventory;
|
||||||
if (clickHandler == null) {
|
byte windowId = packet.windowId;
|
||||||
clickHandler = player.getInventory();
|
if (windowId == 0) {
|
||||||
|
inventory = null;
|
||||||
|
} else {
|
||||||
|
inventory = player.getOpenInventory();
|
||||||
}
|
}
|
||||||
|
|
||||||
byte windowId = packet.windowId;
|
InventoryClickHandler clickHandler = inventory == null ?
|
||||||
|
player.getInventory() : player.getOpenInventory();
|
||||||
|
|
||||||
short slot = packet.slot;
|
short slot = packet.slot;
|
||||||
byte button = packet.button;
|
byte button = packet.button;
|
||||||
short actionNumber = packet.actionNumber;
|
short actionNumber = packet.actionNumber;
|
||||||
@ -74,7 +79,7 @@ public class WindowListener {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
refreshCursorItem(player, player.getOpenInventory());
|
refreshCursorItem(player, inventory);
|
||||||
|
|
||||||
WindowConfirmationPacket windowConfirmationPacket = new WindowConfirmationPacket();
|
WindowConfirmationPacket windowConfirmationPacket = new WindowConfirmationPacket();
|
||||||
windowConfirmationPacket.windowId = windowId;
|
windowConfirmationPacket.windowId = windowId;
|
||||||
|
@ -5,12 +5,12 @@ import net.minestom.server.network.packet.client.ClientPlayPacket;
|
|||||||
|
|
||||||
public class ClientPluginMessagePacket extends ClientPlayPacket {
|
public class ClientPluginMessagePacket extends ClientPlayPacket {
|
||||||
|
|
||||||
public String identifier;
|
public String channel;
|
||||||
public byte[] data;
|
public byte[] data;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void read(PacketReader reader) {
|
public void read(PacketReader reader) {
|
||||||
this.identifier = reader.readSizedString();
|
this.channel = reader.readSizedString();
|
||||||
this.data = reader.getRemainingBytes();
|
this.data = reader.getRemainingBytes();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -6,7 +6,7 @@ import net.minestom.server.network.packet.server.ServerPacketIdentifier;
|
|||||||
|
|
||||||
public class KeepAlivePacket implements ServerPacket {
|
public class KeepAlivePacket implements ServerPacket {
|
||||||
|
|
||||||
private long id;
|
public long id;
|
||||||
|
|
||||||
public KeepAlivePacket(long id) {
|
public KeepAlivePacket(long id) {
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
@ -23,7 +23,7 @@ public class FakePlayerConnection extends PlayerConnection {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void sendPacket(ServerPacket serverPacket) {
|
public void sendPacket(ServerPacket serverPacket) {
|
||||||
|
this.fakePlayer.getController().consumePacket(serverPacket);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user