2021-06-11 12:02:28 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Mon, 15 Jan 2018 21:46:46 -0500
|
|
|
|
Subject: [PATCH] Basic PlayerProfile API
|
|
|
|
|
|
|
|
Provides basic elements of a PlayerProfile to be used by future API/events
|
|
|
|
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/profile/PlayerProfile.java b/src/main/java/com/destroystokyo/paper/profile/PlayerProfile.java
|
|
|
|
new file mode 100644
|
2022-02-12 18:29:41 +00:00
|
|
|
index 0000000000000000000000000000000000000000..d4766e2116c2202d84080637a2832bef0ab3f718
|
2021-06-11 12:02:28 +00:00
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/profile/PlayerProfile.java
|
2022-02-12 18:29:41 +00:00
|
|
|
@@ -0,0 +1,199 @@
|
2021-06-11 12:02:28 +00:00
|
|
|
+package com.destroystokyo.paper.profile;
|
|
|
|
+
|
|
|
|
+import java.util.Collection;
|
|
|
|
+import java.util.Set;
|
|
|
|
+import java.util.UUID;
|
2022-02-12 13:20:33 +00:00
|
|
|
+
|
|
|
|
+import org.bukkit.profile.PlayerTextures;
|
2021-06-11 12:02:28 +00:00
|
|
|
+import org.jetbrains.annotations.NotNull;
|
|
|
|
+import org.jetbrains.annotations.Nullable;
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * Represents a players profile for the game, such as UUID, Name, and textures.
|
|
|
|
+ */
|
2022-02-12 13:20:33 +00:00
|
|
|
+public interface PlayerProfile extends org.bukkit.profile.PlayerProfile {
|
2021-06-11 12:02:28 +00:00
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return The players name, if set
|
|
|
|
+ */
|
|
|
|
+ @Nullable
|
|
|
|
+ String getName();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Sets this profiles Name
|
|
|
|
+ *
|
|
|
|
+ * @param name The new Name
|
|
|
|
+ * @return The previous Name
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
2022-02-12 18:29:41 +00:00
|
|
|
+ @Deprecated(forRemoval = true)
|
2021-06-11 12:02:28 +00:00
|
|
|
+ String setName(@Nullable String name);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return The players unique identifier, if set
|
|
|
|
+ */
|
|
|
|
+ @Nullable UUID getId();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Sets this profiles UUID
|
|
|
|
+ *
|
|
|
|
+ * @param uuid The new UUID
|
|
|
|
+ * @return The previous UUID
|
|
|
|
+ */
|
|
|
|
+ @Nullable
|
2022-02-12 18:29:41 +00:00
|
|
|
+ @Deprecated(forRemoval = true)
|
2021-06-11 12:02:28 +00:00
|
|
|
+ UUID setId(@Nullable UUID uuid);
|
|
|
|
+
|
|
|
|
+ /**
|
2022-02-12 13:20:33 +00:00
|
|
|
+ * Gets the {@link PlayerTextures} of this profile.
|
|
|
|
+ * This will build a snapshot of the current texture data once
|
|
|
|
+ * requested inside PlayerTextures.
|
|
|
|
+ *
|
|
|
|
+ * @return the textures, not <code>null</code>
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ PlayerTextures getTextures();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Copies the given textures.
|
|
|
|
+ *
|
|
|
|
+ * @param textures the textures to copy, or <code>null</code> to clear the
|
|
|
|
+ * textures
|
|
|
|
+ */
|
|
|
|
+ void setTextures(@Nullable PlayerTextures textures);
|
|
|
|
+
|
|
|
|
+ /**
|
2021-06-11 12:02:28 +00:00
|
|
|
+ * @return A Mutable set of this players properties, such as textures.
|
|
|
|
+ * Values specified here are subject to implementation details.
|
|
|
|
+ */
|
|
|
|
+ @NotNull Set<ProfileProperty> getProperties();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Check if the Profile has the specified property
|
|
|
|
+ * @param property Property name to check
|
|
|
|
+ * @return If the property is set
|
|
|
|
+ */
|
|
|
|
+ boolean hasProperty(@Nullable String property);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Sets a property. If the property already exists, the previous one will be replaced
|
|
|
|
+ * @param property Property to set.
|
|
|
|
+ */
|
|
|
|
+ void setProperty(@NotNull ProfileProperty property);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Sets multiple properties. If any of the set properties already exist, it will be replaced
|
|
|
|
+ * @param properties The properties to set
|
|
|
|
+ */
|
|
|
|
+ void setProperties(@NotNull Collection<ProfileProperty> properties);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Removes a specific property from this profile
|
|
|
|
+ * @param property The property to remove
|
|
|
|
+ * @return If a property was removed
|
|
|
|
+ */
|
|
|
|
+ boolean removeProperty(@Nullable String property);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Removes a specific property from this profile
|
|
|
|
+ * @param property The property to remove
|
|
|
|
+ * @return If a property was removed
|
|
|
|
+ */
|
|
|
|
+ default boolean removeProperty(@NotNull ProfileProperty property) {
|
|
|
|
+ return removeProperty(property.getName());
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Removes all properties in the collection
|
|
|
|
+ * @param properties The properties to remove
|
|
|
|
+ * @return If any property was removed
|
|
|
|
+ */
|
|
|
|
+ default boolean removeProperties(@NotNull Collection<ProfileProperty> properties) {
|
|
|
|
+ boolean removed = false;
|
|
|
|
+ for (ProfileProperty property : properties) {
|
|
|
|
+ if (removeProperty(property)) {
|
|
|
|
+ removed = true;
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return removed;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Clears all properties on this profile
|
|
|
|
+ */
|
|
|
|
+ void clearProperties();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name)
|
|
|
|
+ */
|
|
|
|
+ boolean isComplete();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Like {@link #complete(boolean)} but will try only from cache, and not make network calls
|
|
|
|
+ * Does not account for textures.
|
|
|
|
+ *
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name)
|
|
|
|
+ */
|
|
|
|
+ boolean completeFromCache();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Like {@link #complete(boolean)} but will try only from cache, and not make network calls
|
|
|
|
+ * Does not account for textures.
|
|
|
|
+ *
|
|
|
|
+ * @param onlineMode Treat this as online mode or not
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name)
|
|
|
|
+ */
|
|
|
|
+ boolean completeFromCache(boolean onlineMode);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Like {@link #complete(boolean)} but will try only from cache, and not make network calls
|
|
|
|
+ * Does not account for textures.
|
|
|
|
+ *
|
|
|
|
+ * @param lookupUUID If only name is supplied, should we do a UUID lookup
|
|
|
|
+ * @param onlineMode Treat this as online mode or not
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name)
|
|
|
|
+ */
|
|
|
|
+ boolean completeFromCache(boolean lookupUUID, boolean onlineMode);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * If this profile is not complete, then make the API call to complete it.
|
|
|
|
+ * This is a blocking operation and should be done asynchronously.
|
|
|
|
+ *
|
|
|
|
+ * This will also complete textures. If you do not want to load textures, use {{@link #complete(boolean)}}
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name) (if you get rate limited, this operation may fail)
|
|
|
|
+ */
|
|
|
|
+ default boolean complete() {
|
|
|
|
+ return complete(true);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * If this profile is not complete, then make the API call to complete it.
|
|
|
|
+ * This is a blocking operation and should be done asynchronously.
|
|
|
|
+ *
|
|
|
|
+ * Optionally will also fill textures.
|
|
|
|
+ *
|
|
|
|
+ * Online mode will be automatically determined
|
|
|
|
+ * @param textures controls if we should fill the profile with texture properties
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name) (if you get rate limited, this operation may fail)
|
|
|
|
+ */
|
|
|
|
+ boolean complete(boolean textures);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * If this profile is not complete, then make the API call to complete it.
|
|
|
|
+ * This is a blocking operation and should be done asynchronously.
|
|
|
|
+ *
|
|
|
|
+ * Optionally will also fill textures.
|
|
|
|
+ * @param textures controls if we should fill the profile with texture properties
|
|
|
|
+ * @param onlineMode Treat this server as online mode or not
|
|
|
|
+ * @return If the profile is now complete (has UUID and Name) (if you get rate limited, this operation may fail)
|
|
|
|
+ */
|
|
|
|
+ boolean complete(boolean textures, boolean onlineMode);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Whether or not this Profile has textures associated to it
|
|
|
|
+ * @return If has a textures property
|
|
|
|
+ */
|
|
|
|
+ default boolean hasTextures() {
|
|
|
|
+ return hasProperty("textures");
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/com/destroystokyo/paper/profile/ProfileProperty.java b/src/main/java/com/destroystokyo/paper/profile/ProfileProperty.java
|
|
|
|
new file mode 100644
|
|
|
|
index 0000000000000000000000000000000000000000..7b3b6ef533d32169fbeca389bd61cfc6b0e0faee
|
|
|
|
--- /dev/null
|
|
|
|
+++ b/src/main/java/com/destroystokyo/paper/profile/ProfileProperty.java
|
|
|
|
@@ -0,0 +1,72 @@
|
|
|
|
+package com.destroystokyo.paper.profile;
|
|
|
|
+
|
|
|
|
+import com.google.common.base.Preconditions;
|
|
|
|
+
|
|
|
|
+import java.util.Objects;
|
|
|
|
+import org.jetbrains.annotations.NotNull;
|
|
|
|
+import org.jetbrains.annotations.Nullable;
|
|
|
|
+
|
|
|
|
+/**
|
|
|
|
+ * Represents a property on a {@link PlayerProfile}
|
|
|
|
+ */
|
|
|
|
+public class ProfileProperty {
|
|
|
|
+ private final String name;
|
|
|
|
+ private final String value;
|
|
|
|
+ private final String signature;
|
|
|
|
+
|
|
|
|
+ public ProfileProperty(@NotNull String name, @NotNull String value) {
|
|
|
|
+ this(name, value, null);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ public ProfileProperty(@NotNull String name, @NotNull String value, @Nullable String signature) {
|
|
|
|
+ this.name = Preconditions.checkNotNull(name, "ProfileProperty name can not be null");
|
|
|
|
+ this.value = Preconditions.checkNotNull(value, "ProfileProperty value can not be null");
|
|
|
|
+ this.signature = signature;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return The property name, ie "textures"
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ public String getName() {
|
|
|
|
+ return name;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return The property value, likely to be base64 encoded
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ public String getValue() {
|
|
|
|
+ return value;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return A signature from Mojang for signed properties
|
|
|
|
+ */
|
|
|
|
+ @Nullable
|
|
|
|
+ public String getSignature() {
|
|
|
|
+ return signature;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * @return If this property has a signature or not
|
|
|
|
+ */
|
|
|
|
+ public boolean isSigned() {
|
|
|
|
+ return this.signature != null;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public boolean equals(Object o) {
|
|
|
|
+ if (this == o) return true;
|
|
|
|
+ if (o == null || getClass() != o.getClass()) return false;
|
|
|
|
+ ProfileProperty that = (ProfileProperty) o;
|
|
|
|
+ return Objects.equals(name, that.name) &&
|
|
|
|
+ Objects.equals(value, that.value) &&
|
|
|
|
+ Objects.equals(signature, that.signature);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public int hashCode() {
|
|
|
|
+ return Objects.hash(name);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
diff --git a/src/main/java/org/bukkit/Bukkit.java b/src/main/java/org/bukkit/Bukkit.java
|
2022-03-19 13:39:38 +00:00
|
|
|
index b175f07b99a07ba50c4721c38f9e6330f02942f8..88720b2fa92f387714c11a11cba8c9bf0a25e797 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/org/bukkit/Bukkit.java
|
|
|
|
+++ b/src/main/java/org/bukkit/Bukkit.java
|
2022-03-19 13:39:38 +00:00
|
|
|
@@ -2080,6 +2080,50 @@ public final class Bukkit {
|
2021-06-11 12:02:28 +00:00
|
|
|
public static boolean suggestPlayerNamesWhenNullTabCompletions() {
|
|
|
|
return server.suggestPlayerNamesWhenNullTabCompletions();
|
|
|
|
}
|
|
|
|
+
|
|
|
|
+ /**
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * Creates a PlayerProfile for the specified uuid, with name as null.
|
|
|
|
+ *
|
|
|
|
+ * If a player with the passed uuid exists on the server at the time of creation, the returned player profile will
|
|
|
|
+ * be populated with the properties of said player.
|
|
|
|
+ *
|
2021-06-11 12:02:28 +00:00
|
|
|
+ * @param uuid UUID to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ public static com.destroystokyo.paper.profile.PlayerProfile createProfile(@NotNull UUID uuid) {
|
|
|
|
+ return server.createProfile(uuid);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * Creates a PlayerProfile for the specified name, with UUID as null.
|
|
|
|
+ *
|
|
|
|
+ * If a player with the passed name exists on the server at the time of creation, the returned player profile will
|
|
|
|
+ * be populated with the properties of said player.
|
|
|
|
+ *
|
2021-06-11 12:02:28 +00:00
|
|
|
+ * @param name Name to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ public static com.destroystokyo.paper.profile.PlayerProfile createProfile(@NotNull String name) {
|
|
|
|
+ return server.createProfile(name);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Creates a PlayerProfile for the specified name/uuid
|
|
|
|
+ *
|
|
|
|
+ * Both UUID and Name can not be null at same time. One must be supplied.
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * If a player with the passed uuid or name exists on the server at the time of creation, the returned player
|
|
|
|
+ * profile will be populated with the properties of said player.
|
2021-06-11 12:02:28 +00:00
|
|
|
+ *
|
|
|
|
+ * @param uuid UUID to create profile for
|
|
|
|
+ * @param name Name to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ public static com.destroystokyo.paper.profile.PlayerProfile createProfile(@Nullable UUID uuid, @Nullable String name) {
|
|
|
|
+ return server.createProfile(uuid, name);
|
|
|
|
+ }
|
|
|
|
// Paper end
|
|
|
|
|
|
|
|
@NotNull
|
|
|
|
diff --git a/src/main/java/org/bukkit/Server.java b/src/main/java/org/bukkit/Server.java
|
2022-03-19 13:39:38 +00:00
|
|
|
index 24e68d5cb4f713984b25ab19330cb77f1eddb5cf..29886928ab33edf9965b93e89482a84bd82e4fd2 100644
|
2021-06-11 12:02:28 +00:00
|
|
|
--- a/src/main/java/org/bukkit/Server.java
|
|
|
|
+++ b/src/main/java/org/bukkit/Server.java
|
2022-03-19 13:39:38 +00:00
|
|
|
@@ -1825,5 +1825,43 @@ public interface Server extends PluginMessageRecipient, net.kyori.adventure.audi
|
2021-06-11 12:02:28 +00:00
|
|
|
* @return true if player names should be suggested
|
|
|
|
*/
|
|
|
|
boolean suggestPlayerNamesWhenNullTabCompletions();
|
|
|
|
+
|
|
|
|
+ /**
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * Creates a PlayerProfile for the specified uuid, with name as null.
|
|
|
|
+ *
|
|
|
|
+ * If a player with the passed uuid exists on the server at the time of creation, the returned player profile will
|
|
|
|
+ * be populated with the properties of said player.
|
|
|
|
+ *
|
2021-06-11 12:02:28 +00:00
|
|
|
+ * @param uuid UUID to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ com.destroystokyo.paper.profile.PlayerProfile createProfile(@NotNull UUID uuid);
|
|
|
|
+
|
|
|
|
+ /**
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * Creates a PlayerProfile for the specified name, with UUID as null.
|
|
|
|
+ *
|
|
|
|
+ * If a player with the passed name exists on the server at the time of creation, the returned player profile will
|
|
|
|
+ * be populated with the properties of said player.
|
|
|
|
+ *
|
2021-06-11 12:02:28 +00:00
|
|
|
+ * @param name Name to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ com.destroystokyo.paper.profile.PlayerProfile createProfile(@NotNull String name);
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Creates a PlayerProfile for the specified name/uuid
|
|
|
|
+ *
|
|
|
|
+ * Both UUID and Name can not be null at same time. One must be supplied.
|
2022-03-19 13:39:38 +00:00
|
|
|
+ * If a player with the passed uuid or name exists on the server at the time of creation, the returned player
|
|
|
|
+ * profile will be populated with the properties of said player.
|
2021-06-11 12:02:28 +00:00
|
|
|
+ *
|
|
|
|
+ * @param uuid UUID to create profile for
|
|
|
|
+ * @param name Name to create profile for
|
|
|
|
+ * @return A PlayerProfile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
|
|
|
+ com.destroystokyo.paper.profile.PlayerProfile createProfile(@Nullable UUID uuid, @Nullable String name);
|
|
|
|
// Paper end
|
|
|
|
}
|