Changed keys used for PerServerData container to use their own object.

This commit is contained in:
Rsl1122 2018-06-05 14:15:50 +03:00
parent ff143af328
commit 657b25ec4f
9 changed files with 97 additions and 31 deletions

View File

@ -4,9 +4,10 @@ import java.util.HashMap;
import java.util.UUID; import java.util.UUID;
/** /**
* Container for data * Container for data about a player on a single server.
* *
* @author Rsl1122 * @author Rsl1122
* @see com.djrapitops.plan.data.store.keys.PerServerKeys For Key objects.
*/ */
public class PerServerData extends HashMap<UUID, DataContainer> { public class PerServerData extends HashMap<UUID, DataContainer> {
} }

View File

@ -6,7 +6,7 @@ package com.djrapitops.plan.data.store.containers;
* Use {@code getValue(PlayerKeys.REGISTERED).isPresent()} to determine if Plan has data about the player. * Use {@code getValue(PlayerKeys.REGISTERED).isPresent()} to determine if Plan has data about the player.
* *
* @author Rsl1122 * @author Rsl1122
* @see com.djrapitops.plan.data.store.keys.PlayerKeys for supported Key objects. * @see com.djrapitops.plan.data.store.keys.PlayerKeys For Key objects.
*/ */
public class PlayerContainer extends DataContainer { public class PlayerContainer extends DataContainer {
} }

View File

@ -1,7 +1,12 @@
package com.djrapitops.plan.data.store.keys; package com.djrapitops.plan.data.store.keys;
import com.djrapitops.plan.data.container.PlayerKill;
import com.djrapitops.plan.data.container.Session;
import com.djrapitops.plan.data.store.Key; import com.djrapitops.plan.data.store.Key;
import com.djrapitops.plan.data.store.Type;
import com.djrapitops.plan.data.time.WorldTimes;
import java.util.List;
import java.util.UUID; import java.util.UUID;
/** /**
@ -12,5 +17,18 @@ import java.util.UUID;
public class CommonKeys { public class CommonKeys {
public static final Key<UUID> UUID = new Key<>(UUID.class, "uuid"); public static final Key<UUID> UUID = new Key<>(UUID.class, "uuid");
public static final Key<Long> REGISTERED = new Key<>(Long.class, "registered");
public static final Key<List<Session>> SESSIONS = new Key<>(new Type<List<Session>>() {}, "sessions");
public static final Key<WorldTimes> WORLD_TIMES = new Key<>(WorldTimes.class, "world_times");
public static final Key<Long> LAST_SEEN = new Key<>(Long.class, "last_seen");
public static final Key<List<PlayerKill>> PLAYER_KILLS = new Key<>(new Type<List<PlayerKill>>() {}, "player_kills");
public static final Key<Integer> PLAYER_KILL_COUNT = new Key<>(Integer.class, "player_kill_count");
public static final Key<Integer> MOB_KILL_COUNT = new Key<>(Integer.class, "mob_kill_count");
public static final Key<Integer> DEATH_COUNT = new Key<>(Integer.class, "death_count");
public static final Key<Boolean> BANNED = new Key<>(Boolean.class, "banned");
public static final Key<Boolean> OPERATOR = new Key<>(Boolean.class, "operator");
} }

View File

@ -0,0 +1,32 @@
package com.djrapitops.plan.data.store.keys;
import com.djrapitops.plan.data.container.PlayerKill;
import com.djrapitops.plan.data.container.Session;
import com.djrapitops.plan.data.store.Key;
import com.djrapitops.plan.data.time.WorldTimes;
import java.util.List;
/**
* Key objects for PerServerData container.
*
* @author Rsl1122
* @see com.djrapitops.plan.data.store.containers.PerServerData For the DataContainer.
*/
public class PerServerKeys {
public static final Key<Long> REGISTERED = CommonKeys.REGISTERED;
public static final Key<List<Session>> SESSIONS = CommonKeys.SESSIONS;
public static final Key<WorldTimes> WORLD_TIMES = CommonKeys.WORLD_TIMES;
public static final Key<List<PlayerKill>> PLAYER_KILLS = CommonKeys.PLAYER_KILLS;
public static final Key<Integer> PLAYER_KILL_COUNT = CommonKeys.PLAYER_KILL_COUNT;
public static final Key<Integer> MOB_KILL_COUNT = CommonKeys.MOB_KILL_COUNT;
public static final Key<Integer> DEATH_COUNT = CommonKeys.DEATH_COUNT;
public static final Key<Long> LAST_SEEN = CommonKeys.LAST_SEEN;
public static final Key<Boolean> BANNED = CommonKeys.BANNED;
public static final Key<Boolean> OPERATOR = CommonKeys.OPERATOR;
}

