2021-06-11 14:02:28 +02:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: Aikar <aikar@aikar.co>
|
|
|
|
Date: Sun, 18 Mar 2018 12:28:55 -0400
|
|
|
|
Subject: [PATCH] Player.setPlayerProfile API
|
|
|
|
|
|
|
|
This can be useful for changing name or skins after a player has logged in.
|
|
|
|
|
2022-02-12 14:20:33 +01:00
|
|
|
diff --git a/src/main/java/org/bukkit/Bukkit.java b/src/main/java/org/bukkit/Bukkit.java
|
2023-11-11 21:25:45 +01:00
|
|
|
index 87ce6947a1e974c18e84f56ba622bee9fff3570b..0dfb60e4635cc960b5cb481206b6c02adb36d7f9 100644
|
2022-02-12 14:20:33 +01:00
|
|
|
--- a/src/main/java/org/bukkit/Bukkit.java
|
|
|
|
+++ b/src/main/java/org/bukkit/Bukkit.java
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1306,8 +1306,10 @@ public final class Bukkit {
|
2022-04-23 16:40:37 +02:00
|
|
|
* @return the new PlayerProfile
|
|
|
|
* @throws IllegalArgumentException if both the unique id is
|
2022-02-12 14:20:33 +01:00
|
|
|
* <code>null</code> and the name is <code>null</code> or blank
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(UUID, String)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
public static PlayerProfile createPlayerProfile(@Nullable UUID uniqueId, @Nullable String name) {
|
|
|
|
return server.createPlayerProfile(uniqueId, name);
|
|
|
|
}
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1318,8 +1320,10 @@ public final class Bukkit {
|
2022-04-23 16:40:37 +02:00
|
|
|
* @param uniqueId the unique id
|
|
|
|
* @return the new PlayerProfile
|
2022-02-12 14:20:33 +01:00
|
|
|
* @throws IllegalArgumentException if the unique id is <code>null</code>
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(UUID)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
public static PlayerProfile createPlayerProfile(@NotNull UUID uniqueId) {
|
|
|
|
return server.createPlayerProfile(uniqueId);
|
|
|
|
}
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1331,8 +1335,10 @@ public final class Bukkit {
|
2022-04-23 16:40:37 +02:00
|
|
|
* @return the new PlayerProfile
|
|
|
|
* @throws IllegalArgumentException if the name is <code>null</code> or
|
2022-02-12 14:20:33 +01:00
|
|
|
* blank
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(String)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
public static PlayerProfile createPlayerProfile(@NotNull String name) {
|
|
|
|
return server.createPlayerProfile(name);
|
|
|
|
}
|
2022-12-22 05:30:21 +01:00
|
|
|
diff --git a/src/main/java/org/bukkit/OfflinePlayer.java b/src/main/java/org/bukkit/OfflinePlayer.java
|
2023-08-06 02:21:59 +02:00
|
|
|
index bec480aff819e09220b52175cab0cb6d68ae68c6..12349910297a75c00e64f6ccc7981aeeeb43ecd3 100644
|
2022-12-22 05:30:21 +01:00
|
|
|
--- a/src/main/java/org/bukkit/OfflinePlayer.java
|
|
|
|
+++ b/src/main/java/org/bukkit/OfflinePlayer.java
|
2023-08-06 02:21:59 +02:00
|
|
|
@@ -59,7 +59,7 @@ public interface OfflinePlayer extends ServerOperator, AnimalTamer, Configuratio
|
2022-12-22 05:30:21 +01:00
|
|
|
* @return the player's profile
|
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
- PlayerProfile getPlayerProfile();
|
|
|
|
+ com.destroystokyo.paper.profile.PlayerProfile getPlayerProfile(); // Paper
|
|
|
|
|
|
|
|
/**
|
2023-07-04 10:22:56 +02:00
|
|
|
* Checks if this player has had their profile banned.
|
2022-02-12 14:20:33 +01:00
|
|
|
diff --git a/src/main/java/org/bukkit/Server.java b/src/main/java/org/bukkit/Server.java
|
2023-11-11 21:25:45 +01:00
|
|
|
index bc68d8af8b38232392a12ef5f338e85ca80bccd0..ccc1142e496c33c70104646255bae98d43a6b6c2 100644
|
2022-02-12 14:20:33 +01:00
|
|
|
--- a/src/main/java/org/bukkit/Server.java
|
|
|
|
+++ b/src/main/java/org/bukkit/Server.java
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1119,8 +1119,10 @@ public interface Server extends PluginMessageRecipient, net.kyori.adventure.audi
|
2022-04-23 16:40:37 +02:00
|
|
|
* @return the new PlayerProfile
|
|
|
|
* @throws IllegalArgumentException if both the unique id is
|
2022-02-12 14:20:33 +01:00
|
|
|
* <code>null</code> and the name is <code>null</code> or blank
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(UUID, String)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
PlayerProfile createPlayerProfile(@Nullable UUID uniqueId, @Nullable String name);
|
|
|
|
|
|
|
|
/**
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1129,8 +1131,10 @@ public interface Server extends PluginMessageRecipient, net.kyori.adventure.audi
|
2022-04-23 16:40:37 +02:00
|
|
|
* @param uniqueId the unique id
|
|
|
|
* @return the new PlayerProfile
|
2022-02-12 14:20:33 +01:00
|
|
|
* @throws IllegalArgumentException if the unique id is <code>null</code>
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(UUID)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
PlayerProfile createPlayerProfile(@NotNull UUID uniqueId);
|
|
|
|
|
|
|
|
/**
|
2023-11-11 21:25:45 +01:00
|
|
|
@@ -1140,8 +1144,10 @@ public interface Server extends PluginMessageRecipient, net.kyori.adventure.audi
|
2022-04-23 16:40:37 +02:00
|
|
|
* @return the new PlayerProfile
|
|
|
|
* @throws IllegalArgumentException if the name is <code>null</code> or
|
2022-02-12 14:20:33 +01:00
|
|
|
* blank
|
2022-04-23 16:40:37 +02:00
|
|
|
+ * @deprecated use {@link #createProfile(String)}
|
2022-02-12 14:20:33 +01:00
|
|
|
*/
|
|
|
|
@NotNull
|
|
|
|
+ @Deprecated
|
|
|
|
PlayerProfile createPlayerProfile(@NotNull String name);
|
|
|
|
|
|
|
|
/**
|
2021-06-11 14:02:28 +02:00
|
|
|
diff --git a/src/main/java/org/bukkit/entity/Player.java b/src/main/java/org/bukkit/entity/Player.java
|
2023-09-22 04:31:59 +02:00
|
|
|
index 9dca8fc727b727063d9ca50fdd8f6452173a5cd4..ccd80734cf5641455fd9d9b63238739987e225da 100644
|
2021-06-11 14:02:28 +02:00
|
|
|
--- a/src/main/java/org/bukkit/entity/Player.java
|
|
|
|
+++ b/src/main/java/org/bukkit/entity/Player.java
|
2023-09-21 10:35:38 +02:00
|
|
|
@@ -2678,6 +2678,24 @@ public interface Player extends HumanEntity, Conversable, OfflinePlayer, PluginM
|
2021-06-11 14:02:28 +02:00
|
|
|
* was {@link org.bukkit.event.player.PlayerResourcePackStatusEvent.Status#SUCCESSFULLY_LOADED}
|
|
|
|
*/
|
|
|
|
boolean hasResourcePack();
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Gets a copy of this players profile
|
|
|
|
+ * @return The players profile object
|
|
|
|
+ */
|
|
|
|
+ @NotNull
|
2022-02-12 14:20:33 +01:00
|
|
|
+ com.destroystokyo.paper.profile.PlayerProfile getPlayerProfile();
|
2021-06-11 14:02:28 +02:00
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * Changes the PlayerProfile for this player. This will cause this player
|
2023-08-12 16:10:09 +02:00
|
|
|
+ * to be reregistered to all clients that can currently see this player.
|
|
|
|
+ *
|
|
|
|
+ * After executing this method, the player {@link java.util.UUID} won't
|
|
|
|
+ * be swapped, only their name and gameprofile properties.
|
|
|
|
+ *
|
2021-06-11 14:02:28 +02:00
|
|
|
+ * @param profile The new profile to use
|
|
|
|
+ */
|
2022-02-12 14:20:33 +01:00
|
|
|
+ void setPlayerProfile(@NotNull com.destroystokyo.paper.profile.PlayerProfile profile);
|
2021-06-11 14:02:28 +02:00
|
|
|
// Paper end
|
|
|
|
|
|
|
|
// Spigot start
|
2022-02-12 14:20:33 +01:00
|
|
|
diff --git a/src/main/java/org/bukkit/profile/PlayerProfile.java b/src/main/java/org/bukkit/profile/PlayerProfile.java
|
2022-07-22 20:18:00 +02:00
|
|
|
index fc46add38bf59dc1a04ea566fd230dcd8ae2708c..d36b3e3c7e53840132011add365ca2a26d799064 100644
|
2022-02-12 14:20:33 +01:00
|
|
|
--- a/src/main/java/org/bukkit/profile/PlayerProfile.java
|
|
|
|
+++ b/src/main/java/org/bukkit/profile/PlayerProfile.java
|
|
|
|
@@ -16,7 +16,9 @@ import org.jetbrains.annotations.Nullable;
|
|
|
|
* <p>
|
|
|
|
* New profiles can be created via
|
|
|
|
* {@link Server#createPlayerProfile(UUID, String)}.
|
|
|
|
+ * @deprecated see {@link com.destroystokyo.paper.profile.PlayerProfile}
|
|
|
|
*/
|
|
|
|
+@Deprecated // Paper
|
|
|
|
public interface PlayerProfile extends Cloneable, ConfigurationSerializable {
|
|
|
|
|
|
|
|
/**
|
|
|
|
@@ -25,6 +27,7 @@ public interface PlayerProfile extends Cloneable, ConfigurationSerializable {
|
|
|
|
* @return the player's unique id, or <code>null</code> if not available
|
|
|
|
*/
|
|
|
|
@Nullable
|
|
|
|
+ @Deprecated // Paper
|
|
|
|
UUID getUniqueId();
|
|
|
|
|
|
|
|
/**
|