PlayerProfileLoadingTask.java 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. package com.gmail.nossr50.runnables.player;
  2. import com.gmail.nossr50.config.Config;
  3. import com.gmail.nossr50.datatypes.player.McMMOPlayer;
  4. import com.gmail.nossr50.datatypes.player.PersistentPlayerData;
  5. import com.gmail.nossr50.datatypes.player.PersistentPlayerDataBuilder;
  6. import com.neetgames.mcmmo.player.MMOPlayerData;
  7. import com.neetgames.mcmmo.player.OnlineMMOPlayer;
  8. import com.gmail.nossr50.datatypes.player.PlayerProfile;
  9. import com.gmail.nossr50.locale.LocaleLoader;
  10. import com.gmail.nossr50.mcMMO;
  11. import com.gmail.nossr50.runnables.commands.McScoreboardKeepTask;
  12. import com.gmail.nossr50.util.EventUtils;
  13. import com.gmail.nossr50.util.Misc;
  14. import com.gmail.nossr50.util.scoreboards.ScoreboardManager;
  15. import org.bukkit.Server;
  16. import org.bukkit.entity.Player;
  17. import org.bukkit.scheduler.BukkitRunnable;
  18. public class PlayerProfileLoadingTask extends BukkitRunnable {
  19. private final Player player;
  20. private int attempt = 0;
  21. public PlayerProfileLoadingTask(Player player) {
  22. this.player = player;
  23. }
  24. private PlayerProfileLoadingTask(Player player, int attempt) {
  25. this.player = player;
  26. this.attempt = attempt;
  27. }
  28. // WARNING: ASYNC TASK
  29. // DO NOT MODIFY THE McMMOPLAYER FROM THIS CODE
  30. @Override
  31. public void run() {
  32. if (Misc.isNPCIncludingVillagers(player)) {
  33. return;
  34. }
  35. // Quit if they logged out
  36. if (!player.isOnline()) {
  37. mcMMO.p.getLogger().info("Aborting profile loading recovery for " + player.getName() + " - player logged out");
  38. return;
  39. }
  40. try {
  41. MMOPlayerData mmoPlayerData = mcMMO.getDatabaseManager().queryPlayerDataByPlayer(player);
  42. McMMOPlayer mmoPlayer = new McMMOPlayer(player, player.getUniqueId(), player.getName());
  43. new ApplySuccessfulProfile(new McMMOPlayer(player, )).runTask(mcMMO.p);
  44. EventUtils.callPlayerProfileLoadEvent(player, profile);
  45. return;
  46. } catch () {
  47. // Print errors to console/logs if we're failing at least 2 times in a row to load the profile
  48. if (attempt >= 3)
  49. {
  50. //Log the error
  51. mcMMO.p.getLogger().severe(LocaleLoader.getString("Profile.Loading.FailureNotice",
  52. player.getName(), String.valueOf(attempt)));
  53. //Notify the admins
  54. mcMMO.p.getServer().broadcast(LocaleLoader.getString("Profile.Loading.FailureNotice", player.getName()), Server.BROADCAST_CHANNEL_ADMINISTRATIVE);
  55. //Notify the player
  56. player.sendMessage(LocaleLoader.getString("Profile.Loading.FailurePlayer", String.valueOf(attempt)).split("\n"));
  57. }
  58. // Increment attempt counter and try
  59. attempt++;
  60. new PlayerProfileLoadingTask(player, attempt).runTaskLaterAsynchronously(mcMMO.p, (100 + (attempt * 100)));
  61. }
  62. }
  63. private class ApplySuccessfulProfile extends BukkitRunnable {
  64. private final McMMOPlayer mmoPlayer;
  65. private ApplySuccessfulProfile(McMMOPlayer mmoPlayer) {
  66. this.mmoPlayer = mmoPlayer;
  67. }
  68. // Synchronized task
  69. // No database access permitted
  70. @Override
  71. public void run() {
  72. if (!player.isOnline()) {
  73. mcMMO.p.getLogger().info("Aborting profile loading recovery for " + player.getName() + " - player logged out");
  74. return;
  75. }
  76. mcMMO.getUserManager().track(mmoPlayer);
  77. mmoPlayer.actualizeRespawnATS();
  78. if (Config.getInstance().getScoreboardsEnabled()) {
  79. ScoreboardManager.setupPlayer(player);
  80. if (Config.getInstance().getShowStatsAfterLogin()) {
  81. ScoreboardManager.enablePlayerStatsScoreboard(player);
  82. new McScoreboardKeepTask(player).runTaskLater(mcMMO.p, Misc.TICK_CONVERSION_FACTOR);
  83. }
  84. }
  85. if (Config.getInstance().getShowProfileLoadedMessage()) {
  86. player.sendMessage(LocaleLoader.getString("Profile.Loading.Success"));
  87. }
  88. }
  89. }
  90. }