mirror of
https://github.com/PaperMC/Paper.git
synced 2025-01-25 09:34:44 +01:00
Use fetched GameProfile for getOfflinePlayer(String)
When getting an OfflinePlayer by name we lookup their UUID and then use that to fetch the OfflinePlayer. If the player has not played on this server before the resulting OfflinePlayer will return null for getName(). As this is unintuitive we now create the OfflinePlayer directly using the profile we looked up and make OfflinePlayer prefer that data.
This commit is contained in:
parent
8f771c7378
commit
7b409ed4e9
2 changed files with 19 additions and 6 deletions
|
@ -49,6 +49,11 @@ public class CraftOfflinePlayer implements OfflinePlayer, ConfigurationSerializa
|
||||||
return player.getName();
|
return player.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// This might not match lastKnownName but if not it should be more correct
|
||||||
|
if (profile.getName() != null) {
|
||||||
|
return profile.getName();
|
||||||
|
}
|
||||||
|
|
||||||
NBTTagCompound data = getBukkitData();
|
NBTTagCompound data = getBukkitData();
|
||||||
|
|
||||||
if (data != null) {
|
if (data != null) {
|
||||||
|
|
|
@ -1260,14 +1260,22 @@ public final class CraftServer implements Server {
|
||||||
public OfflinePlayer getOfflinePlayer(String name) {
|
public OfflinePlayer getOfflinePlayer(String name) {
|
||||||
Validate.notNull(name, "Name cannot be null");
|
Validate.notNull(name, "Name cannot be null");
|
||||||
|
|
||||||
|
OfflinePlayer result = getPlayerExact(name);
|
||||||
|
if (result == null) {
|
||||||
// This is potentially blocking :(
|
// This is potentially blocking :(
|
||||||
GameProfile profile = MinecraftServer.getServer().getUserCache().a(name);
|
GameProfile profile = MinecraftServer.getServer().getUserCache().a(name);
|
||||||
if (profile == null) {
|
if (profile == null) {
|
||||||
// Make an OfflinePlayer using an offline mode UUID since the name has no profile
|
// Make an OfflinePlayer using an offline mode UUID since the name has no profile
|
||||||
return getOfflinePlayer(new GameProfile(java.util.UUID.nameUUIDFromBytes(("OfflinePlayer:" + name).getBytes(Charsets.UTF_8)), name));
|
result = getOfflinePlayer(new GameProfile(java.util.UUID.nameUUIDFromBytes(("OfflinePlayer:" + name).getBytes(Charsets.UTF_8)), name));
|
||||||
|
} else {
|
||||||
|
// Use the GameProfile even when we get a UUID so we ensure we still have a name
|
||||||
|
result = getOfflinePlayer(profile);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
offlinePlayers.remove(result.getUniqueId());
|
||||||
}
|
}
|
||||||
|
|
||||||
return getOfflinePlayer(profile.getId());
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
public OfflinePlayer getOfflinePlayer(java.util.UUID id) {
|
public OfflinePlayer getOfflinePlayer(java.util.UUID id) {
|
||||||
|
|
Loading…
Add table
Reference in a new issue