mirror of
https://github.com/DiscordSRV/Ascension.git
synced 2025-01-06 19:09:18 +01:00
Merge profile loading into PlayerProvider
This commit is contained in:
parent
b588dc185a
commit
824a392414
@ -31,7 +31,6 @@ import com.discordsrv.bukkit.config.manager.BukkitConfigManager;
|
|||||||
import com.discordsrv.bukkit.config.manager.BukkitConnectionConfigManager;
|
import com.discordsrv.bukkit.config.manager.BukkitConnectionConfigManager;
|
||||||
import com.discordsrv.bukkit.config.manager.BukkitMessagesConfigManager;
|
import com.discordsrv.bukkit.config.manager.BukkitMessagesConfigManager;
|
||||||
import com.discordsrv.bukkit.console.BukkitConsole;
|
import com.discordsrv.bukkit.console.BukkitConsole;
|
||||||
import com.discordsrv.bukkit.listener.BukkitConnectionListener;
|
|
||||||
import com.discordsrv.bukkit.listener.BukkitDeathListener;
|
import com.discordsrv.bukkit.listener.BukkitDeathListener;
|
||||||
import com.discordsrv.bukkit.listener.BukkitStatusMessageListener;
|
import com.discordsrv.bukkit.listener.BukkitStatusMessageListener;
|
||||||
import com.discordsrv.bukkit.listener.award.BukkitAwardForwarder;
|
import com.discordsrv.bukkit.listener.award.BukkitAwardForwarder;
|
||||||
@ -222,9 +221,6 @@ public class BukkitDiscordSRV extends AbstractDiscordSRV<DiscordSRVBukkitBootstr
|
|||||||
server().getPluginManager().registerEvents(BukkitChatForwarder.get(this), plugin());
|
server().getPluginManager().registerEvents(BukkitChatForwarder.get(this), plugin());
|
||||||
server().getPluginManager().registerEvents(new BukkitDeathListener(this), plugin());
|
server().getPluginManager().registerEvents(new BukkitDeathListener(this), plugin());
|
||||||
server().getPluginManager().registerEvents(new BukkitStatusMessageListener(this), plugin());
|
server().getPluginManager().registerEvents(new BukkitStatusMessageListener(this), plugin());
|
||||||
|
|
||||||
// Connection listener
|
|
||||||
server().getPluginManager().registerEvents(new BukkitConnectionListener(this), plugin());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,76 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of DiscordSRV, licensed under the GPLv3 License
|
|
||||||
* Copyright (c) 2016-2024 Austin "Scarsz" Shapiro, Henri "Vankka" Schubin and DiscordSRV contributors
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package com.discordsrv.bukkit.listener;
|
|
||||||
|
|
||||||
import com.discordsrv.bukkit.BukkitDiscordSRV;
|
|
||||||
import org.bukkit.entity.Player;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.EventPriority;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.player.PlayerJoinEvent;
|
|
||||||
import org.bukkit.event.player.PlayerLoginEvent;
|
|
||||||
import org.bukkit.event.player.PlayerQuitEvent;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public class BukkitConnectionListener implements Listener {
|
|
||||||
|
|
||||||
private final BukkitDiscordSRV discordSRV;
|
|
||||||
|
|
||||||
public BukkitConnectionListener(BukkitDiscordSRV discordSRV) {
|
|
||||||
this.discordSRV = discordSRV;
|
|
||||||
|
|
||||||
// Load players who joined before this listener was created
|
|
||||||
for (Player onlinePlayer : discordSRV.server().getOnlinePlayers()) {
|
|
||||||
discordSRV.profileManager().loadProfile(onlinePlayer.getUniqueId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.NORMAL)
|
|
||||||
public void onPlayerLoginNormal(PlayerLoginEvent event) {
|
|
||||||
if (event.getResult() != PlayerLoginEvent.Result.ALLOWED) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
discordSRV.profileManager().loadProfile(event.getPlayer().getUniqueId());
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR)
|
|
||||||
public void onPlayerLoginMonitor(PlayerLoginEvent event) {
|
|
||||||
if (event.getResult() != PlayerLoginEvent.Result.ALLOWED) {
|
|
||||||
// Unload in case got blocked after NORMAL
|
|
||||||
discordSRV.profileManager().unloadProfile(event.getPlayer().getUniqueId());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.LOWEST)
|
|
||||||
public void onPlayerJoin(PlayerJoinEvent event) {
|
|
||||||
UUID playerUUID = event.getPlayer().getUniqueId();
|
|
||||||
if (discordSRV.profileManager().getProfile(playerUUID) == null) {
|
|
||||||
// Not loaded in yet (offline mode)
|
|
||||||
// No blocking since this runs on main thread
|
|
||||||
discordSRV.profileManager().loadProfile(playerUUID);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR)
|
|
||||||
public void onPlayerQuit(PlayerQuitEvent event) {
|
|
||||||
discordSRV.profileManager().unloadProfile(event.getPlayer().getUniqueId());
|
|
||||||
}
|
|
||||||
}
|
|
@ -850,6 +850,7 @@ public abstract class AbstractDiscordSRV<
|
|||||||
|
|
||||||
if (flags.contains(ReloadFlag.LINKED_ACCOUNT_PROVIDER)) {
|
if (flags.contains(ReloadFlag.LINKED_ACCOUNT_PROVIDER)) {
|
||||||
LinkedAccountConfig linkedAccountConfig = config().linkedAccounts;
|
LinkedAccountConfig linkedAccountConfig = config().linkedAccounts;
|
||||||
|
boolean linkProviderMissing = linkProvider == null;
|
||||||
if (linkedAccountConfig != null && linkedAccountConfig.enabled) {
|
if (linkedAccountConfig != null && linkedAccountConfig.enabled) {
|
||||||
LinkedAccountConfig.Provider provider = linkedAccountConfig.provider;
|
LinkedAccountConfig.Provider provider = linkedAccountConfig.provider;
|
||||||
boolean permitMinecraftAuth = connectionConfig().minecraftAuth.allow;
|
boolean permitMinecraftAuth = connectionConfig().minecraftAuth.allow;
|
||||||
@ -883,6 +884,10 @@ public abstract class AbstractDiscordSRV<
|
|||||||
linkProvider = null;
|
linkProvider = null;
|
||||||
logger().info("Linked accounts are disabled");
|
logger().info("Linked accounts are disabled");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (linkProviderMissing && linkProvider != null) {
|
||||||
|
playerProvider().loadAllProfilesAsync();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flags.contains(ReloadFlag.DISCORD_CONNECTION)) {
|
if (flags.contains(ReloadFlag.DISCORD_CONNECTION)) {
|
||||||
|
@ -70,6 +70,8 @@ public abstract class AbstractPlayerProvider<T extends IPlayer, DT extends Disco
|
|||||||
this.allPlayers.add(player);
|
this.allPlayers.add(player);
|
||||||
discordSRV.scheduler().run(() -> discordSRV.eventBus().publish(new PlayerConnectedEvent(player, initial)));
|
discordSRV.scheduler().run(() -> discordSRV.eventBus().publish(new PlayerConnectedEvent(player, initial)));
|
||||||
|
|
||||||
|
discordSRV.profileManager().loadProfile(player.uniqueId());
|
||||||
|
|
||||||
if (UUIDUtil.isOffline(uuid)) {
|
if (UUIDUtil.isOffline(uuid)) {
|
||||||
anyOffline.set(true);
|
anyOffline.set(true);
|
||||||
}
|
}
|
||||||
@ -81,6 +83,8 @@ public abstract class AbstractPlayerProvider<T extends IPlayer, DT extends Disco
|
|||||||
allPlayers.remove(player);
|
allPlayers.remove(player);
|
||||||
discordSRV.scheduler().run(() -> discordSRV.eventBus().publish(new PlayerDisconnectedEvent(player)));
|
discordSRV.scheduler().run(() -> discordSRV.eventBus().publish(new PlayerDisconnectedEvent(player)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
discordSRV.profileManager().unloadProfile(uuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -103,6 +107,13 @@ public abstract class AbstractPlayerProvider<T extends IPlayer, DT extends Disco
|
|||||||
return allPlayers;
|
return allPlayers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void loadAllProfilesAsync() {
|
||||||
|
for (T player : allPlayers()) {
|
||||||
|
discordSRV.profileManager().loadProfile(player.uniqueId());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<UUID> lookupUUIDForUsername(String username) {
|
public CompletableFuture<UUID> lookupUUIDForUsername(String username) {
|
||||||
IPlayer player = player(username);
|
IPlayer player = player(username);
|
||||||
|
@ -54,6 +54,8 @@ public interface PlayerProvider<T extends IPlayer> extends IPlayerProvider {
|
|||||||
@NotNull
|
@NotNull
|
||||||
Collection<T> allPlayers();
|
Collection<T> allPlayers();
|
||||||
|
|
||||||
|
void loadAllProfilesAsync();
|
||||||
|
|
||||||
CompletableFuture<UUID> lookupUUIDForUsername(String username);
|
CompletableFuture<UUID> lookupUUIDForUsername(String username);
|
||||||
|
|
||||||
default CompletableFuture<IOfflinePlayer> lookupOfflinePlayer(String username) {
|
default CompletableFuture<IOfflinePlayer> lookupOfflinePlayer(String username) {
|
||||||
|
@ -20,6 +20,7 @@ package com.discordsrv.common.feature.profile;
|
|||||||
|
|
||||||
import com.discordsrv.api.profile.IProfileManager;
|
import com.discordsrv.api.profile.IProfileManager;
|
||||||
import com.discordsrv.common.DiscordSRV;
|
import com.discordsrv.common.DiscordSRV;
|
||||||
|
import com.discordsrv.common.feature.linking.LinkProvider;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@ -49,6 +50,7 @@ public class ProfileManager implements IProfileManager {
|
|||||||
return profile;
|
return profile;
|
||||||
});
|
});
|
||||||
profileLookups.put(playerUUID, lookup);
|
profileLookups.put(playerUUID, lookup);
|
||||||
|
lookup.whenComplete((__, ___) -> profileLookups.remove(playerUUID));
|
||||||
return lookup;
|
return lookup;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -70,7 +72,9 @@ public class ProfileManager implements IProfileManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull CompletableFuture<Profile> lookupProfile(UUID playerUUID) {
|
public @NotNull CompletableFuture<Profile> lookupProfile(UUID playerUUID) {
|
||||||
return discordSRV.linkProvider().getUserId(playerUUID)
|
LinkProvider linkProvider = discordSRV.linkProvider();
|
||||||
|
if (linkProvider == null) return CompletableFuture.completedFuture(null);
|
||||||
|
return linkProvider.getUserId(playerUUID)
|
||||||
.thenApply(opt -> new Profile(playerUUID, opt.orElse(null)));
|
.thenApply(opt -> new Profile(playerUUID, opt.orElse(null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -81,7 +85,9 @@ public class ProfileManager implements IProfileManager {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull CompletableFuture<Profile> lookupProfile(long userId) {
|
public @NotNull CompletableFuture<Profile> lookupProfile(long userId) {
|
||||||
return discordSRV.linkProvider().getPlayerUUID(userId)
|
LinkProvider linkProvider = discordSRV.linkProvider();
|
||||||
|
if (linkProvider == null) return CompletableFuture.completedFuture(null);
|
||||||
|
return linkProvider.getPlayerUUID(userId)
|
||||||
.thenApply(opt -> new Profile(opt.orElse(null), userId));
|
.thenApply(opt -> new Profile(opt.orElse(null), userId));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user