mirror of
https://github.com/PaperMC/Paper.git
synced 2025-03-13 19:28:03 +01:00
Profile Lookup Events
Adds a Pre Lookup Event and a Post Lookup Event so that plugins may prefill in profile data, and cache the responses from profiles that had to be looked up.
This commit is contained in:
parent
aab7ec1655
commit
a229776460
1 changed files with 44 additions and 1 deletions
|
@ -1,9 +1,14 @@
|
|||
package com.destroystokyo.paper.profile;
|
||||
|
||||
import com.destroystokyo.paper.event.profile.LookupProfileEvent;
|
||||
import com.destroystokyo.paper.event.profile.PreLookupProfileEvent;
|
||||
import com.google.common.collect.Sets;
|
||||
import com.mojang.authlib.Environment;
|
||||
import com.mojang.authlib.GameProfile;
|
||||
import com.mojang.authlib.ProfileLookupCallback;
|
||||
import com.mojang.authlib.yggdrasil.YggdrasilGameProfileRepository;
|
||||
import java.net.Proxy;
|
||||
import java.util.Set;
|
||||
|
||||
public class PaperGameProfileRepository extends YggdrasilGameProfileRepository {
|
||||
public PaperGameProfileRepository(Proxy proxy, Environment environment) {
|
||||
|
@ -12,6 +17,44 @@ public class PaperGameProfileRepository extends YggdrasilGameProfileRepository {
|
|||
|
||||
@Override
|
||||
public void findProfilesByNames(String[] names, ProfileLookupCallback callback) {
|
||||
super.findProfilesByNames(names, callback);
|
||||
Set<String> unfoundNames = Sets.newHashSet();
|
||||
for (String name : names) {
|
||||
PreLookupProfileEvent event = new PreLookupProfileEvent(name);
|
||||
event.callEvent();
|
||||
if (event.getUUID() != null) {
|
||||
// Plugin provided UUID, we can skip network call.
|
||||
GameProfile gameprofile = new GameProfile(event.getUUID(), name);
|
||||
// We might even have properties!
|
||||
Set<ProfileProperty> profileProperties = event.getProfileProperties();
|
||||
if (!profileProperties.isEmpty()) {
|
||||
for (ProfileProperty property : profileProperties) {
|
||||
gameprofile.getProperties().put(property.getName(), CraftPlayerProfile.asAuthlib(property));
|
||||
}
|
||||
}
|
||||
callback.onProfileLookupSucceeded(gameprofile);
|
||||
} else {
|
||||
unfoundNames.add(name);
|
||||
}
|
||||
}
|
||||
|
||||
// Some things were not found.... Proceed to look up.
|
||||
if (!unfoundNames.isEmpty()) {
|
||||
String[] namesArr = unfoundNames.toArray(new String[unfoundNames.size()]);
|
||||
super.findProfilesByNames(namesArr, new PreProfileLookupCallback(callback));
|
||||
}
|
||||
}
|
||||
|
||||
private record PreProfileLookupCallback(ProfileLookupCallback callback) implements ProfileLookupCallback {
|
||||
@Override
|
||||
public void onProfileLookupSucceeded(GameProfile gameProfile) {
|
||||
PlayerProfile from = CraftPlayerProfile.asBukkitMirror(gameProfile);
|
||||
new LookupProfileEvent(from).callEvent();
|
||||
this.callback.onProfileLookupSucceeded(gameProfile);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onProfileLookupFailed(final String profileName, final Exception exception) {
|
||||
this.callback.onProfileLookupFailed(profileName, exception);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue