2020-05-06 17:48:49 +08:00
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
2018-01-16 11:13:17 +08:00
From: Aikar <aikar@aikar.co>
Date: Mon, 15 Jan 2018 22:11:48 -0500
Subject: [PATCH] Basic PlayerProfile API
2018-05-11 11:01:52 +08:00
Establishes base extension of profile systems for future edits too
2018-01-16 11:13:17 +08:00
2018-01-19 13:03:09 +08:00
diff --git a/src/main/java/com/destroystokyo/paper/profile/CraftPlayerProfile.java b/src/main/java/com/destroystokyo/paper/profile/CraftPlayerProfile.java
2018-01-16 11:13:17 +08:00
new file mode 100644
2021-05-05 10:54:42 +08:00
index 0000000000000000000000000000000000000000..3d9452892a4077e64f37424052a9e52d76dd7a6d
2018-01-16 11:13:17 +08:00
--- /dev/null
2018-01-19 13:03:09 +08:00
+++ b/src/main/java/com/destroystokyo/paper/profile/CraftPlayerProfile.java
2021-03-02 05:06:05 +08:00
@@ -0,0 +1,301 @@
2018-01-16 11:13:17 +08:00
+package com.destroystokyo.paper.profile;
+
2018-03-22 13:28:22 +08:00
+import com.destroystokyo.paper.PaperConfig;
+import com.google.common.base.Charsets;
2018-01-16 11:13:17 +08:00
+import com.mojang.authlib.GameProfile;
+import com.mojang.authlib.properties.Property;
+import com.mojang.authlib.properties.PropertyMap;
2018-03-18 23:31:32 +08:00
+import net.minecraft.server.MinecraftServer;
2021-03-16 21:04:28 +08:00
+import net.minecraft.server.players.UserCache;
2020-06-22 10:59:34 +08:00
+import org.apache.commons.lang3.Validate;
2018-03-22 13:28:22 +08:00
+import org.bukkit.craftbukkit.entity.CraftPlayer;
+import org.spigotmc.SpigotConfig;
2018-01-16 11:13:17 +08:00
+
+import javax.annotation.Nonnull;
+import javax.annotation.Nullable;
2018-01-22 03:09:09 +08:00
+import java.util.AbstractSet;
2018-01-16 11:13:17 +08:00
+import java.util.Collection;
2018-01-22 03:09:09 +08:00
+import java.util.Iterator;
2018-03-23 09:56:18 +08:00
+import java.util.Objects;
2018-01-16 11:13:17 +08:00
+import java.util.Set;
+import java.util.UUID;
+
2018-01-19 13:03:09 +08:00
+public class CraftPlayerProfile implements PlayerProfile {
2018-01-16 11:13:17 +08:00
+
2018-03-18 23:31:32 +08:00
+ private GameProfile profile;
2018-03-23 09:40:57 +08:00
+ private final PropertySet properties = new PropertySet();
2018-01-16 11:13:17 +08:00
+
2018-03-22 13:28:22 +08:00
+ public CraftPlayerProfile(CraftPlayer player) {
2018-03-23 09:40:57 +08:00
+ this.profile = player.getHandle().getProfile();
+ }
+
2018-01-19 13:03:09 +08:00
+ public CraftPlayerProfile(UUID id, String name) {
2018-03-26 08:05:30 +08:00
+ this.profile = new GameProfile(id, name);
2018-03-23 09:40:57 +08:00
+ }
+
+ public CraftPlayerProfile(GameProfile profile) {
2020-06-22 10:59:34 +08:00
+ Validate.notNull(profile, "GameProfile cannot be null!");
2018-03-23 09:40:57 +08:00
+ this.profile = profile;
2018-03-22 13:28:22 +08:00
+ }
+
2018-03-26 08:05:30 +08:00
+ @Override
+ public boolean hasProperty(String property) {
+ return profile.getProperties().containsKey(property);
+ }
2018-03-22 13:28:22 +08:00
+
2018-03-26 08:05:30 +08:00
+ @Override
+ public void setProperty(ProfileProperty property) {
+ String name = property.getName();
+ PropertyMap properties = profile.getProperties();
+ properties.removeAll(name);
+ properties.put(name, new Property(name, property.getValue(), property.getSignature()));
2018-03-22 13:28:22 +08:00
+ }
+
2018-03-26 08:05:30 +08:00
+ public GameProfile getGameProfile() {
2018-03-23 09:40:57 +08:00
+ return profile;
+ }
+
2018-03-26 08:05:30 +08:00
+ @Nullable
+ @Override
+ public UUID getId() {
+ return profile.getId();
2018-01-16 11:13:17 +08:00
+ }
+
2018-03-26 09:50:46 +08:00
+ @Override
+ public UUID setId(@Nullable UUID uuid) {
+ GameProfile prev = this.profile;
+ this.profile = new GameProfile(uuid, prev.getName());
+ copyProfileProperties(prev, this.profile);
+ return prev.getId();
+ }
+
2018-03-26 08:05:30 +08:00
+ @Nullable
2018-01-16 11:13:17 +08:00
+ @Override
2018-03-26 08:05:30 +08:00
+ public String getName() {
+ return profile.getName();
2018-01-19 13:38:49 +08:00
+ }
+
2018-03-26 09:50:46 +08:00
+ @Override
+ public String setName(@Nullable String name) {
+ GameProfile prev = this.profile;
+ this.profile = new GameProfile(prev.getId(), name);
+ copyProfileProperties(prev, this.profile);
+ return prev.getName();
+ }
+
2018-03-26 08:05:30 +08:00
+ @Nonnull
2018-01-19 13:38:49 +08:00
+ @Override
2018-03-26 08:05:30 +08:00
+ public Set<ProfileProperty> getProperties() {
+ return properties;
2018-01-16 11:13:17 +08:00
+ }
+
+ @Override
+ public void setProperties(Collection<ProfileProperty> properties) {
+ properties.forEach(this::setProperty);
+ }
+
+ @Override
2018-03-26 08:05:30 +08:00
+ public void clearProperties() {
+ profile.getProperties().clear();
+ }
+
+ @Override
2018-01-16 11:13:17 +08:00
+ public boolean removeProperty(String property) {
+ return !profile.getProperties().removeAll(property).isEmpty();
+ }
+
+ @Override
2018-03-26 08:05:30 +08:00
+ public boolean equals(Object o) {
+ if (this == o) return true;
+ if (o == null || getClass() != o.getClass()) return false;
+ CraftPlayerProfile that = (CraftPlayerProfile) o;
+ return Objects.equals(profile, that.profile);
+ }
+
+ @Override
+ public int hashCode() {
+ return profile.hashCode();
+ }
+
+ @Override
+ public String toString() {
+ return profile.toString();
+ }
+
+ @Override
+ public CraftPlayerProfile clone() {
+ CraftPlayerProfile clone = new CraftPlayerProfile(this.getId(), this.getName());
+ clone.setProperties(getProperties());
+ return clone;
2018-01-16 11:13:17 +08:00
+ }
+
+ @Override
+ public boolean isComplete() {
+ return profile.isComplete();
+ }
+
2018-03-26 09:50:46 +08:00
+ @Override
+ public boolean completeFromCache() {
2020-06-23 16:53:02 +08:00
+ MinecraftServer server = MinecraftServer.getServer();
2021-05-05 10:54:42 +08:00
+ return completeFromCache(false, PaperConfig.isProxyOnlineMode());
2020-06-23 16:53:02 +08:00
+ }
+
+ public boolean completeFromCache(boolean onlineMode) {
+ return completeFromCache(false, onlineMode);
2018-03-26 09:50:46 +08:00
+ }
+
2020-06-23 16:53:02 +08:00
+ public boolean completeFromCache(boolean lookupUUID, boolean onlineMode) {
2018-03-23 09:40:57 +08:00
+ MinecraftServer server = MinecraftServer.getServer();
+ String name = profile.getName();
2018-03-26 09:50:46 +08:00
+ UserCache userCache = server.getUserCache();
2018-03-23 09:40:57 +08:00
+ if (profile.getId() == null) {
2018-03-26 09:50:46 +08:00
+ final GameProfile profile;
2020-06-23 16:53:02 +08:00
+ if (onlineMode) {
+ profile = lookupUUID ? userCache.getProfile(name) : userCache.getProfileIfCached(name);
2018-03-26 09:50:46 +08:00
+ } else {
+ // Make an OfflinePlayer using an offline mode UUID since the name has no profile
+ profile = new GameProfile(UUID.nameUUIDFromBytes(("OfflinePlayer:" + name).getBytes(Charsets.UTF_8)), name);
+ }
2018-07-31 13:37:41 +08:00
+ if (profile != null) {
2020-06-20 09:32:42 +08:00
+ // if old has it, assume its newer, so overwrite, else use cached if it was set and ours wasn't
+ copyProfileProperties(this.profile, profile);
2018-07-31 13:37:41 +08:00
+ this.profile = profile;
2018-03-23 09:40:57 +08:00
+ }
+ }
2018-03-26 09:50:46 +08:00
+
2020-06-21 02:46:57 +08:00
+ if ((profile.getName() == null || !hasTextures()) && profile.getId() != null) {
2018-03-26 09:50:46 +08:00
+ GameProfile profile = userCache.getProfile(this.profile.getId());
2018-03-26 08:05:30 +08:00
+ if (profile != null) {
2021-03-02 05:06:05 +08:00
+ if (this.profile.getName() == null) {
+ // if old has it, assume its newer, so overwrite, else use cached if it was set and ours wasn't
+ copyProfileProperties(this.profile, profile);
+ this.profile = profile;
+ } else {
+ copyProfileProperties(profile, this.profile);
+ }
2018-03-26 08:05:30 +08:00
+ }
+ }
2018-03-26 09:50:46 +08:00
+ return this.profile.isComplete();
+ }
+
+ public boolean complete(boolean textures) {
+ MinecraftServer server = MinecraftServer.getServer();
2021-05-05 10:54:42 +08:00
+ return complete(textures, PaperConfig.isProxyOnlineMode());
2020-06-23 16:53:02 +08:00
+ }
+ public boolean complete(boolean textures, boolean onlineMode) {
+ MinecraftServer server = MinecraftServer.getServer();
2018-03-26 09:50:46 +08:00
+
2020-06-25 17:27:25 +08:00
+ boolean isCompleteFromCache = this.completeFromCache(true, onlineMode);
2020-06-23 16:53:02 +08:00
+ if (onlineMode && (!isCompleteFromCache || textures && !hasTextures())) {
2020-08-02 13:39:36 +08:00
+ GameProfile result = server.getMinecraftSessionService().fillProfileProperties(profile, true);
2018-03-22 13:28:22 +08:00
+ if (result != null) {
2020-06-20 09:32:42 +08:00
+ copyProfileProperties(result, this.profile, true);
2018-03-22 13:28:22 +08:00
+ }
2020-06-25 17:27:25 +08:00
+ if (this.profile.isComplete()) {
+ server.getUserCache().saveProfile(this.profile);
+ }
2018-03-22 07:12:02 +08:00
+ }
2020-06-23 16:53:02 +08:00
+ return profile.isComplete() && (!onlineMode || !textures || hasTextures());
2018-03-18 23:31:32 +08:00
+ }
+
2018-03-26 08:05:30 +08:00
+ private static void copyProfileProperties(GameProfile source, GameProfile target) {
2020-06-20 09:32:42 +08:00
+ copyProfileProperties(source, target, false);
+ }
+
+ private static void copyProfileProperties(GameProfile source, GameProfile target, boolean clearTarget) {
2018-03-26 09:50:46 +08:00
+ PropertyMap sourceProperties = source.getProperties();
2020-06-20 09:32:42 +08:00
+ PropertyMap targetProperties = target.getProperties();
+ if (clearTarget) targetProperties.clear();
2018-03-26 09:50:46 +08:00
+ if (sourceProperties.isEmpty()) {
+ return;
+ }
+
+ for (Property property : sourceProperties.values()) {
2020-06-29 07:37:53 +08:00
+ targetProperties.removeAll(property.getName());
2020-06-20 09:32:42 +08:00
+ targetProperties.put(property.getName(), property);
2018-03-26 08:05:30 +08:00
+ }
+ }
+
2018-01-19 13:03:09 +08:00
+ private static ProfileProperty toBukkit(Property property) {
2018-01-16 11:13:17 +08:00
+ return new ProfileProperty(property.getName(), property.getValue(), property.getSignature());
+ }
2018-01-19 13:03:09 +08:00
+
2018-01-19 13:38:49 +08:00
+ public static PlayerProfile asBukkitCopy(GameProfile gameProfile) {
2018-03-22 13:28:22 +08:00
+ CraftPlayerProfile profile = new CraftPlayerProfile(gameProfile.getId(), gameProfile.getName());
+ copyProfileProperties(gameProfile, profile.profile);
2018-01-19 13:03:09 +08:00
+ return profile;
+ }
+
2018-01-19 13:38:49 +08:00
+ public static PlayerProfile asBukkitMirror(GameProfile profile) {
+ return new CraftPlayerProfile(profile);
+ }
+
2018-01-19 13:03:09 +08:00
+ public static Property asAuthlib(ProfileProperty property) {
+ return new Property(property.getName(), property.getValue(), property.getSignature());
+ }
2018-03-26 08:05:30 +08:00
+
2018-01-19 13:38:49 +08:00
+ public static GameProfile asAuthlibCopy(PlayerProfile profile) {
+ CraftPlayerProfile craft = ((CraftPlayerProfile) profile);
+ return asAuthlib(craft.clone());
+ }
+
+ public static GameProfile asAuthlib(PlayerProfile profile) {
+ CraftPlayerProfile craft = ((CraftPlayerProfile) profile);
+ return craft.getGameProfile();
+ }
2018-01-22 03:09:09 +08:00
+
+ private class PropertySet extends AbstractSet<ProfileProperty> {
+
+ @Override
2018-03-08 10:03:01 +08:00
+ @Nonnull
2018-01-22 03:09:09 +08:00
+ public Iterator<ProfileProperty> iterator() {
2018-03-08 10:03:01 +08:00
+ return new ProfilePropertyIterator(profile.getProperties().values().iterator());
2018-01-22 03:09:09 +08:00
+ }
+
+ @Override
+ public int size() {
+ return profile.getProperties().size();
+ }
+
+ @Override
+ public boolean add(ProfileProperty property) {
+ setProperty(property);
+ return true;
+ }
+
+ @Override
+ public boolean addAll(Collection<? extends ProfileProperty> c) {
+ //noinspection unchecked
+ setProperties((Collection<ProfileProperty>) c);
+ return true;
+ }
+
+ @Override
+ public boolean contains(Object o) {
+ return o instanceof ProfileProperty && profile.getProperties().containsKey(((ProfileProperty) o).getName());
+ }
2018-03-08 10:03:01 +08:00
+
+ private class ProfilePropertyIterator implements Iterator<ProfileProperty> {
+ private final Iterator<Property> iterator;
+
+ ProfilePropertyIterator(Iterator<Property> iterator) {
+ this.iterator = iterator;
+ }
+
+ @Override
+ public boolean hasNext() {
+ return iterator.hasNext();
+ }
+
+ @Override
+ public ProfileProperty next() {
+ return toBukkit(iterator.next());
+ }
+
+ @Override
+ public void remove() {
+ iterator.remove();
+ }
+ }
2018-01-22 03:09:09 +08:00
+ }
2018-01-16 11:13:17 +08:00
+}
2018-05-11 11:01:52 +08:00
diff --git a/src/main/java/com/destroystokyo/paper/profile/PaperAuthenticationService.java b/src/main/java/com/destroystokyo/paper/profile/PaperAuthenticationService.java
new file mode 100644
2020-11-03 10:22:15 +08:00
index 0000000000000000000000000000000000000000..d64d45eb01c65864fca1077982d89bc05e0f811b
2018-05-11 11:01:52 +08:00
--- /dev/null
+++ b/src/main/java/com/destroystokyo/paper/profile/PaperAuthenticationService.java
2020-06-25 21:11:48 +08:00
@@ -0,0 +1,31 @@
2018-05-11 11:01:52 +08:00
+package com.destroystokyo.paper.profile;
+
2020-06-25 21:11:48 +08:00
+import com.mojang.authlib.*;
2018-05-11 11:01:52 +08:00
+import com.mojang.authlib.minecraft.MinecraftSessionService;
+import com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService;
2020-06-25 21:11:48 +08:00
+import com.mojang.authlib.yggdrasil.YggdrasilEnvironment;
2018-05-11 11:01:52 +08:00
+
+import java.net.Proxy;
+
+public class PaperAuthenticationService extends YggdrasilAuthenticationService {
2020-06-25 21:11:48 +08:00
+ private final Environment environment;
2020-11-03 10:22:15 +08:00
+ public PaperAuthenticationService(Proxy proxy) {
+ super(proxy);
2020-06-25 21:11:48 +08:00
+ this.environment = (Environment)EnvironmentParser.getEnvironmentFromProperties().orElse(YggdrasilEnvironment.PROD);;
2018-05-11 11:01:52 +08:00
+ }
+
+ @Override
+ public UserAuthentication createUserAuthentication(Agent agent) {
+ return new PaperUserAuthentication(this, agent);
+ }
+
+ @Override
+ public MinecraftSessionService createMinecraftSessionService() {
2020-06-25 21:11:48 +08:00
+ return new PaperMinecraftSessionService(this, this.environment);
2018-05-11 11:01:52 +08:00
+ }
+
+ @Override
+ public GameProfileRepository createProfileRepository() {
2020-06-25 21:11:48 +08:00
+ return new PaperGameProfileRepository(this, this.environment);
2018-05-11 11:01:52 +08:00
+ }
+}
diff --git a/src/main/java/com/destroystokyo/paper/profile/PaperGameProfileRepository.java b/src/main/java/com/destroystokyo/paper/profile/PaperGameProfileRepository.java
new file mode 100644
2020-06-25 21:11:48 +08:00
index 0000000000000000000000000000000000000000..582c169c85ac66f1f9430f79042e4655f776c157
2018-05-11 11:01:52 +08:00
--- /dev/null
+++ b/src/main/java/com/destroystokyo/paper/profile/PaperGameProfileRepository.java
2020-06-25 21:11:48 +08:00
@@ -0,0 +1,18 @@
2018-05-11 11:01:52 +08:00
+package com.destroystokyo.paper.profile;
+
+import com.mojang.authlib.Agent;
2020-06-25 21:11:48 +08:00
+import com.mojang.authlib.Environment;
2018-05-11 11:01:52 +08:00
+import com.mojang.authlib.ProfileLookupCallback;
+import com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService;
+import com.mojang.authlib.yggdrasil.YggdrasilGameProfileRepository;
+
+public class PaperGameProfileRepository extends YggdrasilGameProfileRepository {
2020-06-25 21:11:48 +08:00
+ public PaperGameProfileRepository(YggdrasilAuthenticationService authenticationService, Environment environment) {
+ super(authenticationService, environment);
2018-05-11 11:01:52 +08:00
+ }
+
+ @Override
+ public void findProfilesByNames(String[] names, Agent agent, ProfileLookupCallback callback) {
+ super.findProfilesByNames(names, agent, callback);
+ }
+}
diff --git a/src/main/java/com/destroystokyo/paper/profile/PaperMinecraftSessionService.java b/src/main/java/com/destroystokyo/paper/profile/PaperMinecraftSessionService.java
new file mode 100644
2020-06-25 21:11:48 +08:00
index 0000000000000000000000000000000000000000..93d73c27340645c7502acafdc0b2cfbc1a759dd8
2018-05-11 11:01:52 +08:00
--- /dev/null
+++ b/src/main/java/com/destroystokyo/paper/profile/PaperMinecraftSessionService.java
2020-06-25 21:11:48 +08:00
@@ -0,0 +1,30 @@
2018-05-11 11:01:52 +08:00
+package com.destroystokyo.paper.profile;
+
2020-06-25 21:11:48 +08:00
+import com.mojang.authlib.Environment;
2018-05-11 11:01:52 +08:00
+import com.mojang.authlib.GameProfile;
+import com.mojang.authlib.minecraft.MinecraftProfileTexture;
+import com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService;
+import com.mojang.authlib.yggdrasil.YggdrasilMinecraftSessionService;
+
+import java.util.Map;
+
+public class PaperMinecraftSessionService extends YggdrasilMinecraftSessionService {
2020-06-25 21:11:48 +08:00
+ protected PaperMinecraftSessionService(YggdrasilAuthenticationService authenticationService, Environment environment) {
+ super(authenticationService, environment);
2018-05-11 11:01:52 +08:00
+ }
+
+ @Override
+ public Map<MinecraftProfileTexture.Type, MinecraftProfileTexture> getTextures(GameProfile profile, boolean requireSecure) {
+ return super.getTextures(profile, requireSecure);
+ }
+
+ @Override
+ public GameProfile fillProfileProperties(GameProfile profile, boolean requireSecure) {
+ return super.fillProfileProperties(profile, requireSecure);
+ }
+
+ @Override
+ protected GameProfile fillGameProfile(GameProfile profile, boolean requireSecure) {
+ return super.fillGameProfile(profile, requireSecure);
+ }
+}
diff --git a/src/main/java/com/destroystokyo/paper/profile/PaperUserAuthentication.java b/src/main/java/com/destroystokyo/paper/profile/PaperUserAuthentication.java
new file mode 100644
2020-11-03 10:22:15 +08:00
index 0000000000000000000000000000000000000000..3cdd06d3af7ff94f1fe1a11b9a9275e17c695a38
2018-05-11 11:01:52 +08:00
--- /dev/null
+++ b/src/main/java/com/destroystokyo/paper/profile/PaperUserAuthentication.java
2020-11-03 10:22:15 +08:00
@@ -0,0 +1,12 @@
2018-05-11 11:01:52 +08:00
+package com.destroystokyo.paper.profile;
+
+import com.mojang.authlib.Agent;
+import com.mojang.authlib.yggdrasil.YggdrasilAuthenticationService;
+import com.mojang.authlib.yggdrasil.YggdrasilUserAuthentication;
2020-11-03 10:22:15 +08:00
+import java.util.UUID;
2018-05-11 11:01:52 +08:00
+
+public class PaperUserAuthentication extends YggdrasilUserAuthentication {
+ public PaperUserAuthentication(YggdrasilAuthenticationService authenticationService, Agent agent) {
2020-11-03 10:22:15 +08:00
+ super(authenticationService, UUID.randomUUID().toString(), agent);
2018-05-11 11:01:52 +08:00
+ }
+}
2018-01-19 13:12:03 +08:00
diff --git a/src/main/java/net/minecraft/server/MCUtil.java b/src/main/java/net/minecraft/server/MCUtil.java
2021-03-16 15:19:45 +08:00
index 18b56b59fd6efd618e6ff6f9cf3a02f57588d244..cd7dc7d90efddb8a1bb50cd964b43d18cf9c83d1 100644
2018-01-19 13:12:03 +08:00
--- a/src/main/java/net/minecraft/server/MCUtil.java
+++ b/src/main/java/net/minecraft/server/MCUtil.java
2021-03-16 15:19:45 +08:00
@@ -1,6 +1,8 @@
2018-01-19 13:12:03 +08:00
package net.minecraft.server;
2018-09-04 07:59:54 +08:00
import com.destroystokyo.paper.block.TargetBlockInfo;
2018-01-19 13:12:03 +08:00
+import com.destroystokyo.paper.profile.CraftPlayerProfile;
+import com.destroystokyo.paper.profile.PlayerProfile;
import com.google.common.util.concurrent.ThreadFactoryBuilder;
2020-08-25 10:22:08 +08:00
import it.unimi.dsi.fastutil.objects.ObjectRBTreeSet;
2021-03-16 15:19:45 +08:00
import net.minecraft.core.BlockPosition;
@@ -11,6 +13,7 @@ import net.minecraft.world.level.ChunkCoordIntPair;
import net.minecraft.world.level.RayTrace;
import net.minecraft.world.level.World;
2018-01-19 13:12:03 +08:00
import org.apache.commons.lang.exception.ExceptionUtils;
2020-05-23 07:03:48 +08:00
+import com.mojang.authlib.GameProfile;
2018-01-19 13:12:03 +08:00
import org.bukkit.Location;
2018-09-04 07:59:54 +08:00
import org.bukkit.block.BlockFace;
2020-05-23 07:03:48 +08:00
import org.bukkit.craftbukkit.CraftWorld;
2021-03-16 15:19:45 +08:00
@@ -345,6 +348,10 @@ public final class MCUtil {
2018-01-19 13:12:03 +08:00
return run.get();
}
+ public static PlayerProfile toBukkit(GameProfile profile) {
2018-01-19 13:38:49 +08:00
+ return CraftPlayerProfile.asBukkitMirror(profile);
2018-01-19 13:12:03 +08:00
+ }
+
/**
* Calculates distance between 2 entities
* @param e1
2020-06-25 21:11:48 +08:00
diff --git a/src/main/java/net/minecraft/server/Main.java b/src/main/java/net/minecraft/server/Main.java
2021-03-16 15:19:45 +08:00
index 89db31061fcc3420bc8e668533a4051cdbd12253..191a74bd9b894f9d64d0a55747cb17e07ceef597 100644
2020-06-25 21:11:48 +08:00
--- a/src/main/java/net/minecraft/server/Main.java
+++ b/src/main/java/net/minecraft/server/Main.java
2021-03-16 15:19:45 +08:00
@@ -132,7 +132,7 @@ public class Main {
2020-06-25 21:11:48 +08:00
}
File file = (File) optionset.valueOf("universe"); // CraftBukkit
2020-11-03 10:22:15 +08:00
- YggdrasilAuthenticationService yggdrasilauthenticationservice = new YggdrasilAuthenticationService(Proxy.NO_PROXY);
+ YggdrasilAuthenticationService yggdrasilauthenticationservice = new com.destroystokyo.paper.profile.PaperAuthenticationService(Proxy.NO_PROXY); // Paper
2018-05-11 11:01:52 +08:00
MinecraftSessionService minecraftsessionservice = yggdrasilauthenticationservice.createMinecraftSessionService();
GameProfileRepository gameprofilerepository = yggdrasilauthenticationservice.createProfileRepository();
2020-06-25 21:11:48 +08:00
UserCache usercache = new UserCache(gameprofilerepository, new File(file, MinecraftServer.b.getName()));
2021-03-16 15:19:45 +08:00
diff --git a/src/main/java/net/minecraft/server/players/UserCache.java b/src/main/java/net/minecraft/server/players/UserCache.java
2021-05-05 10:54:42 +08:00
index b9f94f957dd5372c8b02d785204690e4ade36a98..692d95c94df85d752a3ddc66e1f2af765565b160 100644
2021-03-16 15:19:45 +08:00
--- a/src/main/java/net/minecraft/server/players/UserCache.java
+++ b/src/main/java/net/minecraft/server/players/UserCache.java
2021-04-07 13:17:32 +08:00
@@ -45,7 +45,7 @@ public class UserCache {
2018-03-26 09:50:46 +08:00
2020-08-25 10:22:08 +08:00
private static final Logger LOGGER = LogManager.getLogger();
private static boolean b;
- private final Map<String, UserCache.UserCacheEntry> c = Maps.newConcurrentMap();
+ private final Map<String, UserCache.UserCacheEntry> c = Maps.newConcurrentMap();private final Map<String, UserCache.UserCacheEntry> nameCache = c; // Paper - OBFHELPER // Paper
private final Map<UUID, UserCache.UserCacheEntry> d = Maps.newConcurrentMap();
private final GameProfileRepository e;
private final Gson f = (new GsonBuilder()).create();
2021-05-05 10:54:42 +08:00
@@ -110,6 +110,7 @@ public class UserCache {
return com.destroystokyo.paper.PaperConfig.isProxyOnlineMode(); // Paper
2020-06-20 09:32:42 +08:00
}
+ public void saveProfile(GameProfile gameprofile) { a(gameprofile); } // Paper - OBFHELPER
2020-08-25 10:22:08 +08:00
public synchronized void a(GameProfile gameprofile) { // Paper - synchronize
Calendar calendar = Calendar.getInstance();
2021-05-05 10:54:42 +08:00
@@ -159,6 +160,13 @@ public class UserCache {
2020-08-25 10:22:08 +08:00
return gameprofile;
2018-03-26 09:50:46 +08:00
}
+ // Paper start
+ @Nullable public GameProfile getProfileIfCached(String name) {
+ UserCache.UserCacheEntry entry = this.nameCache.get(name.toLowerCase(Locale.ROOT));
+ return entry == null ? null : entry.getProfile();
+ }
+ // Paper end
+
@Nullable
2019-12-12 07:43:22 +08:00
public GameProfile getProfile(UUID uuid) {
2020-08-25 10:22:08 +08:00
UserCache.UserCacheEntry usercache_usercacheentry = (UserCache.UserCacheEntry) this.d.get(uuid);
2021-05-05 10:54:42 +08:00
@@ -341,7 +349,7 @@ public class UserCache {
2018-03-26 09:50:46 +08:00
2020-08-25 10:22:08 +08:00
static class UserCacheEntry {
2018-03-26 09:50:46 +08:00
2020-08-25 10:22:08 +08:00
- private final GameProfile a;
+ private final GameProfile a;public GameProfile getProfile() { return a; } // Paper - OBFHELPER
private final Date b;
private volatile long c;
2018-03-26 09:50:46 +08:00
2018-01-16 11:13:17 +08:00
diff --git a/src/main/java/org/bukkit/craftbukkit/CraftServer.java b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2021-05-12 16:07:08 +08:00
index 92c68becf45d83dbc18d3a9c1f86f8aa308e0d87..c8ea7b8ad46ce0fab794b897b5f3fe414a679387 100644
2018-01-16 11:13:17 +08:00
--- a/src/main/java/org/bukkit/craftbukkit/CraftServer.java
+++ b/src/main/java/org/bukkit/craftbukkit/CraftServer.java
2021-02-22 04:55:01 +08:00
@@ -227,6 +227,9 @@ import org.yaml.snakeyaml.error.MarkedYAMLException;
2019-04-27 14:26:04 +08:00
import net.md_5.bungee.api.chat.BaseComponent; // Spigot
2018-01-16 11:13:17 +08:00
+import javax.annotation.Nullable; // Paper
+import javax.annotation.Nonnull; // Paper
+
public final class CraftServer implements Server {
2018-07-18 08:08:13 +08:00
private final String serverName = "Paper"; // Paper
2018-01-16 11:13:17 +08:00
private final String serverVersion;
2021-05-12 16:07:08 +08:00
@@ -2317,5 +2320,24 @@ public final class CraftServer implements Server {
2018-01-16 11:13:17 +08:00
public boolean suggestPlayerNamesWhenNullTabCompletions() {
return com.destroystokyo.paper.PaperConfig.suggestPlayersWhenNullTabCompletions;
}
+
2019-04-27 14:26:04 +08:00
+ @Override
2018-01-16 11:13:17 +08:00
+ public com.destroystokyo.paper.profile.PlayerProfile createProfile(@Nonnull UUID uuid) {
+ return createProfile(uuid, null);
+ }
+
2019-04-27 14:26:04 +08:00
+ @Override
2018-01-16 11:13:17 +08:00
+ public com.destroystokyo.paper.profile.PlayerProfile createProfile(@Nonnull String name) {
+ return createProfile(null, name);
+ }
+
2019-04-27 14:26:04 +08:00
+ @Override
2018-01-16 11:13:17 +08:00
+ public com.destroystokyo.paper.profile.PlayerProfile createProfile(@Nullable UUID uuid, @Nullable String name) {
2018-03-22 13:28:22 +08:00
+ Player player = uuid != null ? Bukkit.getPlayer(uuid) : (name != null ? Bukkit.getPlayerExact(name) : null);
+ if (player != null) {
+ return new com.destroystokyo.paper.profile.CraftPlayerProfile((CraftPlayer)player);
+ }
2018-01-19 13:03:09 +08:00
+ return new com.destroystokyo.paper.profile.CraftPlayerProfile(uuid, name);
2018-01-16 11:13:17 +08:00
+ }
// Paper end
}
2020-06-20 09:32:42 +08:00
diff --git a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
2021-03-16 15:19:45 +08:00
index dff67a48961399f3746f99b4f2363724bfe51c36..8298ae9bf1c5635f08552c15f004b3d0f6e9f19b 100644
2020-06-20 09:32:42 +08:00
--- a/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
+++ b/src/main/java/org/bukkit/craftbukkit/inventory/CraftMetaSkull.java
2021-03-09 07:12:31 +08:00
@@ -80,6 +80,13 @@ class CraftMetaSkull extends CraftMetaItem implements SkullMeta {
2020-06-20 09:32:42 +08:00
}
private void setProfile(GameProfile profile) {
+ // Paper start
2020-06-22 10:59:34 +08:00
+ if (profile != null) {
+ com.destroystokyo.paper.profile.CraftPlayerProfile paperProfile = new com.destroystokyo.paper.profile.CraftPlayerProfile(profile);
2020-06-23 16:53:02 +08:00
+ paperProfile.completeFromCache(false, true);
2020-06-22 10:59:34 +08:00
+ profile = paperProfile.getGameProfile();
+ }
2020-06-20 09:32:42 +08:00
+ // Paper end
this.profile = profile;
this.serializedProfile = (profile == null) ? null : GameProfileSerializer.serialize(new NBTTagCompound(), profile);
}