-
-
Notifications
You must be signed in to change notification settings - Fork 32
Added support for getOfflinePlayer(String) with optional cache #35
base: master
Are you sure you want to change the base?
Added support for getOfflinePlayer(String) with optional cache #35
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Couple of things plus you're missing the helper method in the PaperLib class (and its javadocs)
src/main/java/io/papermc/lib/features/offlineplayers/GetOfflinePlayerCachedOption.java
Outdated
Show resolved
Hide resolved
src/main/java/io/papermc/lib/environments/PaperEnvironment.java
Outdated
Show resolved
Hide resolved
src/main/java/io/papermc/lib/features/offlineplayers/GetOfflinePlayerNoCacheOption.java
Outdated
Show resolved
Hide resolved
@Override | ||
@Nullable | ||
public OfflinePlayer getOfflinePlayer(@Nonnull String name, boolean makeWebRequest) { | ||
return Bukkit.getOfflinePlayer(name); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
reflection can be used here to check if the profile cache returns null for the given username (UserCache#c#get
mapping has been consistent since 1.8.8). That way the makeWebRequest
parameter can be respected even if we're on spigot.
(core team may have input on this)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hmm, that would certainly be a neat idea.
I will look into it but also wait and see what others think about this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So I had a look into it and UserCache#c
seems to refer to a static boolean on Spigot 1.16.4 (tested using git-Spigot-05da6fa-b0c6dfe
).
So unless, that was a typo the mapping does not seem to be as consistent as expected.
The actual Map<String, UserCacheEntry>
is found under UserCache#d
on the build I investigated.
There is a UserCache#getProfile(String)
method though, which returns a nullable GameProfile for a given username from the cache (unless expired).
I would need to look up how long this method existed though.
Update: UserCache#getProfile(String)
has been consistent since CB 1.8 (said class did not exist prior to 1.8). Invoking that method using reflection is definitely our safest option to implement this in a non-Paper environment.
What do you think?
* Added static helper method to PaperLib * Renamed implementation classes
Thanks for the input!
Whoops, I somehow completely forgot about that, thanks for spotting it. |
PaperMC/Paper#4687 has introduced the ability to get an
OfflinePlayer
by their name without making a web request.To properly utilise this feature in a Spigot-compatible environment, we currently need to rely on an
isPaper
and a version check to even see whether one is able to optimize for that.I think this is a perfect opportunity for a
PaperLib
implementation.This is just a basic implementation which was done in a similar manner to how the
BlockStateSnapshot
is handled.The boolean
makeWebRequest
determines whether a web request is allowed. In environments that do not supportBukkit.getOfflinePlayerIfCached()
, this boolean is just ignored. Similar to howBlockStateSnapshot
will ignore theuseSnapshot
boolean if unsupported.Of course, the
Bukkit.getOfflinePlayerIfCached()
method will not be available in every single 1.16.4-compatible build of Paper I presume, but I am gonna assume the typical "old versions are not supported anyway" situation here for now.Lemme know if there is anything that should be changed or documented.