mirror of
https://github.com/plan-player-analytics/Plan.git
synced 2024-10-27 13:59:56 +01:00
Log file cleaning #510
This commit is contained in:
parent
ecd56a1bf7
commit
70e70ee958
@ -8,7 +8,11 @@ import com.djrapitops.plan.PlanPlugin;
|
||||
import com.djrapitops.plan.api.exceptions.EnableException;
|
||||
import com.djrapitops.plan.system.PlanSystem;
|
||||
import com.djrapitops.plan.system.SubSystem;
|
||||
import com.djrapitops.plan.system.tasks.LogsFolderCleanTask;
|
||||
import com.djrapitops.plan.utilities.file.FileUtil;
|
||||
import com.djrapitops.plugin.api.TimeAmount;
|
||||
import com.djrapitops.plugin.api.utility.log.Log;
|
||||
import com.djrapitops.plugin.task.RunnableFactory;
|
||||
import com.djrapitops.plugin.utilities.Verify;
|
||||
|
||||
import java.io.File;
|
||||
@ -63,10 +67,11 @@ public class FileSystem implements SubSystem {
|
||||
if (configFile.exists()) {
|
||||
configFile.createNewFile();
|
||||
}
|
||||
RunnableFactory.createNew(new LogsFolderCleanTask(Log.getLogsFolder()))
|
||||
.runTaskLaterAsynchronously(TimeAmount.SECOND.ticks() * 30L);
|
||||
} catch (IOException e) {
|
||||
throw new EnableException("Failed to create config.yml", e);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -50,6 +50,7 @@ public enum Settings {
|
||||
MAX_PLAYERS("Customization.Display.MaxPlayers"),
|
||||
MAX_PLAYERS_PLAYERS_PAGE("Customization.Display.MaxPlayersPlayersPage"),
|
||||
AFK_THRESHOLD_MINUTES("Data.AFKThresholdMinutes"),
|
||||
KEEP_LOGS_DAYS("Plugin.KeepLogsForXDays"),
|
||||
|
||||
// String
|
||||
DEBUG("Plugin.Debug"),
|
||||
|
@ -21,6 +21,8 @@ import java.util.Map;
|
||||
import java.util.Optional;
|
||||
import java.util.UUID;
|
||||
|
||||
import static com.djrapitops.plan.system.settings.Settings.*;
|
||||
|
||||
/**
|
||||
* Class for managing Config setting transfer from Bungee to Bukkit servers.
|
||||
*
|
||||
@ -36,7 +38,7 @@ public class NetworkSettings {
|
||||
return;
|
||||
}
|
||||
|
||||
if (Settings.BUNGEE_OVERRIDE_STANDALONE_MODE.isTrue() || Settings.BUNGEE_COPY_CONFIG.isFalse()) {
|
||||
if (BUNGEE_OVERRIDE_STANDALONE_MODE.isTrue() || BUNGEE_COPY_CONFIG.isFalse()) {
|
||||
return;
|
||||
}
|
||||
|
||||
@ -134,27 +136,50 @@ public class NetworkSettings {
|
||||
private Map<String, Object> getConfigValues() throws DBException {
|
||||
Log.debug("NetworkSettings: Loading Config Values..");
|
||||
Map<String, Object> configValues = new HashMap<>();
|
||||
addConfigValue(configValues, Settings.DB_TYPE, "mysql");
|
||||
addConfigValue(configValues, DB_TYPE, "mysql");
|
||||
Settings[] sameStrings = new Settings[]{
|
||||
Settings.DB_HOST, Settings.DB_USER, Settings.DB_PASS,
|
||||
Settings.DB_DATABASE, Settings.DB_LAUNCH_OPTIONS,
|
||||
Settings.FORMAT_DECIMALS, Settings.FORMAT_SECONDS,
|
||||
Settings.FORMAT_DAY, Settings.FORMAT_DAYS, Settings.FORMAT_HOURS,
|
||||
Settings.FORMAT_MINUTES, Settings.FORMAT_MONTHS, Settings.FORMAT_MONTH,
|
||||
Settings.FORMAT_YEAR, Settings.FORMAT_YEARS, Settings.FORMAT_ZERO_SECONDS,
|
||||
Settings.USE_SERVER_TIME, Settings.DISPLAY_SESSIONS_AS_TABLE, Settings.APPEND_WORLD_PERC,
|
||||
Settings.ORDER_WORLD_PIE_BY_PERC, Settings.MAX_SESSIONS, Settings.MAX_PLAYERS,
|
||||
Settings.MAX_PLAYERS_PLAYERS_PAGE, Settings.PLAYERTABLE_FOOTER, Settings.FORMAT_DATE_RECENT_DAYS,
|
||||
Settings.FORMAT_DATE_RECENT_DAYS_PATTERN, Settings.FORMAT_DATE_CLOCK, Settings.FORMAT_DATE_NO_SECONDS,
|
||||
Settings.FORMAT_DATE_FULL, Settings.DISPLAY_PLAYER_IPS, Settings.ACTIVE_LOGIN_THRESHOLD,
|
||||
Settings.ACTIVE_PLAY_THRESHOLD, Settings.DISPLAY_GAPS_IN_GRAPH_DATA, Settings.AFK_THRESHOLD_MINUTES,
|
||||
Settings.DATA_GEOLOCATIONS
|
||||
DB_HOST,
|
||||
DB_USER,
|
||||
DB_PASS,
|
||||
DB_DATABASE,
|
||||
DB_LAUNCH_OPTIONS,
|
||||
FORMAT_DECIMALS,
|
||||
FORMAT_SECONDS,
|
||||
FORMAT_DAY,
|
||||
FORMAT_DAYS,
|
||||
FORMAT_HOURS,
|
||||
FORMAT_MINUTES,
|
||||
FORMAT_MONTHS,
|
||||
FORMAT_MONTH,
|
||||
FORMAT_YEAR,
|
||||
FORMAT_YEARS,
|
||||
FORMAT_ZERO_SECONDS,
|
||||
USE_SERVER_TIME,
|
||||
DISPLAY_SESSIONS_AS_TABLE,
|
||||
APPEND_WORLD_PERC,
|
||||
ORDER_WORLD_PIE_BY_PERC,
|
||||
MAX_SESSIONS,
|
||||
MAX_PLAYERS,
|
||||
MAX_PLAYERS_PLAYERS_PAGE,
|
||||
PLAYERTABLE_FOOTER,
|
||||
FORMAT_DATE_RECENT_DAYS,
|
||||
FORMAT_DATE_RECENT_DAYS_PATTERN,
|
||||
FORMAT_DATE_CLOCK,
|
||||
FORMAT_DATE_NO_SECONDS,
|
||||
FORMAT_DATE_FULL,
|
||||
DISPLAY_PLAYER_IPS,
|
||||
ACTIVE_LOGIN_THRESHOLD,
|
||||
ACTIVE_PLAY_THRESHOLD,
|
||||
DISPLAY_GAPS_IN_GRAPH_DATA,
|
||||
AFK_THRESHOLD_MINUTES,
|
||||
DATA_GEOLOCATIONS,
|
||||
KEEP_LOGS_DAYS
|
||||
};
|
||||
Log.debug("NetworkSettings: Adding Config Values..");
|
||||
for (Settings setting : sameStrings) {
|
||||
addConfigValue(configValues, setting, setting.toString());
|
||||
}
|
||||
addConfigValue(configValues, Settings.DB_PORT, Settings.DB_PORT.getNumber());
|
||||
addConfigValue(configValues, DB_PORT, DB_PORT.getNumber());
|
||||
addServerSpecificValues(configValues);
|
||||
return configValues;
|
||||
}
|
||||
@ -176,18 +201,18 @@ public class NetworkSettings {
|
||||
ServerSpecificSettings settings = Settings.serverSpecific();
|
||||
|
||||
for (UUID serverUUID : Database.getActive().fetch().getServerUUIDs()) {
|
||||
String theme = settings.getString(serverUUID, Settings.THEME_BASE);
|
||||
Integer port = settings.getInt(serverUUID, Settings.WEBSERVER_PORT);
|
||||
String name = settings.getString(serverUUID, Settings.SERVER_NAME);
|
||||
String theme = settings.getString(serverUUID, THEME_BASE);
|
||||
Integer port = settings.getInt(serverUUID, WEBSERVER_PORT);
|
||||
String name = settings.getString(serverUUID, SERVER_NAME);
|
||||
|
||||
if (!Verify.isEmpty(theme)) {
|
||||
addConfigValue(configValues, serverUUID, Settings.THEME_BASE, theme);
|
||||
addConfigValue(configValues, serverUUID, THEME_BASE, theme);
|
||||
}
|
||||
if (port != null && port != 0) {
|
||||
addConfigValue(configValues, serverUUID, Settings.WEBSERVER_PORT, port);
|
||||
addConfigValue(configValues, serverUUID, WEBSERVER_PORT, port);
|
||||
}
|
||||
if (!Verify.isEmpty(name)) {
|
||||
addConfigValue(configValues, serverUUID, Settings.SERVER_NAME, name);
|
||||
addConfigValue(configValues, serverUUID, SERVER_NAME, name);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,54 @@
|
||||
package com.djrapitops.plan.system.tasks;
|
||||
|
||||
import com.djrapitops.plan.system.settings.Settings;
|
||||
import com.djrapitops.plugin.api.TimeAmount;
|
||||
import com.djrapitops.plugin.api.utility.log.Log;
|
||||
import com.djrapitops.plugin.task.AbsRunnable;
|
||||
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
import java.nio.file.Files;
|
||||
import java.util.Objects;
|
||||
|
||||
/**
|
||||
* Task in charge of removing old log files
|
||||
*
|
||||
* @author Rsl1122
|
||||
*/
|
||||
public class LogsFolderCleanTask extends AbsRunnable {
|
||||
|
||||
private final File folder;
|
||||
|
||||
public LogsFolderCleanTask(File folder) {
|
||||
super(LogsFolderCleanTask.class.getSimpleName());
|
||||
this.folder = folder;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void run() {
|
||||
try {
|
||||
if (!folder.exists() || folder.isFile()) {
|
||||
return;
|
||||
}
|
||||
cleanFolder();
|
||||
} catch (NullPointerException ignore) {
|
||||
/* Ignored - not supposed to occur. */
|
||||
} finally {
|
||||
cancel();
|
||||
}
|
||||
}
|
||||
|
||||
private void cleanFolder() {
|
||||
long now = System.currentTimeMillis();
|
||||
for (File file : Objects.requireNonNull(folder.listFiles())) {
|
||||
long forDaysMs = Settings.KEEP_LOGS_DAYS.getNumber() * TimeAmount.DAY.ms();
|
||||
if (now - file.lastModified() > (forDaysMs > 0 ? forDaysMs : TimeAmount.DAY.ms())) {
|
||||
try {
|
||||
Files.delete(file.toPath());
|
||||
} catch (IOException e) {
|
||||
Log.warn("Could not delete log file at: " + file.getAbsolutePath() + ", " + e.getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -14,6 +14,7 @@ Plugin:
|
||||
Locale: default
|
||||
Allow-Update-Command: true
|
||||
Notify-About-DEV-Releases: false
|
||||
KeepLogsForXDays: 7
|
||||
|
||||
# -----------------------------------------------------
|
||||
# More information about SSL Certificate Settings:
|
||||
|
@ -19,6 +19,7 @@ Plugin:
|
||||
CopyBungeeConfig: true
|
||||
Allow-Update-Command: true
|
||||
Notify-About-DEV-Releases: false
|
||||
KeepLogsForXDays: 7
|
||||
|
||||
# -----------------------------------------------------
|
||||
# More information about SSL Certificate Settings:
|
||||
|
Loading…
Reference in New Issue
Block a user