Added McMMOPlayerLoadedEvent firing after the profile was loaded from storage

This commit is contained in:
games647 2017-09-18 09:34:59 +02:00
parent 87ebf7023f
commit 6d37e0c8c6
No known key found for this signature in database
GPG Key ID: BFC68C8708713A88
2 changed files with 55 additions and 5 deletions

View File

@ -0,0 +1,41 @@
package com.gmail.nossr50.events;
import com.gmail.nossr50.datatypes.player.McMMOPlayer;
import org.bukkit.event.HandlerList;
import org.bukkit.event.player.PlayerEvent;
/**
* Called after the mcMMO player profile was successful loaded from data storage. This happens if the player recently
* joined the server or the data was reloaded (e.g. database convert, reset stats, convert experience)
* while the player is online.
*/
public class McMMOPlayerLoadedEvent extends PlayerEvent {
private final McMMOPlayer mcMMOPlayer;
public McMMOPlayerLoadedEvent(McMMOPlayer mcMMOPlayer) {
super(mcMMOPlayer.getPlayer());
this.mcMMOPlayer = mcMMOPlayer;
}
/**
* @return mcMMO player profile associated to the player
*/
public McMMOPlayer getMcMMOPlayer() {
return mcMMOPlayer;
}
/** Rest of file is required boilerplate for custom events **/
private static final HandlerList handlers = new HandlerList();
@Override
public HandlerList getHandlers() {
return handlers;
}
public static HandlerList getHandlerList() {
return handlers;
}
}

View File

@ -1,19 +1,21 @@
package com.gmail.nossr50.runnables.player; package com.gmail.nossr50.runnables.player;
import org.bukkit.Server;
import org.bukkit.entity.Player;
import org.bukkit.scheduler.BukkitRunnable;
import com.gmail.nossr50.mcMMO;
import com.gmail.nossr50.config.Config; import com.gmail.nossr50.config.Config;
import com.gmail.nossr50.datatypes.player.McMMOPlayer; import com.gmail.nossr50.datatypes.player.McMMOPlayer;
import com.gmail.nossr50.datatypes.player.PlayerProfile; import com.gmail.nossr50.datatypes.player.PlayerProfile;
import com.gmail.nossr50.events.McMMOPlayerLoadedEvent;
import com.gmail.nossr50.locale.LocaleLoader; import com.gmail.nossr50.locale.LocaleLoader;
import com.gmail.nossr50.mcMMO;
import com.gmail.nossr50.runnables.commands.McScoreboardKeepTask; import com.gmail.nossr50.runnables.commands.McScoreboardKeepTask;
import com.gmail.nossr50.util.Misc; import com.gmail.nossr50.util.Misc;
import com.gmail.nossr50.util.player.UserManager; import com.gmail.nossr50.util.player.UserManager;
import com.gmail.nossr50.util.scoreboards.ScoreboardManager; import com.gmail.nossr50.util.scoreboards.ScoreboardManager;
import org.bukkit.Bukkit;
import org.bukkit.Server;
import org.bukkit.entity.Player;
import org.bukkit.scheduler.BukkitRunnable;
public class PlayerProfileLoadingTask extends BukkitRunnable { public class PlayerProfileLoadingTask extends BukkitRunnable {
private static final int MAX_TRIES = 5; private static final int MAX_TRIES = 5;
private final Player player; private final Player player;
@ -87,6 +89,13 @@ public class PlayerProfileLoadingTask extends BukkitRunnable {
ScoreboardManager.enablePlayerStatsScoreboard(player); ScoreboardManager.enablePlayerStatsScoreboard(player);
new McScoreboardKeepTask(player).runTaskLater(mcMMO.p, 1 * Misc.TICK_CONVERSION_FACTOR); new McScoreboardKeepTask(player).runTaskLater(mcMMO.p, 1 * Misc.TICK_CONVERSION_FACTOR);
} }
Bukkit.getScheduler().runTask(mcMMO.p, new Runnable() {
@Override
public void run() {
Bukkit.getPluginManager().callEvent(new McMMOPlayerLoadedEvent(mcMMOPlayer));
}
});
} }
} }
} }