View File

@ -16,6 +16,7 @@ import java.util.UUID;
* Class that holds Key objects for PlayerContainer. * Class that holds Key objects for PlayerContainer.
* *
* @author Rsl1122 * @author Rsl1122
* @see com.djrapitops.plan.data.store.containers.PlayerContainer For DataContainer.
*/ */
public class PlayerKeys { public class PlayerKeys {
@ -23,23 +24,23 @@ public class PlayerKeys {
public static final Key<String> NAME = new Key<>(String.class, "name"); public static final Key<String> NAME = new Key<>(String.class, "name");
public static final Key<List<Nickname>> NICKNAMES = new Key<>(new Type<List<Nickname>>() {}, "nicknames"); public static final Key<List<Nickname>> NICKNAMES = new Key<>(new Type<List<Nickname>>() {}, "nicknames");
public static final Key<Long> REGISTERED = new Key<>(Long.class, "registered"); public static final Key<Long> REGISTERED = CommonKeys.REGISTERED;
public static final Key<Integer> KICK_COUNT = new Key<>(Integer.class, "kick_count"); public static final Key<Integer> KICK_COUNT = new Key<>(Integer.class, "kick_count");
public static final Key<List<GeoInfo>> GEO_INFO = new Key<>(new Type<List<GeoInfo>>() {}, "geo_info"); public static final Key<List<GeoInfo>> GEO_INFO = new Key<>(new Type<List<GeoInfo>>() {}, "geo_info");
public static final Key<Session> ACTIVE_SESSION = new Key<Session>(Session.class, "active_session"); public static final Key<Session> ACTIVE_SESSION = new Key<>(Session.class, "active_session");
public static final Key<List<Session>> SESSIONS = new Key<>(new Type<List<Session>>() {}, "sessions"); public static final Key<List<Session>> SESSIONS = CommonKeys.SESSIONS;
public static final Key<WorldTimes> WORLD_TIMES = new Key<>(WorldTimes.class, "world_times"); public static final Key<WorldTimes> WORLD_TIMES = CommonKeys.WORLD_TIMES;
public static final Key<List<PlayerKill>> PLAYER_KILLS = new Key<>(new Type<List<PlayerKill>>() {}, "player_kills"); public static final Key<List<PlayerKill>> PLAYER_KILLS = CommonKeys.PLAYER_KILLS;
public static final Key<Integer> PLAYER_KILL_COUNT = new Key<>(Integer.class, "player_kill_count"); public static final Key<Integer> PLAYER_KILL_COUNT = CommonKeys.PLAYER_KILL_COUNT;
public static final Key<Integer> MOB_KILL_COUNT = new Key<>(Integer.class, "mob_kill_count"); public static final Key<Integer> MOB_KILL_COUNT = CommonKeys.MOB_KILL_COUNT;
public static final Key<Integer> DEATH_COUNT = new Key<>(Integer.class, "death_count"); public static final Key<Integer> DEATH_COUNT = CommonKeys.DEATH_COUNT;
public static final Key<PerServerData> PER_SERVER = new Key<>(PerServerData.class, "per_server_data"); public static final Key<PerServerData> PER_SERVER = new Key<>(PerServerData.class, "per_server_data");
public static final Key<Long> LAST_SEEN = new Key<>(Long.class, "last_seen"); public static final Key<Long> LAST_SEEN = CommonKeys.LAST_SEEN;
public static final Key<Boolean> BANNED = new Key<>(Boolean.class, "banned"); public static final Key<Boolean> BANNED = CommonKeys.BANNED;
public static final Key<Boolean> OPERATOR = new Key<>(Boolean.class, "operator"); public static final Key<Boolean> OPERATOR = CommonKeys.OPERATOR;
} }

View File

@ -2,7 +2,10 @@ package com.djrapitops.plan.data.store.mutators;
import com.djrapitops.plan.data.container.PlayerKill; import com.djrapitops.plan.data.container.PlayerKill;
import com.djrapitops.plan.data.container.Session; import com.djrapitops.plan.data.container.Session;
import com.djrapitops.plan.data.store.containers.DataContainer;
import com.djrapitops.plan.data.store.keys.PlayerKeys;
import com.djrapitops.plan.data.time.WorldTimes; import com.djrapitops.plan.data.time.WorldTimes;
import com.djrapitops.plugin.utilities.Verify;
import java.util.*; import java.util.*;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -18,6 +21,12 @@ public class SessionsMutator {
private List<Session> sessions; private List<Session> sessions;
public static SessionsMutator forContainer(DataContainer dataContainer) {
Verify.isTrue(dataContainer.supports(PlayerKeys.SESSIONS),
() -> new IllegalArgumentException("Given DataContainer does not support SESSIONS"));
return new SessionsMutator(dataContainer.getValue(PlayerKeys.SESSIONS).orElse(new ArrayList<>()));
}
public SessionsMutator(List<Session> sessions) { public SessionsMutator(List<Session> sessions) {
this.sessions = sessions; this.sessions = sessions;
} }

View File

@ -7,6 +7,7 @@ import com.djrapitops.plan.data.container.*;
import com.djrapitops.plan.data.store.containers.DataContainer; import com.djrapitops.plan.data.store.containers.DataContainer;
import com.djrapitops.plan.data.store.containers.PerServerData; import com.djrapitops.plan.data.store.containers.PerServerData;
import com.djrapitops.plan.data.store.containers.PlayerContainer; import com.djrapitops.plan.data.store.containers.PlayerContainer;
import com.djrapitops.plan.data.store.keys.PerServerKeys;
import com.djrapitops.plan.data.store.keys.PlayerKeys; import com.djrapitops.plan.data.store.keys.PlayerKeys;
import com.djrapitops.plan.data.store.mutators.PerServerDataMutator; import com.djrapitops.plan.data.store.mutators.PerServerDataMutator;
import com.djrapitops.plan.data.store.mutators.SessionsMutator; import com.djrapitops.plan.data.store.mutators.SessionsMutator;
@ -191,18 +192,21 @@ public class SQLFetchOps extends SQLOps implements FetchOperations {
List<Session> serverSessions = entry.getValue(); List<Session> serverSessions = entry.getValue();
DataContainer perServer = perServerData.getOrDefault(serverUUID, new DataContainer()); DataContainer perServer = perServerData.getOrDefault(serverUUID, new DataContainer());
perServer.putRawData(PlayerKeys.SESSIONS, serverSessions); perServer.putRawData(PerServerKeys.SESSIONS, serverSessions);
perServer.putSupplier(PlayerKeys.WORLD_TIMES, () -> perServer.putSupplier(PerServerKeys.LAST_SEEN, () ->
new SessionsMutator(perServer.getUnsafe(PlayerKeys.SESSIONS)).toTotalWorldTimes()); new SessionsMutator(perServer.getUnsafe(PerServerKeys.SESSIONS)).toLastSeen());
perServer.putSupplier(PlayerKeys.PLAYER_KILLS, () ->
new SessionsMutator(perServer.getUnsafe(PlayerKeys.SESSIONS)).toPlayerKillList()); perServer.putSupplier(PerServerKeys.WORLD_TIMES, () ->
perServer.putSupplier(PlayerKeys.PLAYER_KILL_COUNT, () -> new SessionsMutator(perServer.getUnsafe(PerServerKeys.SESSIONS)).toTotalWorldTimes());
perServer.getUnsafe(PlayerKeys.PLAYER_KILLS).size()); perServer.putSupplier(PerServerKeys.PLAYER_KILLS, () ->
perServer.putSupplier(PlayerKeys.MOB_KILL_COUNT, () -> new SessionsMutator(perServer.getUnsafe(PerServerKeys.SESSIONS)).toPlayerKillList());
new SessionsMutator(perServer.getUnsafe(PlayerKeys.SESSIONS)).toMobKillCount()); perServer.putSupplier(PerServerKeys.PLAYER_KILL_COUNT, () ->
perServer.putSupplier(PlayerKeys.DEATH_COUNT, () -> perServer.getUnsafe(PerServerKeys.PLAYER_KILLS).size());
new SessionsMutator(perServer.getUnsafe(PlayerKeys.SESSIONS)).toDeathCount()); perServer.putSupplier(PerServerKeys.MOB_KILL_COUNT, () ->
new SessionsMutator(perServer.getUnsafe(PerServerKeys.SESSIONS)).toMobKillCount());
perServer.putSupplier(PerServerKeys.DEATH_COUNT, () ->
new SessionsMutator(perServer.getUnsafe(PerServerKeys.SESSIONS)).toDeathCount());
perServerData.put(serverUUID, perServer); perServerData.put(serverUUID, perServer);
} }

View File

@ -134,7 +134,7 @@ public class InspectPage extends Page {
String[] sessionsAccordion = HtmlStructure.createSessionsTabContentInspectPage(sessionsByServerName, allSessions, uuid); String[] sessionsAccordion = HtmlStructure.createSessionsTabContentInspectPage(sessionsByServerName, allSessions, uuid);
ServerAccordion serverAccordion = new ServerAccordion(container, worldTimesPerServer, serverNames); ServerAccordion serverAccordion = new ServerAccordion(container, serverNames);
PlayerCalendar playerCalendar = new PlayerCalendar(allSessions, registered); PlayerCalendar playerCalendar = new PlayerCalendar(allSessions, registered);

View File

@ -9,6 +9,7 @@ import com.djrapitops.plan.data.container.Session;
import com.djrapitops.plan.data.store.containers.DataContainer; import com.djrapitops.plan.data.store.containers.DataContainer;
import com.djrapitops.plan.data.store.containers.PerServerData; import com.djrapitops.plan.data.store.containers.PerServerData;
import com.djrapitops.plan.data.store.containers.PlayerContainer; import com.djrapitops.plan.data.store.containers.PlayerContainer;
import com.djrapitops.plan.data.store.keys.PerServerKeys;
import com.djrapitops.plan.data.store.keys.PlayerKeys; import com.djrapitops.plan.data.store.keys.PlayerKeys;
import com.djrapitops.plan.data.time.WorldTimes; import com.djrapitops.plan.data.time.WorldTimes;
import com.djrapitops.plan.system.settings.theme.Theme; import com.djrapitops.plan.system.settings.theme.Theme;
@ -32,7 +33,7 @@ public class ServerAccordion extends AbstractAccordion {
private final Map<UUID, String> serverNames; private final Map<UUID, String> serverNames;
private PerServerData perServer; private PerServerData perServer;
public ServerAccordion(PlayerContainer container, Map<UUID, WorldTimes> worldTimesPerServer, Map<UUID, String> serverNames) { public ServerAccordion(PlayerContainer container, Map<UUID, String> serverNames) {
super("server_accordion"); super("server_accordion");
viewScript = new StringBuilder(); viewScript = new StringBuilder();
@ -58,13 +59,13 @@ public class ServerAccordion extends AbstractAccordion {
UUID serverUUID = entry.getKey(); UUID serverUUID = entry.getKey();
DataContainer container = entry.getValue(); DataContainer container = entry.getValue();
String serverName = serverNames.getOrDefault(serverUUID, "Unknown"); String serverName = serverNames.getOrDefault(serverUUID, "Unknown");
WorldTimes worldTimes = container.getValue(PlayerKeys.WORLD_TIMES).orElse(new WorldTimes(new HashMap<>())); WorldTimes worldTimes = container.getValue(PerServerKeys.WORLD_TIMES).orElse(new WorldTimes(new HashMap<>()));
List<Session> sessions = container.getValue(PlayerKeys.SESSIONS).orElse(new ArrayList<>()); List<Session> sessions = container.getValue(PerServerKeys.SESSIONS).orElse(new ArrayList<>());
boolean banned = container.getValue(PlayerKeys.BANNED).orElse(false); boolean banned = container.getValue(PerServerKeys.BANNED).orElse(false);
boolean opeator = container.getValue(PlayerKeys.OPERATOR).orElse(false); boolean opeator = container.getValue(PerServerKeys.OPERATOR).orElse(false);
long registered = container.getValue(PlayerKeys.REGISTERED).orElse(0L); long registered = container.getValue(PerServerKeys.REGISTERED).orElse(0L);
long playtime = PlayerProfile.getPlaytime(sessions.stream()); long playtime = PlayerProfile.getPlaytime(sessions.stream());
long afkTime = PlayerProfile.getAFKTime(sessions.stream()); long afkTime = PlayerProfile.getAFKTime(sessions.stream());