From 5de53af38b5e50dac47ed4a9920f072e664831ce Mon Sep 17 00:00:00 2001 From: Minecrell <minecrell@minecrell.net> Date: Tue, 10 Oct 2017 18:44:42 +0200 Subject: [PATCH] Expose client protocol version and virtual host Add a NetworkClient interface that provides access to: - The socket address - The protocol version - The virtual host (the hostname/port the client used to connect to the server) --- .../paper/network/NetworkClient.java | 39 +++++++++++++++++++ .../main/java/org/bukkit/entity/Player.java | 2 +- 2 files changed, 40 insertions(+), 1 deletion(-) create mode 100644 paper-api/src/main/java/com/destroystokyo/paper/network/NetworkClient.java diff --git a/paper-api/src/main/java/com/destroystokyo/paper/network/NetworkClient.java b/paper-api/src/main/java/com/destroystokyo/paper/network/NetworkClient.java new file mode 100644 index 0000000000..c84ce3fc87 --- /dev/null +++ b/paper-api/src/main/java/com/destroystokyo/paper/network/NetworkClient.java @@ -0,0 +1,39 @@ +package com.destroystokyo.paper.network; + +import java.net.InetSocketAddress; +import org.jspecify.annotations.NullMarked; +import org.jspecify.annotations.Nullable; + +/** + * Represents a client connected to the server. + */ +@NullMarked +public interface NetworkClient { + + /** + * Returns the socket address of the client. + * + * @return The client's socket address + */ + InetSocketAddress getAddress(); + + /** + * Returns the protocol version of the client. + * + * @return The client's protocol version, or {@code -1} if unknown + * @see <a href="http://wiki.vg/Protocol_version_numbers">List of protocol + * version numbers</a> + */ + int getProtocolVersion(); + + /** + * Returns the virtual host the client is connected to. + * + * <p>The virtual host refers to the hostname/port the client used to + * connect to the server.</p> + * + * @return The client's virtual host, or {@code null} if unknown + */ + @Nullable InetSocketAddress getVirtualHost(); + +} diff --git a/paper-api/src/main/java/org/bukkit/entity/Player.java b/paper-api/src/main/java/org/bukkit/entity/Player.java index 5b12fa8c41..2c9a1378ec 100644 --- a/paper-api/src/main/java/org/bukkit/entity/Player.java +++ b/paper-api/src/main/java/org/bukkit/entity/Player.java @@ -58,7 +58,7 @@ import org.jetbrains.annotations.Nullable; /** * Represents a player, connected or not */ -public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginMessageRecipient, net.kyori.adventure.identity.Identified, net.kyori.adventure.bossbar.BossBarViewer { // Paper +public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginMessageRecipient, net.kyori.adventure.identity.Identified, net.kyori.adventure.bossbar.BossBarViewer, com.destroystokyo.paper.network.NetworkClient { // Paper // Paper start @Override