2021-06-11 14:02:28 +02:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
From: Jedediah Smith <jedediah@silencegreys.com>
Date: Sat, 2 Apr 2016 05:09:16 -0400
Subject: [PATCH] Add PlayerUseUnknownEntityEvent
2022-11-19 15:53:20 -08:00
== AT ==
public net.minecraft.network.protocol.game.ServerboundInteractPacket$ActionType
2021-06-11 14:02:28 +02:00
diff --git a/src/main/java/net/minecraft/network/protocol/game/ServerboundInteractPacket.java b/src/main/java/net/minecraft/network/protocol/game/ServerboundInteractPacket.java
2022-12-07 19:52:24 +01:00
index a5d57cc862036012d83b090bb1b3ccf4115a88b3..21068f766b75c414d5818073b7dca083d8ff4409 100644
2021-06-11 14:02:28 +02:00
--- a/src/main/java/net/minecraft/network/protocol/game/ServerboundInteractPacket.java
+++ b/src/main/java/net/minecraft/network/protocol/game/ServerboundInteractPacket.java
2021-06-11 20:37:02 -07:00
@@ -10,8 +10,8 @@ import net.minecraft.world.entity.Entity;
2021-06-11 20:07:57 -07:00
import net.minecraft.world.phys.Vec3;
2021-06-11 14:02:28 +02:00
public class ServerboundInteractPacket implements Packet<ServerGamePacketListener> {
2021-06-11 20:07:57 -07:00
- private final int entityId;
2021-06-11 20:37:02 -07:00
- private final ServerboundInteractPacket.Action action;
2021-06-11 20:07:57 -07:00
+ private final int entityId; public final int getEntityId() { return this.entityId; } // Paper - add accessor
2021-06-11 20:37:02 -07:00
+ private final ServerboundInteractPacket.Action action; public final ServerboundInteractPacket.ActionType getActionType() { return this.action.getType(); } // Paper - add accessor
2021-06-11 20:07:57 -07:00
private final boolean usingSecondaryAction;
static final ServerboundInteractPacket.Action ATTACK_ACTION = new ServerboundInteractPacket.Action() {
2021-06-11 20:37:02 -07:00
@Override
2021-06-11 14:02:28 +02:00
diff --git a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
2023-03-14 19:36:39 +01:00
index f5b8da00f641a401d7ff4641908dd7de55cbe683..76f7ddbbba4be5c31d70ce9af9e041e69ee31662 100644
2021-06-11 14:02:28 +02:00
--- a/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
+++ b/src/main/java/net/minecraft/server/network/ServerGamePacketListenerImpl.java
2023-03-14 19:36:39 +01:00
@@ -2534,8 +2534,37 @@ public class ServerGamePacketListenerImpl implements ServerPlayerConnection, Tic
2021-06-11 20:37:02 -07:00
});
2021-06-11 14:02:28 +02:00
}
}
+ // Paper start - fire event
+ else {
2021-06-11 20:37:02 -07:00
+ packet.dispatch(new net.minecraft.network.protocol.game.ServerboundInteractPacket.Handler() {
+ @Override
+ public void onInteraction(net.minecraft.world.InteractionHand hand) {
+ ServerGamePacketListenerImpl.this.callPlayerUseUnknownEntityEvent(packet, hand);
+ }
+
+ @Override
+ public void onInteraction(net.minecraft.world.InteractionHand hand, net.minecraft.world.phys.Vec3 pos) {
+ ServerGamePacketListenerImpl.this.callPlayerUseUnknownEntityEvent(packet, hand);
+ }
+
+ @Override
+ public void onAttack() {
+ ServerGamePacketListenerImpl.this.callPlayerUseUnknownEntityEvent(packet, net.minecraft.world.InteractionHand.MAIN_HAND);
+ }
+ });
2021-06-11 14:02:28 +02:00
+ }
2021-06-11 20:37:02 -07:00
+
+ }
2021-06-11 14:02:28 +02:00
2021-06-11 20:37:02 -07:00
+ private void callPlayerUseUnknownEntityEvent(ServerboundInteractPacket packet, InteractionHand hand) {
+ this.cserver.getPluginManager().callEvent(new com.destroystokyo.paper.event.player.PlayerUseUnknownEntityEvent(
+ this.getCraftPlayer(),
+ packet.getEntityId(),
+ packet.getActionType() == ServerboundInteractPacket.ActionType.ATTACK,
+ hand == InteractionHand.MAIN_HAND ? EquipmentSlot.HAND : EquipmentSlot.OFF_HAND
+ ));
2021-06-11 14:02:28 +02:00
}
2021-06-11 20:37:02 -07:00
+ // Paper end
2021-06-11 14:02:28 +02:00
2021-06-11 20:37:02 -07:00
@Override
public void handleClientCommand(ServerboundClientCommandPacket packet) {