From 3d981241ebd3b476794d6e7cbb2427c24d4b65fa Mon Sep 17 00:00:00 2001 From: asofold Date: Mon, 8 Oct 2012 06:11:59 +0200 Subject: [PATCH] Delete data and history if system time ran backwards. --- .../neatmonster/nocheatplus/utilities/TickTask.java | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/fr/neatmonster/nocheatplus/utilities/TickTask.java b/src/fr/neatmonster/nocheatplus/utilities/TickTask.java index 3e171de6..f4d4b2e4 100644 --- a/src/fr/neatmonster/nocheatplus/utilities/TickTask.java +++ b/src/fr/neatmonster/nocheatplus/utilities/TickTask.java @@ -13,6 +13,7 @@ import fr.neatmonster.nocheatplus.NoCheatPlus; import fr.neatmonster.nocheatplus.checks.CheckType; import fr.neatmonster.nocheatplus.checks.ViolationData; import fr.neatmonster.nocheatplus.checks.access.ICheckData; +import fr.neatmonster.nocheatplus.players.DataManager; /** * Task to run every tick, to update permissions and execute actions, and maybe later for extended lag measurement. @@ -58,6 +59,8 @@ public class TickTask implements Runnable { protected static long timeStart = 0; + protected static long timeLast = 0; + ////////////////////////////////////////////////////////////// // Special static methods, usually not called from outside. @@ -141,6 +144,10 @@ public class TickTask implements Runnable { return timeStart; } + public static final long getTimeLast(){ + return timeLast; + } + //////////////////////////////////////// // Public methods for internal use. //////////////////////////////////////// @@ -165,9 +172,15 @@ public class TickTask implements Runnable { @Override public void run() { tick ++; + final long time = System.currentTimeMillis(); // The isEmpty checks are faster than synchronizing fully always, the actions get delayed one tick at most. if (!delayedActions.isEmpty()) executeActions(); if (!permissionUpdates.isEmpty()) updatePermissions(); + if (timeLast > time){ + CheckUtils.logSevere("[NoCheatPlus] System time ran backwards (" + timeLast + "->" + time + "), clear all data and history..."); + DataManager.clear(CheckType.ALL); + } + timeLast = time; } }