Interface PlayerDataAPI
-
Method Summary
Modifier and TypeMethodDescriptionFetches all uuids of players that are known for this plugin.void
fetchLeaderboard
(PlayerStatSet statSet, int minRank, int maxRank, Consumer<LeaderboardFetchResult> callback) Fetches players at the given ranks at the leaderboard.void
fetchLeaderboardPosition
(UUID playerUUID, PlayerStatSet statSet, Consumer<Integer> callback) Fetches the position of a player on the leaderboard.default void
fetchLeaderboardPosition
(OfflinePlayer player, PlayerStatSet statSet, Consumer<Integer> callback) Fetches the position of a player on the leaderboard.static PlayerDataAPI
get()
Returns the global PlayerDataAPI instance.void
getAchievements
(UUID id, Consumer<PlayerAchievements> callback) Tries to fetch the achievement info of the player.default void
getAchievements
(OfflinePlayer player, Consumer<PlayerAchievements> callback) Tries to fetch the achievements info of the player.Tries to get achievements from the cache.default Optional
<PlayerAchievements> getAchievementsCached
(OfflinePlayer player) Tries to get achievements from the cache.@Nullable PlayerAchievement
Get an achievement by its id.Gets a collection of all currently cached properties achievements.Gets a collection of all currently cached player properties.Gets a collection of all currently cached player stats.void
getProperties
(UUID id, Consumer<PlayerProperties> callback) Tries to fetch the properties of the player.default void
getProperties
(OfflinePlayer player, Consumer<PlayerProperties> callback) Tries to fetch the properties of the player.Tries to get properties from the cache.default Optional
<PlayerProperties> getPropertiesCached
(OfflinePlayer player) Tries to get properties from the cache.Get all existing achievements.Returns all registered data sets for stats.void
getStats
(UUID id, Consumer<PlayerStats> callback) Tries to fetch the stats of the player.default void
getStats
(OfflinePlayer player, Consumer<PlayerStats> callback) Tries to fetch the stats of the player.void
getStatsByName
(String name, Consumer<Optional<PlayerStats>> callback) Tries to fetch the stats of the player given by its name.getStatsCached
(UUID id) Tries to get stats from the cache.default Optional
<PlayerStats> getStatsCached
(OfflinePlayer player) Tries to get stats from the cache.Searches for the data set with that id and returns it.@Nullable PlayerStatSet
getStatsSet
(String id) Returns the stats set with the given id.void
getUUIDByName
(String username, Consumer<Optional<UUID>> callback) Tries to look-up the UUID of a player by its name in the database.boolean
Returns whether the plugin is currently connected to a SQL database.@Nullable Connection
Opens a new database connection (or takes one from the connection pool).void
purgeAllPlayerData
(boolean stats, boolean achievements, boolean properties, boolean cacheOnly, @Nullable Consumer<Boolean> callback) Purges stored and cached data from ALL (!!)void
purgeAllPlayerData
(Set<String> statSetIds, boolean achievements, boolean properties, boolean cacheOnly, @Nullable Consumer<Boolean> callback) Purges stored and cached data from ALL (!!)void
purgePlayerData
(UUID uuid, boolean stats, boolean achievements, boolean properties, boolean cacheOnly, @Nullable Consumer<Boolean> callback) Purges stored and cached data from a certain player.void
registerStatSet
(PlayerStatSet dataSet) Tries to register this data set and make it display everywhere in the plugin.boolean
unregisterStatSet
(PlayerStatSet dataSet) Tries to register this data set.
-
Method Details
-
getStats
Tries to fetch the stats of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
player
- The player who owns the statscallback
- Stats will be given to this callback
-
getStats
Tries to fetch the stats of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
id
- The UUID of the player who owns the statscallback
- Stats will be given to this callback
-
getStatsByName
Tries to fetch the stats of the player given by its name.Casing of the name doesn't have to be exactly equally. Result may gets cached for quick access in the future. Callback might return a null value in case there is no info about a player with that given name.
- Parameters:
name
- The name of the playercallback
- Stats will be given to this callback
-
getStatsCached
Tries to get stats from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getStats(OfflinePlayer, Consumer)
to explicitly load them.- Parameters:
player
- The player who owns the properties- Returns:
- The stats of the player. Maybe empty if they aren't being cached
-
getStatsCached
Tries to get stats from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getStats(UUID, Consumer)
to explicitly load them.- Parameters:
id
- The UUID of the player who owns the properties- Returns:
- The stats of the player. Maybe empty if they aren't being cached
-
getCachedStats
Collection<PlayerStats> getCachedStats()Gets a collection of all currently cached player stats.- Returns:
- An immutable collection of currently cached achievements
-
getAchievements
Tries to fetch the achievements info of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
player
- The player who owns the achievementscallback
- Result will be given to this callback
-
getAchievements
Tries to fetch the achievement info of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
id
- The UUID of the player who owns the achievementscallback
- Result will be given to this callback
-
getAchievementsCached
Tries to get achievements from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getAchievements(OfflinePlayer, Consumer)
to explicitly load them.- Parameters:
player
- The player who owns the properties- Returns:
- The achievements of the player. Maybe empty if they aren't being cached
-
getAchievementsCached
Tries to get achievements from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getAchievements(UUID, Consumer)
to explicitly load them.- Parameters:
id
- The UUID of the player who owns the properties- Returns:
- The achievements of the player. Maybe empty if they aren't being cached
-
getCachedAchievements
Collection<PlayerAchievements> getCachedAchievements()Gets a collection of all currently cached properties achievements.- Returns:
- An immutable collection of currently cached achievements
-
getProperties
Tries to fetch the properties of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
player
- The player who owns the propertiescallback
- Result will be given to this callback
-
getProperties
Tries to fetch the properties of the player.Result may gets cached for quick access in the future. Callback will never return a null value.
- Parameters:
id
- The UUID of the player who owns the propertiescallback
- Result will be given to this callback
-
getPropertiesCached
Tries to get properties from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getProperties(OfflinePlayer, Consumer)
to explicitly load them.- Parameters:
player
- The player who owns the properties- Returns:
- The properties of the player. Maybe empty if they aren't being cached
-
getPropertiesCached
Tries to get properties from the cache.Returns an empty optional when they haven't been loaded yet. This method also does not automatically load them, you must call
getProperties(UUID, Consumer)
to explicitly load them.- Parameters:
id
- The UUID of the player who owns the properties- Returns:
- The properties of the player. Maybe empty if they aren't being cached
-
getCachedProperties
Collection<PlayerProperties> getCachedProperties()Gets a collection of all currently cached player properties.- Returns:
- An immutable collection of currently cached properties
-
getRegisteredStatSets
Collection<PlayerStatSet> getRegisteredStatSets()Returns all registered data sets for stats.- Returns:
- All registered data sets
-
getStatsDataSet
Searches for the data set with that id and returns it.- Parameters:
id
- The id of that data set- Returns:
- Its instance
-
registerStatSet
Tries to register this data set and make it display everywhere in the plugin.- Parameters:
dataSet
- The data set that shall be added- Throws:
IllegalStateException
- If there's already a data set with the same id
-
unregisterStatSet
Tries to register this data set.- Parameters:
dataSet
- The data set that shall be removed- Returns:
true
if it has been unregistered/removed, otherwisefalse
-
getStatsSet
Returns the stats set with the given id.- Parameters:
id
- This id of the stats set we are trying to get- Returns:
- the stats set with the corresponding id. Returns
null
if there is no stats set with the given id
-
fetchAllStoredUUIDs
CloseableIterator<UUID> fetchAllStoredUUIDs()Fetches all uuids of players that are known for this plugin.This method may not match the OfflinePlayer ones and likely contains less or more than there. MBedwars only stores uuids of relevant players. A player is relevant in case there is any info available that needs to be stored for either of its stats, achievements or properties.
This fetch is not being executed async on a separate thread. It will be done in the same thread in which this method is being called!!
Also it is very important that you call
Closeable.close()
once you are done.- Returns:
- An iterator for going through all known uuids
-
purgePlayerData
void purgePlayerData(UUID uuid, boolean stats, boolean achievements, boolean properties, boolean cacheOnly, @Nullable @Nullable Consumer<Boolean> callback) Purges stored and cached data from a certain player. DANGEROUS METHOD!Calls
PlayerDataPurgeEvent
. Plugins using the API may cancel it if they want to.- Parameters:
uuid
- The uuid of the playerstats
- Whether stats shall be purgedachievements
- Whether achievements shall be purgedproperties
- Whether properties shall be purgedcacheOnly
- true: Only local cache updated, false: Local cache of all servers, permanent database get affectedcallback
- Optional callback. Gets called on the main thread. Includes info whether it was successful or not
-
purgeAllPlayerData
void purgeAllPlayerData(boolean stats, boolean achievements, boolean properties, boolean cacheOnly, @Nullable @Nullable Consumer<Boolean> callback) Purges stored and cached data from ALL (!!) players. VERY DANGEROUS METHOD!Calls
PlayerDataPurgeEvent
. Plugins using the API may cancel it if they want to.- Parameters:
stats
- Whether stats shall be purgedachievements
- Whether achievements shall be purgedproperties
- Whether properties shall be purgedcacheOnly
- true: Only local cache updated, false: Local cache of all servers, permanent database get affectedcallback
- Optional callback. Gets called on the main thread. Includes info whether it was successful or not
-
purgeAllPlayerData
void purgeAllPlayerData(Set<String> statSetIds, boolean achievements, boolean properties, boolean cacheOnly, @Nullable @Nullable Consumer<Boolean> callback) Purges stored and cached data from ALL (!!) players. VERY DANGEROUS METHOD!Calls
PlayerDataPurgeEvent
. Plugins using the API may cancel it if they want to.- Parameters:
statSetIds
- The ids of the stat sets that shall be purgedachievements
- Whether achievements shall be purgedproperties
- Whether properties shall be purgedcacheOnly
- true: Only local cache updated, false: Local cache of all servers, permanent database get affectedcallback
- Optional callback. Gets called on the main thread. Includes info whether it was successful or not
-
fetchLeaderboard
void fetchLeaderboard(PlayerStatSet statSet, int minRank, int maxRank, Consumer<LeaderboardFetchResult> callback) Fetches players at the given ranks at the leaderboard.This causes a direct call to the database. It only makes use of what it is currently saved. Meaning that the rank might be slightly off due to temporal factors, as the local cache of all players possibly hasn't been pushed yet to the database.
- Parameters:
statSet
- The stat set according to which we want to order the playersminRank
- The minimum rank that we want to fetch. Must be at least 1maxRank
- The maximum rank that we want to fetchcallback
- The callback that is being used to deliver the result. Always on the main thread- Throws:
IllegalArgumentException
- In case minRank is less than 1 or greater than maxRankIllegalArgumentException
- If the stat set is not registered
-
fetchLeaderboardPosition
Fetches the position of a player on the leaderboard.This causes a direct call to the database. It only makes use of what it is currently saved. Meaning that the rank might be slightly off due to temporal factors, as the local cache of all players possibly hasn't been pushed yet to the database.
- Parameters:
playerUUID
- The UUID of the playerstatSet
- The stat set according to which we want to order the playerscallback
- The callback that is being used to deliver the result. Always on the main thread
-
fetchLeaderboardPosition
default void fetchLeaderboardPosition(OfflinePlayer player, PlayerStatSet statSet, Consumer<Integer> callback) Fetches the position of a player on the leaderboard.This causes a direct call to the database. It only makes use of what it is currently saved. Meaning that the rank might be slightly off due to temporal factors, as the local cache of all players possibly hasn't been pushed yet to the database.
- Parameters:
player
- Tthe playerstatSet
- The stat set according to which we want to order the playerscallback
- The callback that is being used to deliver the result. Always on the main thread
-
getUUIDByName
Tries to look-up the UUID of a player by its name in the database.Also checks among online players, just to be sure and avoid unnecessary database calls. Note that this does not execute a call to Mojang's API for fetching the UUID. It only checks what we know, and in case he never joined the server/network, it will return an empty optional. The use of this method is recommended, as it properly supports cracked/offline players on networks, which
Bukkit.getOfflinePlayer(String)
does not.Depending on the implementation of the database, username might be case-sensitive or not.
- Parameters:
username
- The name of the playercallback
- The callback that is being used to deliver the result. Always on the main thread
-
isSQLServiceActive
boolean isSQLServiceActive()Returns whether the plugin is currently connected to a SQL database.- Returns:
true
when a stable database connection exists
-
openSQLConnection
Opens a new database connection (or takes one from the connection pool).Make sure to close it!
- Returns:
null
when it isn't connected to any database, otherwise the connection- Throws:
SQLException
- An error that possibly occurred during that
-
getAchievementTypeById
Get an achievement by its id.- Parameters:
id
- The id of the achievement- Returns:
- The achievement with the given id. Returns
null
if there is no achievement with the given id
-
getRegisteredAchievementTypes
Collection<PlayerAchievement> getRegisteredAchievementTypes()Get all existing achievements.- Returns:
- A collection of all existing achievements
-
get
Returns the global PlayerDataAPI instance.- Returns:
- The global PlayerDataAPI instance
-