mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2025-01-08 01:17:45 +01:00
Deleted Command usage related code
This commit is contained in:
parent
826faa1b1a
commit
dd6f2a1e30
@ -98,7 +98,6 @@ public abstract class BukkitImporter implements Importer {
|
|||||||
@Override
|
@Override
|
||||||
protected void performOperations() {
|
protected void performOperations() {
|
||||||
execute(LargeStoreQueries.storeAllTPSData(Collections.singletonMap(serverUUID.get(), serverImportData.getTpsData())));
|
execute(LargeStoreQueries.storeAllTPSData(Collections.singletonMap(serverUUID.get(), serverImportData.getTpsData())));
|
||||||
execute(LargeStoreQueries.storeAllCommandUsageData(Collections.singletonMap(serverUUID.get(), serverImportData.getCommandUsages())));
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -35,7 +35,6 @@ public class BukkitListenerSystem extends ListenerSystem {
|
|||||||
private final ChatListener chatListener;
|
private final ChatListener chatListener;
|
||||||
private final GameModeChangeListener gamemodeChangeListener;
|
private final GameModeChangeListener gamemodeChangeListener;
|
||||||
private final WorldChangeListener worldChangeListener;
|
private final WorldChangeListener worldChangeListener;
|
||||||
private final CommandListener commandListener;
|
|
||||||
private final DeathEventListener deathEventListener;
|
private final DeathEventListener deathEventListener;
|
||||||
private final BukkitAFKListener afkListener;
|
private final BukkitAFKListener afkListener;
|
||||||
|
|
||||||
@ -46,7 +45,6 @@ public class BukkitListenerSystem extends ListenerSystem {
|
|||||||
ChatListener chatListener,
|
ChatListener chatListener,
|
||||||
GameModeChangeListener gamemodeChangeListener,
|
GameModeChangeListener gamemodeChangeListener,
|
||||||
WorldChangeListener worldChangeListener,
|
WorldChangeListener worldChangeListener,
|
||||||
CommandListener commandListener,
|
|
||||||
DeathEventListener deathEventListener,
|
DeathEventListener deathEventListener,
|
||||||
BukkitAFKListener afkListener
|
BukkitAFKListener afkListener
|
||||||
) {
|
) {
|
||||||
@ -57,7 +55,6 @@ public class BukkitListenerSystem extends ListenerSystem {
|
|||||||
this.chatListener = chatListener;
|
this.chatListener = chatListener;
|
||||||
this.gamemodeChangeListener = gamemodeChangeListener;
|
this.gamemodeChangeListener = gamemodeChangeListener;
|
||||||
this.worldChangeListener = worldChangeListener;
|
this.worldChangeListener = worldChangeListener;
|
||||||
this.commandListener = commandListener;
|
|
||||||
this.deathEventListener = deathEventListener;
|
this.deathEventListener = deathEventListener;
|
||||||
this.afkListener = afkListener;
|
this.afkListener = afkListener;
|
||||||
}
|
}
|
||||||
@ -69,7 +66,6 @@ public class BukkitListenerSystem extends ListenerSystem {
|
|||||||
chatListener,
|
chatListener,
|
||||||
gamemodeChangeListener,
|
gamemodeChangeListener,
|
||||||
worldChangeListener,
|
worldChangeListener,
|
||||||
commandListener,
|
|
||||||
deathEventListener,
|
deathEventListener,
|
||||||
afkListener
|
afkListener
|
||||||
);
|
);
|
||||||
|
@ -1,108 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of Player Analytics (Plan).
|
|
||||||
*
|
|
||||||
* Plan is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License v3 as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* Plan is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.gathering.listeners.bukkit;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.Plan;
|
|
||||||
import com.djrapitops.plan.identification.ServerInfo;
|
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
|
||||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
|
||||||
import com.djrapitops.plan.settings.config.paths.DataGatheringSettings;
|
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plan.storage.database.transactions.events.CommandStoreTransaction;
|
|
||||||
import com.djrapitops.plugin.logging.L;
|
|
||||||
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
|
||||||
import org.bukkit.command.Command;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.EventPriority;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
import org.bukkit.event.player.PlayerCommandPreprocessEvent;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Event Listener for PlayerCommandPreprocessEvents.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class CommandListener implements Listener {
|
|
||||||
|
|
||||||
private final Plan plugin;
|
|
||||||
private final PlanConfig config;
|
|
||||||
private final ServerInfo serverInfo;
|
|
||||||
private final DBSystem dbSystem;
|
|
||||||
private final ErrorHandler errorHandler;
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
public CommandListener(
|
|
||||||
Plan plugin,
|
|
||||||
PlanConfig config,
|
|
||||||
ServerInfo serverInfo,
|
|
||||||
DBSystem dbSystem,
|
|
||||||
ErrorHandler errorHandler
|
|
||||||
) {
|
|
||||||
this.plugin = plugin;
|
|
||||||
this.config = config;
|
|
||||||
this.serverInfo = serverInfo;
|
|
||||||
this.dbSystem = dbSystem;
|
|
||||||
this.errorHandler = errorHandler;
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR)
|
|
||||||
public void onPlayerCommand(PlayerCommandPreprocessEvent event) {
|
|
||||||
boolean hasIgnorePermission = event.getPlayer().hasPermission(Permissions.IGNORE_COMMAND_USE.getPermission());
|
|
||||||
if (event.isCancelled() || hasIgnorePermission) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
actOnCommandEvent(event);
|
|
||||||
} catch (Exception e) {
|
|
||||||
errorHandler.log(L.ERROR, this.getClass(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actOnCommandEvent(PlayerCommandPreprocessEvent event) {
|
|
||||||
String commandName = event.getMessage().substring(1).split(" ")[0].toLowerCase();
|
|
||||||
|
|
||||||
boolean logUnknownCommands = config.isTrue(DataGatheringSettings.LOG_UNKNOWN_COMMANDS);
|
|
||||||
boolean combineCommandAliases = config.isTrue(DataGatheringSettings.COMBINE_COMMAND_ALIASES);
|
|
||||||
|
|
||||||
if (!logUnknownCommands || combineCommandAliases) {
|
|
||||||
Command command = getBukkitCommand(commandName);
|
|
||||||
if (command == null) {
|
|
||||||
if (!logUnknownCommands) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} else if (combineCommandAliases) {
|
|
||||||
commandName = command.getName();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dbSystem.getDatabase().executeTransaction(new CommandStoreTransaction(serverInfo.getServerUUID(), commandName));
|
|
||||||
}
|
|
||||||
|
|
||||||
private Command getBukkitCommand(String commandName) {
|
|
||||||
Command command = plugin.getServer().getPluginCommand(commandName);
|
|
||||||
if (command == null) {
|
|
||||||
try {
|
|
||||||
command = plugin.getServer().getCommandMap().getCommand(commandName);
|
|
||||||
} catch (NoSuchMethodError ignored) {
|
|
||||||
/* Ignored, Bukkit 1.8 has no such method. This method is from Paper */
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return command;
|
|
||||||
}
|
|
||||||
}
|
|
@ -58,6 +58,7 @@ public class ServerKeys {
|
|||||||
public static final Key<List<TPS>> TPS = new Key<>(new Type<List<TPS>>() {}, "tps");
|
public static final Key<List<TPS>> TPS = new Key<>(new Type<List<TPS>>() {}, "tps");
|
||||||
public static final Key<DateObj<Integer>> ALL_TIME_PEAK_PLAYERS = new Key<>(new Type<DateObj<Integer>>() {}, "all_time_peak_players");
|
public static final Key<DateObj<Integer>> ALL_TIME_PEAK_PLAYERS = new Key<>(new Type<DateObj<Integer>>() {}, "all_time_peak_players");
|
||||||
public static final Key<DateObj<Integer>> RECENT_PEAK_PLAYERS = new Key<>(new Type<DateObj<Integer>>() {}, "recent_peak_players");
|
public static final Key<DateObj<Integer>> RECENT_PEAK_PLAYERS = new Key<>(new Type<DateObj<Integer>>() {}, "recent_peak_players");
|
||||||
|
@Deprecated
|
||||||
public static final Key<Map<String, Integer>> COMMAND_USAGE = new Key<>(new Type<Map<String, Integer>>() {}, "command_usage");
|
public static final Key<Map<String, Integer>> COMMAND_USAGE = new Key<>(new Type<Map<String, Integer>>() {}, "command_usage");
|
||||||
public static final Key<List<ExtensionData>> EXTENSION_DATA = new Key<>(new Type<List<ExtensionData>>() {}, "extension_data");
|
public static final Key<List<ExtensionData>> EXTENSION_DATA = new Key<>(new Type<List<ExtensionData>>() {}, "extension_data");
|
||||||
}
|
}
|
@ -1,51 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of Player Analytics (Plan).
|
|
||||||
*
|
|
||||||
* Plan is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License v3 as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* Plan is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.delivery.domain.mutators;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.delivery.domain.container.DataContainer;
|
|
||||||
import com.djrapitops.plan.delivery.domain.keys.ServerKeys;
|
|
||||||
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Mutator for Command Usage Map objects.
|
|
||||||
* <p>
|
|
||||||
* Can be used to easily get different values about the map.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class CommandUseMutator {
|
|
||||||
|
|
||||||
private Map<String, Integer> commandUsage;
|
|
||||||
|
|
||||||
public CommandUseMutator(Map<String, Integer> commandUsage) {
|
|
||||||
this.commandUsage = commandUsage;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static CommandUseMutator forContainer(DataContainer container) {
|
|
||||||
return new CommandUseMutator(container.getValue(ServerKeys.COMMAND_USAGE).orElse(new HashMap<>()));
|
|
||||||
}
|
|
||||||
|
|
||||||
public int commandUsageCount() {
|
|
||||||
int total = 0;
|
|
||||||
for (Integer value : commandUsage.values()) {
|
|
||||||
total += value;
|
|
||||||
}
|
|
||||||
return total;
|
|
||||||
}
|
|
||||||
}
|
|
@ -19,18 +19,19 @@ package com.djrapitops.plan.gathering.importing.data;
|
|||||||
import com.djrapitops.plan.gathering.domain.TPS;
|
import com.djrapitops.plan.gathering.domain.TPS;
|
||||||
import com.djrapitops.plan.gathering.domain.builders.TPSBuilder;
|
import com.djrapitops.plan.gathering.domain.builders.TPSBuilder;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Fuzzlemann
|
* @author Fuzzlemann
|
||||||
*/
|
*/
|
||||||
public class ServerImportData {
|
public class ServerImportData {
|
||||||
|
|
||||||
private Map<String, Integer> commandUsages;
|
|
||||||
private List<TPS> tpsData;
|
private List<TPS> tpsData;
|
||||||
|
|
||||||
private ServerImportData(Map<String, Integer> commandUsages, List<TPS> tpsData) {
|
private ServerImportData(List<TPS> tpsData) {
|
||||||
this.commandUsages = commandUsages;
|
|
||||||
this.tpsData = tpsData;
|
this.tpsData = tpsData;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -38,14 +39,6 @@ public class ServerImportData {
|
|||||||
return new ServerImportDataBuilder();
|
return new ServerImportDataBuilder();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Map<String, Integer> getCommandUsages() {
|
|
||||||
return commandUsages;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setCommandUsages(Map<String, Integer> commandUsages) {
|
|
||||||
this.commandUsages = commandUsages;
|
|
||||||
}
|
|
||||||
|
|
||||||
public List<TPS> getTpsData() {
|
public List<TPS> getTpsData() {
|
||||||
return tpsData;
|
return tpsData;
|
||||||
}
|
}
|
||||||
@ -55,23 +48,12 @@ public class ServerImportData {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static final class ServerImportDataBuilder {
|
public static final class ServerImportDataBuilder {
|
||||||
private final Map<String, Integer> commandUsages = new HashMap<>();
|
|
||||||
private final List<TPS> tpsData = new ArrayList<>();
|
private final List<TPS> tpsData = new ArrayList<>();
|
||||||
|
|
||||||
private ServerImportDataBuilder() {
|
private ServerImportDataBuilder() {
|
||||||
/* Private Constructor */
|
/* Private Constructor */
|
||||||
}
|
}
|
||||||
|
|
||||||
public ServerImportDataBuilder commandUsage(String command, Integer usages) {
|
|
||||||
this.commandUsages.put(command, usages);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ServerImportDataBuilder commandUsages(Map<String, Integer> commandUsages) {
|
|
||||||
this.commandUsages.putAll(commandUsages);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ServerImportDataBuilder tpsData(long date, double ticksPerSecond, int players, double cpuUsage, long usedMemory, int entityCount, int chunksLoaded) {
|
public ServerImportDataBuilder tpsData(long date, double ticksPerSecond, int players, double cpuUsage, long usedMemory, int entityCount, int chunksLoaded) {
|
||||||
TPS tps = TPSBuilder.get()
|
TPS tps = TPSBuilder.get()
|
||||||
.date(date)
|
.date(date)
|
||||||
@ -97,7 +79,7 @@ public class ServerImportData {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public ServerImportData build() {
|
public ServerImportData build() {
|
||||||
return new ServerImportData(commandUsages, tpsData);
|
return new ServerImportData(tpsData);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,43 +42,6 @@ public class DataStoreQueries {
|
|||||||
/* static method class */
|
/* static method class */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Store the used command in the database.
|
|
||||||
*
|
|
||||||
* @param serverUUID UUID of the Plan server.
|
|
||||||
* @param commandName Name of the command that was used.
|
|
||||||
* @return Executable, use inside a {@link com.djrapitops.plan.storage.database.transactions.Transaction}
|
|
||||||
*/
|
|
||||||
public static Executable storeUsedCommandInformation(UUID serverUUID, String commandName) {
|
|
||||||
return connection -> {
|
|
||||||
if (!updateCommandUsage(serverUUID, commandName).execute(connection)) {
|
|
||||||
insertNewCommandUsage(serverUUID, commandName).execute(connection);
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Executable updateCommandUsage(UUID serverUUID, String commandName) {
|
|
||||||
return new ExecStatement(CommandUseTable.UPDATE_STATEMENT) {
|
|
||||||
@Override
|
|
||||||
public void prepare(PreparedStatement statement) throws SQLException {
|
|
||||||
statement.setString(1, serverUUID.toString());
|
|
||||||
statement.setString(2, commandName);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
private static Executable insertNewCommandUsage(UUID serverUUID, String commandName) {
|
|
||||||
return new ExecStatement(CommandUseTable.INSERT_STATEMENT) {
|
|
||||||
@Override
|
|
||||||
public void prepare(PreparedStatement statement) throws SQLException {
|
|
||||||
statement.setString(1, commandName);
|
|
||||||
statement.setInt(2, 1);
|
|
||||||
statement.setString(3, serverUUID.toString());
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Store a finished session in the database.
|
* Store a finished session in the database.
|
||||||
*
|
*
|
||||||
|
@ -18,7 +18,6 @@ package com.djrapitops.plan.storage.database.queries;
|
|||||||
|
|
||||||
import com.djrapitops.plan.gathering.domain.TPS;
|
import com.djrapitops.plan.gathering.domain.TPS;
|
||||||
import com.djrapitops.plan.gathering.domain.builders.TPSBuilder;
|
import com.djrapitops.plan.gathering.domain.builders.TPSBuilder;
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.CommandUseTable;
|
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.ServerTable;
|
import com.djrapitops.plan.storage.database.sql.tables.ServerTable;
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.TPSTable;
|
import com.djrapitops.plan.storage.database.sql.tables.TPSTable;
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.WorldTable;
|
import com.djrapitops.plan.storage.database.sql.tables.WorldTable;
|
||||||
@ -40,41 +39,6 @@ public class LargeFetchQueries {
|
|||||||
/* Static method class */
|
/* Static method class */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Query database for all command usage data.
|
|
||||||
*
|
|
||||||
* @return Multi map: Server UUID - (Command name - Usage count)
|
|
||||||
*/
|
|
||||||
public static Query<Map<UUID, Map<String, Integer>>> fetchAllCommandUsageData() {
|
|
||||||
String serverIDColumn = ServerTable.TABLE_NAME + '.' + ServerTable.SERVER_ID;
|
|
||||||
String serverUUIDColumn = ServerTable.TABLE_NAME + '.' + ServerTable.SERVER_UUID + " as s_uuid";
|
|
||||||
String sql = SELECT +
|
|
||||||
CommandUseTable.COMMAND + ',' +
|
|
||||||
CommandUseTable.TIMES_USED + ',' +
|
|
||||||
serverUUIDColumn +
|
|
||||||
FROM + CommandUseTable.TABLE_NAME +
|
|
||||||
INNER_JOIN + ServerTable.TABLE_NAME + " on " + serverIDColumn + "=" + CommandUseTable.SERVER_ID;
|
|
||||||
|
|
||||||
return new QueryAllStatement<Map<UUID, Map<String, Integer>>>(sql, 10000) {
|
|
||||||
@Override
|
|
||||||
public Map<UUID, Map<String, Integer>> processResults(ResultSet set) throws SQLException {
|
|
||||||
Map<UUID, Map<String, Integer>> map = new HashMap<>();
|
|
||||||
while (set.next()) {
|
|
||||||
UUID serverUUID = UUID.fromString(set.getString("s_uuid"));
|
|
||||||
|
|
||||||
Map<String, Integer> serverMap = map.getOrDefault(serverUUID, new HashMap<>());
|
|
||||||
|
|
||||||
String command = set.getString(CommandUseTable.COMMAND);
|
|
||||||
int timesUsed = set.getInt(CommandUseTable.TIMES_USED);
|
|
||||||
|
|
||||||
serverMap.put(command, timesUsed);
|
|
||||||
map.put(serverUUID, serverMap);
|
|
||||||
}
|
|
||||||
return map;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Query database for TPS data.
|
* Query database for TPS data.
|
||||||
*
|
*
|
||||||
|
@ -44,38 +44,6 @@ public class LargeStoreQueries {
|
|||||||
/* Static method class */
|
/* Static method class */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Execute a big batch of command use insert statements.
|
|
||||||
*
|
|
||||||
* @param ofServers Multi map: Server UUID - (Command name - Usage count)
|
|
||||||
* @return Executable, use inside a {@link com.djrapitops.plan.storage.database.transactions.Transaction}
|
|
||||||
*/
|
|
||||||
public static Executable storeAllCommandUsageData(Map<UUID, Map<String, Integer>> ofServers) {
|
|
||||||
if (ofServers.isEmpty()) {
|
|
||||||
return Executable.empty();
|
|
||||||
}
|
|
||||||
|
|
||||||
return new ExecBatchStatement(CommandUseTable.INSERT_STATEMENT) {
|
|
||||||
@Override
|
|
||||||
public void prepare(PreparedStatement statement) throws SQLException {
|
|
||||||
// Every Server
|
|
||||||
for (Map.Entry<UUID, Map<String, Integer>> serverEntry : ofServers.entrySet()) {
|
|
||||||
UUID serverUUID = serverEntry.getKey();
|
|
||||||
// Every Command
|
|
||||||
for (Map.Entry<String, Integer> entry : serverEntry.getValue().entrySet()) {
|
|
||||||
String command = entry.getKey();
|
|
||||||
int timesUsed = entry.getValue();
|
|
||||||
|
|
||||||
statement.setString(1, command);
|
|
||||||
statement.setInt(2, timesUsed);
|
|
||||||
statement.setString(3, serverUUID.toString());
|
|
||||||
statement.addBatch();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Execute a big batch of GeoInfo insert statements.
|
* Execute a big batch of GeoInfo insert statements.
|
||||||
*
|
*
|
||||||
|
@ -16,8 +16,6 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.storage.database.queries;
|
package com.djrapitops.plan.storage.database.queries;
|
||||||
|
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.CommandUseTable;
|
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.ServerTable;
|
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.UserInfoTable;
|
import com.djrapitops.plan.storage.database.sql.tables.UserInfoTable;
|
||||||
import com.djrapitops.plan.storage.database.sql.tables.UsersTable;
|
import com.djrapitops.plan.storage.database.sql.tables.UsersTable;
|
||||||
|
|
||||||
@ -103,33 +101,4 @@ public class ServerAggregateQueries {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Count how many times commands have been used on a server.
|
|
||||||
*
|
|
||||||
* @param serverUUID Server UUID of the Plan server.
|
|
||||||
* @return Map: Lowercase used command - Count of use times.
|
|
||||||
*/
|
|
||||||
public static Query<Map<String, Integer>> commandUsageCounts(UUID serverUUID) {
|
|
||||||
String sql = SELECT + CommandUseTable.COMMAND + ',' + CommandUseTable.TIMES_USED + FROM + CommandUseTable.TABLE_NAME +
|
|
||||||
WHERE + CommandUseTable.SERVER_ID + "=" + ServerTable.STATEMENT_SELECT_SERVER_ID;
|
|
||||||
|
|
||||||
return new QueryStatement<Map<String, Integer>>(sql, 5000) {
|
|
||||||
@Override
|
|
||||||
public void prepare(PreparedStatement statement) throws SQLException {
|
|
||||||
statement.setString(1, serverUUID.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Map<String, Integer> processResults(ResultSet set) throws SQLException {
|
|
||||||
Map<String, Integer> commandUse = new HashMap<>();
|
|
||||||
while (set.next()) {
|
|
||||||
String cmd = set.getString(CommandUseTable.COMMAND).toLowerCase();
|
|
||||||
int amountUsed = set.getInt(CommandUseTable.TIMES_USED);
|
|
||||||
commandUse.put(cmd, amountUsed);
|
|
||||||
}
|
|
||||||
return commandUse;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,6 @@ import com.djrapitops.plan.gathering.domain.Session;
|
|||||||
import com.djrapitops.plan.identification.Server;
|
import com.djrapitops.plan.identification.Server;
|
||||||
import com.djrapitops.plan.storage.database.SQLDB;
|
import com.djrapitops.plan.storage.database.SQLDB;
|
||||||
import com.djrapitops.plan.storage.database.queries.Query;
|
import com.djrapitops.plan.storage.database.queries.Query;
|
||||||
import com.djrapitops.plan.storage.database.queries.ServerAggregateQueries;
|
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.ServerQueries;
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.TPSQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.TPSQueries;
|
||||||
import com.djrapitops.plan.storage.database.queries.objects.WorldTimesQueries;
|
import com.djrapitops.plan.storage.database.queries.objects.WorldTimesQueries;
|
||||||
@ -79,7 +78,6 @@ public class ServerContainerQuery implements Query<ServerContainer> {
|
|||||||
return db.query(TPSQueries.fetchPeakPlayerCount(serverUUID, twoDaysAgo)).orElse(null);
|
return db.query(TPSQueries.fetchPeakPlayerCount(serverUUID, twoDaysAgo)).orElse(null);
|
||||||
});
|
});
|
||||||
|
|
||||||
container.putCachingSupplier(ServerKeys.COMMAND_USAGE, () -> db.query(ServerAggregateQueries.commandUsageCounts(serverUUID)));
|
|
||||||
container.putCachingSupplier(ServerKeys.WORLD_TIMES, () -> db.query(WorldTimesQueries.fetchServerTotalWorldTimes(serverUUID)));
|
container.putCachingSupplier(ServerKeys.WORLD_TIMES, () -> db.query(WorldTimesQueries.fetchServerTotalWorldTimes(serverUUID)));
|
||||||
|
|
||||||
// Calculating getters
|
// Calculating getters
|
||||||
|
@ -16,13 +16,6 @@
|
|||||||
*/
|
*/
|
||||||
package com.djrapitops.plan.storage.database.sql.tables;
|
package com.djrapitops.plan.storage.database.sql.tables;
|
||||||
|
|
||||||
import com.djrapitops.plan.storage.database.DBType;
|
|
||||||
import com.djrapitops.plan.storage.database.sql.parsing.CreateTableParser;
|
|
||||||
import com.djrapitops.plan.storage.database.sql.parsing.Sql;
|
|
||||||
|
|
||||||
import static com.djrapitops.plan.storage.database.sql.parsing.Sql.AND;
|
|
||||||
import static com.djrapitops.plan.storage.database.sql.parsing.Sql.WHERE;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Table information about 'plan_commandusages'.
|
* Table information about 'plan_commandusages'.
|
||||||
*
|
*
|
||||||
@ -30,38 +23,15 @@ import static com.djrapitops.plan.storage.database.sql.parsing.Sql.WHERE;
|
|||||||
* {@link com.djrapitops.plan.storage.database.transactions.patches.Version10Patch}
|
* {@link com.djrapitops.plan.storage.database.transactions.patches.Version10Patch}
|
||||||
*
|
*
|
||||||
* @author Rsl1122
|
* @author Rsl1122
|
||||||
|
* @deprecated TODO DELETE AFTER DROPPING TABLE
|
||||||
*/
|
*/
|
||||||
|
@Deprecated
|
||||||
public class CommandUseTable {
|
public class CommandUseTable {
|
||||||
|
|
||||||
public static final String TABLE_NAME = "plan_commandusages";
|
public static final String TABLE_NAME = "plan_commandusages";
|
||||||
|
|
||||||
public static final String ID = "id";
|
|
||||||
public static final String SERVER_ID = "server_id";
|
|
||||||
public static final String COMMAND = "command";
|
|
||||||
public static final String TIMES_USED = "times_used";
|
|
||||||
|
|
||||||
public static final String INSERT_STATEMENT = "INSERT INTO " + TABLE_NAME + " ("
|
|
||||||
+ COMMAND + ','
|
|
||||||
+ TIMES_USED + ','
|
|
||||||
+ SERVER_ID
|
|
||||||
+ ") VALUES (?, ?, " + ServerTable.STATEMENT_SELECT_SERVER_ID + ')';
|
|
||||||
|
|
||||||
public static final String UPDATE_STATEMENT = "UPDATE " + CommandUseTable.TABLE_NAME + " SET "
|
|
||||||
+ CommandUseTable.TIMES_USED + "=" + CommandUseTable.TIMES_USED + "+ 1" +
|
|
||||||
WHERE + CommandUseTable.SERVER_ID + "=" + ServerTable.STATEMENT_SELECT_SERVER_ID +
|
|
||||||
AND + CommandUseTable.COMMAND + "=?";
|
|
||||||
|
|
||||||
private CommandUseTable() {
|
private CommandUseTable() {
|
||||||
/* Static information class */
|
/* Static information class */
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String createTableSQL(DBType dbType) {
|
|
||||||
return CreateTableParser.create(TABLE_NAME, dbType)
|
|
||||||
.column(ID, Sql.INT).primaryKey()
|
|
||||||
.column(COMMAND, Sql.varchar(20)).notNull()
|
|
||||||
.column(TIMES_USED, Sql.INT).notNull()
|
|
||||||
.column(SERVER_ID, Sql.INT).notNull()
|
|
||||||
.foreignKey(SERVER_ID, ServerTable.TABLE_NAME, ServerTable.SERVER_ID)
|
|
||||||
.toString();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -55,7 +55,6 @@ public class BackupCopyTransaction extends RemoveEverythingTransaction {
|
|||||||
copyWorldNames();
|
copyWorldNames();
|
||||||
copyTPSData();
|
copyTPSData();
|
||||||
copyPlanWebUsers();
|
copyPlanWebUsers();
|
||||||
copyCommandUsageData();
|
|
||||||
copyGeoInformation();
|
copyGeoInformation();
|
||||||
copyNicknameData();
|
copyNicknameData();
|
||||||
copySessionsWithKillAndWorldData();
|
copySessionsWithKillAndWorldData();
|
||||||
@ -72,10 +71,6 @@ public class BackupCopyTransaction extends RemoveEverythingTransaction {
|
|||||||
copy(LargeStoreQueries::storeAllPingData, PingQueries.fetchAllPingData());
|
copy(LargeStoreQueries::storeAllPingData, PingQueries.fetchAllPingData());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void copyCommandUsageData() {
|
|
||||||
copy(LargeStoreQueries::storeAllCommandUsageData, LargeFetchQueries.fetchAllCommandUsageData());
|
|
||||||
}
|
|
||||||
|
|
||||||
private void copyGeoInformation() {
|
private void copyGeoInformation() {
|
||||||
copy(LargeStoreQueries::storeAllGeoInformation, GeoInfoQueries.fetchAllGeoInformation());
|
copy(LargeStoreQueries::storeAllGeoInformation, GeoInfoQueries.fetchAllGeoInformation());
|
||||||
}
|
}
|
||||||
|
@ -42,7 +42,6 @@ public class RemoveEverythingTransaction extends Transaction {
|
|||||||
clearTable(PingTable.TABLE_NAME);
|
clearTable(PingTable.TABLE_NAME);
|
||||||
clearTable(UserInfoTable.TABLE_NAME);
|
clearTable(UserInfoTable.TABLE_NAME);
|
||||||
clearTable(UsersTable.TABLE_NAME);
|
clearTable(UsersTable.TABLE_NAME);
|
||||||
clearTable(CommandUseTable.TABLE_NAME);
|
|
||||||
clearTable(TPSTable.TABLE_NAME);
|
clearTable(TPSTable.TABLE_NAME);
|
||||||
clearTable(SecurityTable.TABLE_NAME);
|
clearTable(SecurityTable.TABLE_NAME);
|
||||||
clearTable(ServerTable.TABLE_NAME);
|
clearTable(ServerTable.TABLE_NAME);
|
||||||
|
@ -1,51 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of Player Analytics (Plan).
|
|
||||||
*
|
|
||||||
* Plan is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License v3 as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* Plan is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.storage.database.transactions.events;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.storage.database.queries.DataStoreQueries;
|
|
||||||
import com.djrapitops.plan.storage.database.transactions.Transaction;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Transaction to update command usage information in the database.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class CommandStoreTransaction extends Transaction {
|
|
||||||
|
|
||||||
private final UUID serverUUID;
|
|
||||||
private final String commandName;
|
|
||||||
|
|
||||||
public CommandStoreTransaction(
|
|
||||||
UUID serverUUID,
|
|
||||||
String commandName
|
|
||||||
) {
|
|
||||||
this.serverUUID = serverUUID;
|
|
||||||
this.commandName = commandName;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected boolean shouldBeExecuted() {
|
|
||||||
return commandName.length() <= 20;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected void performOperations() {
|
|
||||||
execute(DataStoreQueries.storeUsedCommandInformation(serverUUID, commandName));
|
|
||||||
}
|
|
||||||
}
|
|
@ -39,7 +39,6 @@ public class CreateTablesTransaction extends OperationCriticalTransaction {
|
|||||||
execute(SessionsTable.createTableSQL(dbType));
|
execute(SessionsTable.createTableSQL(dbType));
|
||||||
execute(KillsTable.createTableSQL(dbType));
|
execute(KillsTable.createTableSQL(dbType));
|
||||||
execute(PingTable.createTableSQL(dbType));
|
execute(PingTable.createTableSQL(dbType));
|
||||||
execute(CommandUseTable.createTableSQL(dbType));
|
|
||||||
execute(TPSTable.createTableSQL(dbType));
|
execute(TPSTable.createTableSQL(dbType));
|
||||||
execute(WorldTable.createTableSQL(dbType));
|
execute(WorldTable.createTableSQL(dbType));
|
||||||
execute(WorldTimesTable.createTableSQL(dbType));
|
execute(WorldTimesTable.createTableSQL(dbType));
|
||||||
|
@ -43,8 +43,6 @@ public class Version10Patch extends Patch {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void alterTablesToV10() {
|
public void alterTablesToV10() {
|
||||||
copyCommandUsage();
|
|
||||||
|
|
||||||
copyTPS();
|
copyTPS();
|
||||||
|
|
||||||
dropTable(UserInfoTable.TABLE_NAME);
|
dropTable(UserInfoTable.TABLE_NAME);
|
||||||
@ -103,22 +101,6 @@ public class Version10Patch extends Patch {
|
|||||||
execute(statement);
|
execute(statement);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void copyCommandUsage() {
|
|
||||||
String tempTableName = "temp_cmdusg";
|
|
||||||
|
|
||||||
renameTable("plan_commandusages", tempTableName);
|
|
||||||
|
|
||||||
execute(CommandUseTable.createTableSQL(dbType));
|
|
||||||
|
|
||||||
String statement = "INSERT INTO plan_commandusages " +
|
|
||||||
"(command, times_used, server_id)" +
|
|
||||||
" SELECT command, times_used, '" + serverID + "'" +
|
|
||||||
FROM + tempTableName;
|
|
||||||
execute(statement);
|
|
||||||
|
|
||||||
dropTable(tempTableName);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void copyTPS() {
|
private void copyTPS() {
|
||||||
String tempTableName = "temp_tps";
|
String tempTableName = "temp_tps";
|
||||||
|
|
||||||
|
@ -29,7 +29,6 @@ import utilities.TestConstants;
|
|||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
import static org.junit.jupiter.api.Assertions.*;
|
||||||
@ -49,7 +48,6 @@ class ImportBuilderTest {
|
|||||||
void emptyServerBuilderInitializesCollections() {
|
void emptyServerBuilderInitializesCollections() {
|
||||||
ServerImportData data = ServerImportData.builder().build();
|
ServerImportData data = ServerImportData.builder().build();
|
||||||
|
|
||||||
assertNotNull(data.getCommandUsages());
|
|
||||||
assertNotNull(data.getTpsData());
|
assertNotNull(data.getTpsData());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -93,16 +91,9 @@ class ImportBuilderTest {
|
|||||||
.tpsData(randomInt, randomInt, randomInt, randomInt, randomInt, randomInt, randomInt)
|
.tpsData(randomInt, randomInt, randomInt, randomInt, randomInt, randomInt, randomInt)
|
||||||
.tpsData(Collections.singletonList(tps))
|
.tpsData(Collections.singletonList(tps))
|
||||||
.tpsData(Arrays.asList(tps, tps))
|
.tpsData(Arrays.asList(tps, tps))
|
||||||
.commandUsage(randomString, randomInt)
|
|
||||||
.commandUsage(randomString, randomInt)
|
|
||||||
.commandUsage(randomString, randomInt)
|
|
||||||
.commandUsage(randomString, randomInt)
|
|
||||||
.commandUsages(new HashMap<>())
|
|
||||||
.commandUsages(ImmutableMap.of(randomString, randomInt))
|
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
assertEquals(10, data.getTpsData().size());
|
assertEquals(10, data.getTpsData().size());
|
||||||
assertEquals(1, data.getCommandUsages().size());
|
|
||||||
|
|
||||||
assertEquals(randomInt, data.getTpsData().get(0).getDate());
|
assertEquals(randomInt, data.getTpsData().get(0).getDate());
|
||||||
}
|
}
|
||||||
|
@ -43,7 +43,6 @@ abstract class DBPatchRegressionTest {
|
|||||||
underTest.executeTransaction(new Transaction() {
|
underTest.executeTransaction(new Transaction() {
|
||||||
@Override
|
@Override
|
||||||
protected void performOperations() {
|
protected void performOperations() {
|
||||||
execute("DROP TABLE " + CommandUseTable.TABLE_NAME);
|
|
||||||
execute("DROP TABLE " + GeoInfoTable.TABLE_NAME);
|
execute("DROP TABLE " + GeoInfoTable.TABLE_NAME);
|
||||||
execute("DROP TABLE " + KillsTable.TABLE_NAME);
|
execute("DROP TABLE " + KillsTable.TABLE_NAME);
|
||||||
execute("DROP TABLE " + NicknamesTable.TABLE_NAME);
|
execute("DROP TABLE " + NicknamesTable.TABLE_NAME);
|
||||||
|
@ -146,56 +146,6 @@ public interface DatabaseTest {
|
|||||||
db().init();
|
db().init();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
default void testSaveCommandUse() {
|
|
||||||
Map<String, Integer> expected = new HashMap<>();
|
|
||||||
|
|
||||||
expected.put("plan", 1);
|
|
||||||
expected.put("tp", 4);
|
|
||||||
expected.put("pla", 7);
|
|
||||||
expected.put("help", 21);
|
|
||||||
|
|
||||||
useCommand("plan");
|
|
||||||
useCommand("tp", 4);
|
|
||||||
useCommand("pla", 7);
|
|
||||||
useCommand("help", 21);
|
|
||||||
useCommand("roiergbnougbierubieugbeigubeigubgierbgeugeg", 3);
|
|
||||||
|
|
||||||
commitTest();
|
|
||||||
|
|
||||||
Map<String, Integer> commandUse = db().query(ServerAggregateQueries.commandUsageCounts(serverUUID()));
|
|
||||||
assertEquals(expected, commandUse);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
default void commandUsageSavingDoesNotCreateNewEntriesForOldCommands() {
|
|
||||||
Map<String, Integer> expected = new HashMap<>();
|
|
||||||
|
|
||||||
expected.put("plan", 1);
|
|
||||||
expected.put("test", 3);
|
|
||||||
expected.put("tp", 6);
|
|
||||||
expected.put("pla", 7);
|
|
||||||
expected.put("help", 21);
|
|
||||||
|
|
||||||
testSaveCommandUse();
|
|
||||||
|
|
||||||
useCommand("test", 3);
|
|
||||||
useCommand("tp", 2);
|
|
||||||
|
|
||||||
Map<String, Integer> commandUse = db().query(ServerAggregateQueries.commandUsageCounts(serverUUID()));
|
|
||||||
assertEquals(expected, commandUse);
|
|
||||||
}
|
|
||||||
|
|
||||||
default void useCommand(String commandName) {
|
|
||||||
db().executeTransaction(new CommandStoreTransaction(serverUUID(), commandName));
|
|
||||||
}
|
|
||||||
|
|
||||||
default void useCommand(String commandName, int times) {
|
|
||||||
for (int i = 0; i < times; i++) {
|
|
||||||
useCommand(commandName);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
default void testTPSSaving() {
|
default void testTPSSaving() {
|
||||||
Random r = new Random();
|
Random r = new Random();
|
||||||
@ -494,7 +444,6 @@ public interface DatabaseTest {
|
|||||||
assertQueryIsEmpty(db(), NicknameQueries.fetchAllNicknameData());
|
assertQueryIsEmpty(db(), NicknameQueries.fetchAllNicknameData());
|
||||||
assertQueryIsEmpty(db(), GeoInfoQueries.fetchAllGeoInformation());
|
assertQueryIsEmpty(db(), GeoInfoQueries.fetchAllGeoInformation());
|
||||||
assertTrue(db().query(SessionQueries.fetchAllSessions()).isEmpty());
|
assertTrue(db().query(SessionQueries.fetchAllSessions()).isEmpty());
|
||||||
assertQueryIsEmpty(db(), LargeFetchQueries.fetchAllCommandUsageData());
|
|
||||||
assertQueryIsEmpty(db(), LargeFetchQueries.fetchAllWorldNames());
|
assertQueryIsEmpty(db(), LargeFetchQueries.fetchAllWorldNames());
|
||||||
assertQueryIsEmpty(db(), LargeFetchQueries.fetchAllTPSData());
|
assertQueryIsEmpty(db(), LargeFetchQueries.fetchAllTPSData());
|
||||||
assertQueryIsEmpty(db(), ServerQueries.fetchPlanServerInformation());
|
assertQueryIsEmpty(db(), ServerQueries.fetchPlanServerInformation());
|
||||||
@ -525,13 +474,6 @@ public interface DatabaseTest {
|
|||||||
|
|
||||||
assertTrue(db().query(PlayerFetchQueries.isPlayerRegistered(playerUUID)));
|
assertTrue(db().query(PlayerFetchQueries.isPlayerRegistered(playerUUID)));
|
||||||
|
|
||||||
useCommand("plan");
|
|
||||||
useCommand("plan");
|
|
||||||
useCommand("tp");
|
|
||||||
useCommand("help");
|
|
||||||
useCommand("help");
|
|
||||||
useCommand("help");
|
|
||||||
|
|
||||||
List<TPS> expected = new ArrayList<>();
|
List<TPS> expected = new ArrayList<>();
|
||||||
Random r = new Random();
|
Random r = new Random();
|
||||||
OperatingSystemMXBean operatingSystemMXBean = ManagementFactory.getOperatingSystemMXBean();
|
OperatingSystemMXBean operatingSystemMXBean = ManagementFactory.getOperatingSystemMXBean();
|
||||||
@ -694,7 +636,6 @@ public interface DatabaseTest {
|
|||||||
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
||||||
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
||||||
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllCommandUsageData());
|
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
||||||
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
||||||
@ -722,7 +663,6 @@ public interface DatabaseTest {
|
|||||||
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
assertQueryResultIsEqual(db(), backup, NicknameQueries.fetchAllNicknameData());
|
||||||
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
assertQueryResultIsEqual(db(), backup, GeoInfoQueries.fetchAllGeoInformation());
|
||||||
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
assertQueryResultIsEqual(db(), backup, SessionQueries.fetchAllSessions());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllCommandUsageData());
|
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllWorldNames());
|
||||||
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
assertQueryResultIsEqual(db(), backup, LargeFetchQueries.fetchAllTPSData());
|
||||||
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
assertQueryResultIsEqual(db(), backup, ServerQueries.fetchPlanServerInformation());
|
||||||
|
@ -33,7 +33,6 @@ public class SpongeListenerSystem extends ListenerSystem {
|
|||||||
|
|
||||||
private final SpongeAFKListener afkListener;
|
private final SpongeAFKListener afkListener;
|
||||||
private final SpongeChatListener chatListener;
|
private final SpongeChatListener chatListener;
|
||||||
private final SpongeCommandListener commandListener;
|
|
||||||
private final SpongeDeathListener deathListener;
|
private final SpongeDeathListener deathListener;
|
||||||
private final SpongeGMChangeListener gmChangeListener;
|
private final SpongeGMChangeListener gmChangeListener;
|
||||||
private final PlayerOnlineListener playerListener;
|
private final PlayerOnlineListener playerListener;
|
||||||
@ -45,7 +44,6 @@ public class SpongeListenerSystem extends ListenerSystem {
|
|||||||
PlanSponge plugin,
|
PlanSponge plugin,
|
||||||
SpongeAFKListener afkListener,
|
SpongeAFKListener afkListener,
|
||||||
SpongeChatListener chatListener,
|
SpongeChatListener chatListener,
|
||||||
SpongeCommandListener commandListener,
|
|
||||||
SpongeDeathListener deathListener,
|
SpongeDeathListener deathListener,
|
||||||
SpongeGMChangeListener gmChangeListener,
|
SpongeGMChangeListener gmChangeListener,
|
||||||
PlayerOnlineListener playerListener,
|
PlayerOnlineListener playerListener,
|
||||||
@ -56,7 +54,6 @@ public class SpongeListenerSystem extends ListenerSystem {
|
|||||||
|
|
||||||
this.afkListener = afkListener;
|
this.afkListener = afkListener;
|
||||||
this.chatListener = chatListener;
|
this.chatListener = chatListener;
|
||||||
this.commandListener = commandListener;
|
|
||||||
this.deathListener = deathListener;
|
this.deathListener = deathListener;
|
||||||
this.gmChangeListener = gmChangeListener;
|
this.gmChangeListener = gmChangeListener;
|
||||||
this.playerListener = playerListener;
|
this.playerListener = playerListener;
|
||||||
@ -69,7 +66,6 @@ public class SpongeListenerSystem extends ListenerSystem {
|
|||||||
plugin.registerListener(
|
plugin.registerListener(
|
||||||
afkListener,
|
afkListener,
|
||||||
chatListener,
|
chatListener,
|
||||||
commandListener,
|
|
||||||
deathListener,
|
deathListener,
|
||||||
playerListener,
|
playerListener,
|
||||||
gmChangeListener,
|
gmChangeListener,
|
||||||
|
@ -1,95 +0,0 @@
|
|||||||
/*
|
|
||||||
* This file is part of Player Analytics (Plan).
|
|
||||||
*
|
|
||||||
* Plan is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU Lesser General Public License v3 as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* Plan is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU Lesser General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU Lesser General Public License
|
|
||||||
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
package com.djrapitops.plan.gathering.listeners.sponge;
|
|
||||||
|
|
||||||
import com.djrapitops.plan.identification.ServerInfo;
|
|
||||||
import com.djrapitops.plan.settings.Permissions;
|
|
||||||
import com.djrapitops.plan.settings.config.PlanConfig;
|
|
||||||
import com.djrapitops.plan.settings.config.paths.DataGatheringSettings;
|
|
||||||
import com.djrapitops.plan.storage.database.DBSystem;
|
|
||||||
import com.djrapitops.plan.storage.database.transactions.events.CommandStoreTransaction;
|
|
||||||
import com.djrapitops.plugin.logging.L;
|
|
||||||
import com.djrapitops.plugin.logging.error.ErrorHandler;
|
|
||||||
import org.spongepowered.api.Sponge;
|
|
||||||
import org.spongepowered.api.command.CommandMapping;
|
|
||||||
import org.spongepowered.api.entity.living.player.Player;
|
|
||||||
import org.spongepowered.api.event.Listener;
|
|
||||||
import org.spongepowered.api.event.Order;
|
|
||||||
import org.spongepowered.api.event.command.SendCommandEvent;
|
|
||||||
import org.spongepowered.api.event.filter.cause.First;
|
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Listener that keeps track of used commands.
|
|
||||||
*
|
|
||||||
* @author Rsl1122
|
|
||||||
*/
|
|
||||||
public class SpongeCommandListener {
|
|
||||||
|
|
||||||
private final PlanConfig config;
|
|
||||||
private final ServerInfo serverInfo;
|
|
||||||
private final DBSystem dbSystem;
|
|
||||||
private final ErrorHandler errorHandler;
|
|
||||||
|
|
||||||
@Inject
|
|
||||||
public SpongeCommandListener(
|
|
||||||
PlanConfig config,
|
|
||||||
ServerInfo serverInfo,
|
|
||||||
DBSystem dbSystem,
|
|
||||||
ErrorHandler errorHandler
|
|
||||||
) {
|
|
||||||
this.config = config;
|
|
||||||
this.serverInfo = serverInfo;
|
|
||||||
this.dbSystem = dbSystem;
|
|
||||||
this.errorHandler = errorHandler;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Listener(order = Order.POST)
|
|
||||||
public void onPlayerCommand(SendCommandEvent event, @First Player player) {
|
|
||||||
boolean hasIgnorePermission = player.hasPermission(Permissions.IGNORE_COMMAND_USE.getPermission());
|
|
||||||
if (event.isCancelled() || hasIgnorePermission) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
try {
|
|
||||||
actOnCommandEvent(event);
|
|
||||||
} catch (Exception e) {
|
|
||||||
errorHandler.log(L.ERROR, this.getClass(), e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void actOnCommandEvent(SendCommandEvent event) {
|
|
||||||
String commandName = event.getCommand();
|
|
||||||
|
|
||||||
boolean logUnknownCommands = config.isTrue(DataGatheringSettings.LOG_UNKNOWN_COMMANDS);
|
|
||||||
boolean combineCommandAliases = config.isTrue(DataGatheringSettings.COMBINE_COMMAND_ALIASES);
|
|
||||||
|
|
||||||
if (!logUnknownCommands || combineCommandAliases) {
|
|
||||||
Optional<? extends CommandMapping> existingCommand = Sponge.getCommandManager().get(commandName);
|
|
||||||
if (!existingCommand.isPresent()) {
|
|
||||||
if (!logUnknownCommands) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} else if (combineCommandAliases) {
|
|
||||||
commandName = existingCommand.get().getPrimaryAlias();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
dbSystem.getDatabase().executeTransaction(new CommandStoreTransaction(serverInfo.getServerUUID(), commandName));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user