Add a lot null-pointer checks and console errors about loading null-value element from database.

This commit is contained in:
BONNe 2019-06-03 23:14:12 +03:00
parent 7914f315f4
commit a9abe32dbe

View File

@ -175,7 +175,7 @@ public class ChallengesManager
* @param challenge Challenge that must be loaded. * @param challenge Challenge that must be loaded.
* @return true if successful * @return true if successful
*/ */
private void loadChallenge(Challenge challenge) private void loadChallenge(@NonNull Challenge challenge)
{ {
this.loadChallenge(challenge, true, null, true); this.loadChallenge(challenge, true, null, true);
} }
@ -190,11 +190,17 @@ public class ChallengesManager
* @param silent - if true, no messages are sent to user * @param silent - if true, no messages are sent to user
* @return - true if imported * @return - true if imported
*/ */
public boolean loadChallenge(Challenge challenge, public boolean loadChallenge(@NonNull Challenge challenge,
boolean overwrite, boolean overwrite,
User user, User user,
boolean silent) boolean silent)
{ {
if (challenge == null)
{
this.addon.logError("Tried to load NULL element from Database. One challenge is broken and will not work.");
return false;
}
if (this.challengeCacheData.containsKey(challenge.getUniqueId())) if (this.challengeCacheData.containsKey(challenge.getUniqueId()))
{ {
if (!overwrite) if (!overwrite)
@ -235,7 +241,7 @@ public class ChallengesManager
* *
* @param level the challenge level * @param level the challenge level
*/ */
private void loadLevel(ChallengeLevel level) private void loadLevel(@NonNull ChallengeLevel level)
{ {
this.loadLevel(level, true, null, true); this.loadLevel(level, true, null, true);
} }
@ -250,8 +256,14 @@ public class ChallengesManager
* @param silent of type boolean that indicate if message to user must be sent. * @param silent of type boolean that indicate if message to user must be sent.
* @return boolean that indicate about load status. * @return boolean that indicate about load status.
*/ */
public boolean loadLevel(ChallengeLevel level, boolean overwrite, User user, boolean silent) public boolean loadLevel(@NonNull ChallengeLevel level, boolean overwrite, User user, boolean silent)
{ {
if (level == null)
{
this.addon.logError("Tried to load NULL element from Database. One level is broken and will not work.");
return false;
}
if (!this.isValidLevel(level)) if (!this.isValidLevel(level))
{ {
if (user != null) if (user != null)
@ -306,7 +318,7 @@ public class ChallengesManager
* This method stores PlayerData into local cache. * This method stores PlayerData into local cache.
* @param playerData ChallengesPlayerData that must be loaded. * @param playerData ChallengesPlayerData that must be loaded.
*/ */
private void loadPlayerData(ChallengesPlayerData playerData) private void loadPlayerData(@NonNull ChallengesPlayerData playerData)
{ {
try try
{ {
@ -352,7 +364,7 @@ public class ChallengesManager
* @param level that must be validated * @param level that must be validated
* @return true ir level is valid, otherwise false. * @return true ir level is valid, otherwise false.
*/ */
private boolean isValidLevel(ChallengeLevel level) private boolean isValidLevel(@NonNull ChallengeLevel level)
{ {
if (!this.addon.getPlugin().getIWM().inWorld(Bukkit.getWorld(level.getWorld()))) if (!this.addon.getPlugin().getIWM().inWorld(Bukkit.getWorld(level.getWorld())))
{ {
@ -369,6 +381,7 @@ public class ChallengesManager
} }
else else
{ {
this.addon.logError("Cannot find " + uniqueID + " challenge for " + level.getUniqueId());
return false; return false;
} }
} }
@ -398,9 +411,17 @@ public class ChallengesManager
// Load player from database // Load player from database
ChallengesPlayerData data = this.playersDatabase.loadObject(uniqueID); ChallengesPlayerData data = this.playersDatabase.loadObject(uniqueID);
// Store in cache // Store in cache
if (data != null)
{
this.playerCacheData.put(uniqueID, data); this.playerCacheData.put(uniqueID, data);
} }
else else
{
this.addon.logError("Could not load NULL player data object.");
}
}
else
{ {
// Create the player data // Create the player data
ChallengesPlayerData pd = new ChallengesPlayerData(uniqueID); ChallengesPlayerData pd = new ChallengesPlayerData(uniqueID);
@ -1194,9 +1215,17 @@ public class ChallengesManager
if (this.challengeDatabase.objectExists(name)) if (this.challengeDatabase.objectExists(name))
{ {
Challenge challenge = this.challengeDatabase.loadObject(name); Challenge challenge = this.challengeDatabase.loadObject(name);
if (challenge != null)
{
this.challengeCacheData.put(name, challenge); this.challengeCacheData.put(name, challenge);
return challenge; return challenge;
} }
else
{
this.addon.logError("Tried to load NULL challenge object!");
}
}
} }
return null; return null;
@ -1221,9 +1250,17 @@ public class ChallengesManager
if (this.challengeDatabase.objectExists(name)) if (this.challengeDatabase.objectExists(name))
{ {
Challenge challenge = this.challengeDatabase.loadObject(name); Challenge challenge = this.challengeDatabase.loadObject(name);
if (challenge != null)
{
this.challengeCacheData.put(name, challenge); this.challengeCacheData.put(name, challenge);
return true; return true;
} }
else
{
this.addon.logError("Tried to load NULL challenge object!");
}
}
} }
return false; return false;
@ -1342,9 +1379,17 @@ public class ChallengesManager
if (this.levelDatabase.objectExists(name)) if (this.levelDatabase.objectExists(name))
{ {
ChallengeLevel level = this.levelDatabase.loadObject(name); ChallengeLevel level = this.levelDatabase.loadObject(name);
if (level != null)
{
this.levelCacheData.put(name, level); this.levelCacheData.put(name, level);
return level; return level;
} }
else
{
this.addon.logError("Tried to load NULL level.");
}
}
} }
return null; return null;
@ -1369,9 +1414,17 @@ public class ChallengesManager
if (this.levelDatabase.objectExists(name)) if (this.levelDatabase.objectExists(name))
{ {
ChallengeLevel level = this.levelDatabase.loadObject(name); ChallengeLevel level = this.levelDatabase.loadObject(name);
if (level != null)
{
this.levelCacheData.put(name, level); this.levelCacheData.put(name, level);
return true; return true;
} }
else
{
this.addon.logError("Tried to load NULL level.");
}
}
} }
return false; return false;