mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-08 17:37:34 +01:00
Ping table to Geolocations tab (server page)
This commit is contained in:
parent
a389dff035
commit
cbce9ff5aa
@ -161,19 +161,19 @@ public class GeoInfoQueries {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static Query<Map<String, Integer>> serverGeolocationCounts(UUID serverUUID) {
|
public static Query<Map<String, Integer>> serverGeolocationCounts(UUID serverUUID) {
|
||||||
String subQuery1 = SELECT +
|
String selectGeolocations = SELECT +
|
||||||
GeoInfoTable.USER_UUID + ", " +
|
GeoInfoTable.USER_UUID + ", " +
|
||||||
GeoInfoTable.GEOLOCATION + ", " +
|
GeoInfoTable.GEOLOCATION + ", " +
|
||||||
GeoInfoTable.LAST_USED +
|
GeoInfoTable.LAST_USED +
|
||||||
FROM + GeoInfoTable.TABLE_NAME;
|
FROM + GeoInfoTable.TABLE_NAME;
|
||||||
String subQuery2 = SELECT +
|
String selectLatestGeolocationDate = SELECT +
|
||||||
GeoInfoTable.USER_UUID + ", " +
|
GeoInfoTable.USER_UUID + ", " +
|
||||||
"MAX(" + GeoInfoTable.LAST_USED + ") as m" +
|
"MAX(" + GeoInfoTable.LAST_USED + ") as m" +
|
||||||
FROM + GeoInfoTable.TABLE_NAME +
|
FROM + GeoInfoTable.TABLE_NAME +
|
||||||
GROUP_BY + GeoInfoTable.USER_UUID;
|
GROUP_BY + GeoInfoTable.USER_UUID;
|
||||||
String sql = SELECT + GeoInfoTable.GEOLOCATION + ", COUNT(1) as c FROM (" +
|
String sql = SELECT + GeoInfoTable.GEOLOCATION + ", COUNT(1) as c FROM (" +
|
||||||
"(" + subQuery1 + ") AS q1" +
|
"(" + selectGeolocations + ") AS q1" +
|
||||||
INNER_JOIN + "(" + subQuery2 + ") AS q2 ON q1.uuid = q2.uuid" +
|
INNER_JOIN + "(" + selectLatestGeolocationDate + ") AS q2 ON q1.uuid = q2.uuid" +
|
||||||
INNER_JOIN + UserInfoTable.TABLE_NAME + " u on u." + UserInfoTable.USER_UUID + "=q1.uuid)" +
|
INNER_JOIN + UserInfoTable.TABLE_NAME + " u on u." + UserInfoTable.USER_UUID + "=q1.uuid)" +
|
||||||
WHERE + GeoInfoTable.LAST_USED + "=m" +
|
WHERE + GeoInfoTable.LAST_USED + "=m" +
|
||||||
AND + "u." + UserInfoTable.SERVER_UUID + "=?" +
|
AND + "u." + UserInfoTable.SERVER_UUID + "=?" +
|
||||||
|
@ -21,6 +21,7 @@ import com.djrapitops.plan.data.container.Ping;
|
|||||||
import com.djrapitops.plan.db.access.Query;
|
import com.djrapitops.plan.db.access.Query;
|
||||||
import com.djrapitops.plan.db.access.QueryAllStatement;
|
import com.djrapitops.plan.db.access.QueryAllStatement;
|
||||||
import com.djrapitops.plan.db.access.QueryStatement;
|
import com.djrapitops.plan.db.access.QueryStatement;
|
||||||
|
import com.djrapitops.plan.db.sql.tables.GeoInfoTable;
|
||||||
import com.djrapitops.plan.db.sql.tables.PingTable;
|
import com.djrapitops.plan.db.sql.tables.PingTable;
|
||||||
|
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
@ -186,4 +187,61 @@ public class PingQueries {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Query<Map<String, Ping>> fetchPingDataOfServerByGeolocation(UUID serverUUID) {
|
||||||
|
String selectPingOfServer = SELECT +
|
||||||
|
PingTable.MAX_PING + ", " +
|
||||||
|
PingTable.MIN_PING + ", " +
|
||||||
|
PingTable.AVG_PING + ", " +
|
||||||
|
PingTable.USER_UUID + ", " +
|
||||||
|
PingTable.SERVER_UUID +
|
||||||
|
FROM + PingTable.TABLE_NAME;
|
||||||
|
|
||||||
|
String selectGeolocations = SELECT +
|
||||||
|
GeoInfoTable.USER_UUID + ", " +
|
||||||
|
GeoInfoTable.GEOLOCATION + ", " +
|
||||||
|
GeoInfoTable.LAST_USED +
|
||||||
|
FROM + GeoInfoTable.TABLE_NAME;
|
||||||
|
String selectLatestGeolocationDate = SELECT +
|
||||||
|
GeoInfoTable.USER_UUID + ", " +
|
||||||
|
"MAX(" + GeoInfoTable.LAST_USED + ") as m" +
|
||||||
|
FROM + GeoInfoTable.TABLE_NAME +
|
||||||
|
GROUP_BY + GeoInfoTable.USER_UUID;
|
||||||
|
|
||||||
|
String selectPingByGeolocation = SELECT + GeoInfoTable.GEOLOCATION +
|
||||||
|
", MIN(" + PingTable.MIN_PING + ") as minPing" +
|
||||||
|
", MAX(" + PingTable.MAX_PING + ") as maxPing" +
|
||||||
|
", AVG(" + PingTable.AVG_PING + ") as avgPing" +
|
||||||
|
FROM + "(" +
|
||||||
|
"(" + selectGeolocations + ") AS q1" +
|
||||||
|
INNER_JOIN + "(" + selectLatestGeolocationDate + ") AS q2 ON q1.uuid = q2.uuid" +
|
||||||
|
INNER_JOIN + '(' + selectPingOfServer + ") sp on sp." + PingTable.USER_UUID + "=q1.uuid)" +
|
||||||
|
WHERE + GeoInfoTable.LAST_USED + "=m" +
|
||||||
|
AND + "sp." + PingTable.SERVER_UUID + "=?" +
|
||||||
|
GROUP_BY + GeoInfoTable.GEOLOCATION;
|
||||||
|
|
||||||
|
return new QueryStatement<Map<String, Ping>>(selectPingByGeolocation) {
|
||||||
|
@Override
|
||||||
|
public void prepare(PreparedStatement statement) throws SQLException {
|
||||||
|
statement.setString(1, serverUUID.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<String, Ping> processResults(ResultSet set) throws SQLException {
|
||||||
|
// TreeMap to sort alphabetically
|
||||||
|
Map<String, Ping> pingByGeolocation = new TreeMap<>();
|
||||||
|
while (set.next()) {
|
||||||
|
Ping ping = new Ping(
|
||||||
|
0L,
|
||||||
|
serverUUID,
|
||||||
|
set.getInt("minPing"),
|
||||||
|
set.getInt("maxPing"),
|
||||||
|
set.getInt("avgPing")
|
||||||
|
);
|
||||||
|
pingByGeolocation.put(set.getString(GeoInfoTable.GEOLOCATION), ping);
|
||||||
|
}
|
||||||
|
return pingByGeolocation;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
@ -16,6 +16,7 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.system.json;
|
package com.djrapitops.plan.system.json;
|
||||||
|
|
||||||
|
import com.djrapitops.plan.data.container.Ping;
|
||||||
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.container.TPS;
|
import com.djrapitops.plan.data.container.TPS;
|
||||||
@ -26,10 +27,7 @@ import com.djrapitops.plan.data.store.objects.DateObj;
|
|||||||
import com.djrapitops.plan.db.Database;
|
import com.djrapitops.plan.db.Database;
|
||||||
import com.djrapitops.plan.db.access.queries.analysis.PlayerCountQueries;
|
import com.djrapitops.plan.db.access.queries.analysis.PlayerCountQueries;
|
||||||
import com.djrapitops.plan.db.access.queries.containers.ServerPlayersTableContainersQuery;
|
import com.djrapitops.plan.db.access.queries.containers.ServerPlayersTableContainersQuery;
|
||||||
import com.djrapitops.plan.db.access.queries.objects.KillQueries;
|
import com.djrapitops.plan.db.access.queries.objects.*;
|
||||||
import com.djrapitops.plan.db.access.queries.objects.ServerQueries;
|
|
||||||
import com.djrapitops.plan.db.access.queries.objects.SessionQueries;
|
|
||||||
import com.djrapitops.plan.db.access.queries.objects.TPSQueries;
|
|
||||||
import com.djrapitops.plan.extension.implementation.storage.queries.ExtensionServerPlayerDataTableQuery;
|
import com.djrapitops.plan.extension.implementation.storage.queries.ExtensionServerPlayerDataTableQuery;
|
||||||
import com.djrapitops.plan.system.database.DBSystem;
|
import com.djrapitops.plan.system.database.DBSystem;
|
||||||
import com.djrapitops.plan.system.info.server.Server;
|
import com.djrapitops.plan.system.info.server.Server;
|
||||||
@ -159,4 +157,21 @@ public class JSONFactory {
|
|||||||
});
|
});
|
||||||
return servers;
|
return servers;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Map<String, Object>> pingPerGeolocation(UUID serverUUID) {
|
||||||
|
Map<String, Ping> pingByGeolocation = dbSystem.getDatabase().query(PingQueries.fetchPingDataOfServerByGeolocation(serverUUID));
|
||||||
|
List<Map<String, Object>> tableEntries = new ArrayList<>();
|
||||||
|
for (Map.Entry<String, Ping> entry : pingByGeolocation.entrySet()) {
|
||||||
|
String geolocation = entry.getKey();
|
||||||
|
Ping ping = entry.getValue();
|
||||||
|
|
||||||
|
Map<String, Object> tableEntry = new HashMap<>();
|
||||||
|
tableEntry.put("country", geolocation);
|
||||||
|
tableEntry.put("avg_ping", ping.getAverage());
|
||||||
|
tableEntry.put("min_ping", ping.getMin());
|
||||||
|
tableEntry.put("max_ping", ping.getMax());
|
||||||
|
tableEntries.add(tableEntry);
|
||||||
|
}
|
||||||
|
return tableEntries;
|
||||||
|
}
|
||||||
}
|
}
|
@ -41,6 +41,7 @@ public class RootJSONHandler extends TreePageHandler {
|
|||||||
public RootJSONHandler(
|
public RootJSONHandler(
|
||||||
ResponseFactory responseFactory,
|
ResponseFactory responseFactory,
|
||||||
Identifiers identifiers,
|
Identifiers identifiers,
|
||||||
|
JSONFactory jsonFactory,
|
||||||
GraphsJSONHandler graphsJSONHandler,
|
GraphsJSONHandler graphsJSONHandler,
|
||||||
SessionsJSONHandler sessionsJSONHandler,
|
SessionsJSONHandler sessionsJSONHandler,
|
||||||
PlayersTableJSONHandler playersTableJSONHandler,
|
PlayersTableJSONHandler playersTableJSONHandler,
|
||||||
@ -62,6 +63,7 @@ public class RootJSONHandler extends TreePageHandler {
|
|||||||
registerPage("players", playersTableJSONHandler);
|
registerPage("players", playersTableJSONHandler);
|
||||||
registerPage("sessions", sessionsJSONHandler);
|
registerPage("sessions", sessionsJSONHandler);
|
||||||
registerPage("kills", playerKillsJSONHandler);
|
registerPage("kills", playerKillsJSONHandler);
|
||||||
|
registerPage("pingTable", jsonFactory::pingPerGeolocation);
|
||||||
registerPage("graph", graphsJSONHandler);
|
registerPage("graph", graphsJSONHandler);
|
||||||
registerPage("extensions", pluginTabJSONParser);
|
registerPage("extensions", pluginTabJSONParser);
|
||||||
|
|
||||||
|
@ -0,0 +1,32 @@
|
|||||||
|
function loadPingTable(json, error) {
|
||||||
|
pingTable = $("#geolocations").find("#data_ping_table").find("tbody");
|
||||||
|
|
||||||
|
if (error) {
|
||||||
|
pingTable.append('<tr><td>Error: ' + error + '</td><td>-</td><td>-</td><td>-</td></tr>');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var countries = json;
|
||||||
|
|
||||||
|
if (!countries.length) {
|
||||||
|
pingTable.append('<tr><td>No Ping Data</td><td>-</td><td>-</td><td>-</td></tr>');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var tableHtml = '';
|
||||||
|
|
||||||
|
for (var i = 0; i < countries.length; i++) {
|
||||||
|
var country = countries[i];
|
||||||
|
tableHtml += createPingTableRow(country);
|
||||||
|
}
|
||||||
|
|
||||||
|
pingTable.append(tableHtml);
|
||||||
|
}
|
||||||
|
|
||||||
|
function createPingTableRow(entry) {
|
||||||
|
return '<tr><td>' + entry.country +
|
||||||
|
'</td><td>' + entry.avg_ping +
|
||||||
|
'</td><td>' + entry.min_ping +
|
||||||
|
'</td><td>' + entry.max_ping +
|
||||||
|
'</td></tr>'
|
||||||
|
}
|
@ -1,15 +1,16 @@
|
|||||||
function loadSessionAccordion(json, error) {
|
function loadSessionAccordion(json, error) {
|
||||||
|
sessionTable = $("#sessions-overview").find("#tableAccordion").find("tbody");
|
||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
$('#sessions-overview').addClass('forbidden'); // TODO Figure out 403
|
sessionTable.append('<tr><td>Error: ' + error + '</td><td>-</td><td>-</td><td>-</td></tr>');
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
sessionTable = $("#sessions-overview").find("#tableAccordion").find("tbody");
|
|
||||||
|
|
||||||
var sessions = json.sessions;
|
var sessions = json.sessions;
|
||||||
|
|
||||||
if (!sessions.length) {
|
if (!sessions.length) {
|
||||||
sessionTable.append('<tr><td>No Sessions</td><td>-</td><td>-</td><td>-</td></tr>')
|
sessionTable.append('<tr><td>No Sessions</td><td>-</td><td>-</td><td>-</td></tr>');
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// sessions_per_page can be undefined (-> NaN) or higher than amount of sessions.
|
// sessions_per_page can be undefined (-> NaN) or higher than amount of sessions.
|
||||||
|
@ -895,7 +895,7 @@
|
|||||||
</div> <!-- /.container-fluid -->
|
</div> <!-- /.container-fluid -->
|
||||||
</div> <!-- End of Player List tab -->
|
</div> <!-- End of Player List tab -->
|
||||||
<!-- Begin Geolocations Tab -->
|
<!-- Begin Geolocations Tab -->
|
||||||
<div class="tab">
|
<div class="tab" id="geolocations">
|
||||||
<div class="container-fluid mt-4">
|
<div class="container-fluid mt-4">
|
||||||
<!-- Page Heading -->
|
<!-- Page Heading -->
|
||||||
<div class="d-sm-flex align-items-center justify-content-between mb-4">
|
<div class="d-sm-flex align-items-center justify-content-between mb-4">
|
||||||
@ -939,23 +939,16 @@
|
|||||||
Connection Information</h6>
|
Connection Information</h6>
|
||||||
</div>
|
</div>
|
||||||
<div class="scrollbar">
|
<div class="scrollbar">
|
||||||
<table class="table">
|
<table class="table" id="data_ping_table">
|
||||||
<thead class="bg-amber">
|
<thead class="bg-amber">
|
||||||
<tr>
|
<tr>
|
||||||
<th><i class=" fa fa-fw fa-globe"></i> Country</th>
|
<th><i class=" fa fa-fw fa-globe"></i> Country</th>
|
||||||
<th><i class=" fa fa-fw fa-signal"></i> Average Ping</th>
|
<th><i class=" fa fa-fw fa-signal"></i> Average Ping</th>
|
||||||
<th><i class=" fa fa-fw fa-signal"></i> Worst Ping</th>
|
|
||||||
<th><i class=" fa fa-fw fa-signal"></i> Best Ping</th>
|
<th><i class=" fa fa-fw fa-signal"></i> Best Ping</th>
|
||||||
|
<th><i class=" fa fa-fw fa-signal"></i> Worst Ping</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody></tbody>
|
||||||
<tr>
|
|
||||||
<td>Local Machine</td>
|
|
||||||
<td>-</td>
|
|
||||||
<td>-</td>
|
|
||||||
<td>-</td>
|
|
||||||
</tr>
|
|
||||||
</tbody>
|
|
||||||
</table>
|
</table>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -1365,6 +1358,7 @@
|
|||||||
|
|
||||||
<!-- Page level custom scripts -->
|
<!-- Page level custom scripts -->
|
||||||
<script src="js/sessionAccordion.js"></script>
|
<script src="js/sessionAccordion.js"></script>
|
||||||
|
<script src="js/pingTable.js"></script>
|
||||||
<script src="js/graphs.js"></script>
|
<script src="js/graphs.js"></script>
|
||||||
<script src="js/server-values.js"></script>
|
<script src="js/server-values.js"></script>
|
||||||
|
|
||||||
@ -1670,6 +1664,7 @@
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
jsonRequest("../v1/kills?server=${serverName}", loadPlayerKills);
|
jsonRequest("../v1/kills?server=${serverName}", loadPlayerKills);
|
||||||
|
jsonRequest("../v1/pingTable?server=${serverName}", loadPingTable);
|
||||||
|
|
||||||
$('.server-name').text('${serverName}');
|
$('.server-name').text('${serverName}');
|
||||||
$('.player-plugin-table').DataTable({
|
$('.player-plugin-table').DataTable({
|
||||||
|
Loading…
Reference in New Issue
Block a user