diff --git a/paper-api/src/main/java/org/bukkit/event/player/PlayerCommandSendEvent.java b/paper-api/src/main/java/org/bukkit/event/player/PlayerCommandSendEvent.java
new file mode 100644
index 0000000000..fbdecdcc1d
--- /dev/null
+++ b/paper-api/src/main/java/org/bukkit/event/player/PlayerCommandSendEvent.java
@@ -0,0 +1,51 @@
+package org.bukkit.event.player;
+
+import java.util.Collection;
+import org.bukkit.Warning;
+import org.bukkit.entity.Player;
+import org.bukkit.event.HandlerList;
+
+/**
+ * This event is called when the list of available server commands is sent to
+ * the player.
+ *
+ * Commands may be removed from display using this event, but implementations
+ * are not required to securely remove all traces of the command. If secure
+ * removal of commands is required, then the command should be assigned a
+ * permission which is not granted to the player.
+ *
+ * @deprecated draft API
+ */
+@Deprecated
+@Warning(false)
+public class PlayerCommandSendEvent extends PlayerEvent {
+
+ private static final HandlerList handlers = new HandlerList();
+ private final Collection commands;
+
+ public PlayerCommandSendEvent(final Player player, final Collection commands) {
+ super(player);
+ this.commands = commands;
+ }
+
+ /**
+ * Returns a mutable collection of all top level commands to be sent.
+ *
+ * It is not legal to add entries to this collection, only remove them.
+ * Behaviour of adding entries is undefined.
+ *
+ * @return collection of all commands
+ */
+ public Collection getCommands() {
+ return commands;
+ }
+
+ @Override
+ public HandlerList getHandlers() {
+ return handlers;
+ }
+
+ public static HandlerList getHandlerList() {
+ return handlers;
+ }
+}