Delete data and history if system time ran backwards.

This commit is contained in:
asofold 2012-10-08 06:11:59 +02:00
parent a209b806c8
commit 3d981241eb

View File

@ -13,6 +13,7 @@ import fr.neatmonster.nocheatplus.NoCheatPlus;
import fr.neatmonster.nocheatplus.checks.CheckType; import fr.neatmonster.nocheatplus.checks.CheckType;
import fr.neatmonster.nocheatplus.checks.ViolationData; import fr.neatmonster.nocheatplus.checks.ViolationData;
import fr.neatmonster.nocheatplus.checks.access.ICheckData; 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. * 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 timeStart = 0;
protected static long timeLast = 0;
////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////
// Special static methods, usually not called from outside. // Special static methods, usually not called from outside.
@ -141,6 +144,10 @@ public class TickTask implements Runnable {
return timeStart; return timeStart;
} }
public static final long getTimeLast(){
return timeLast;
}
//////////////////////////////////////// ////////////////////////////////////////
// Public methods for internal use. // Public methods for internal use.
//////////////////////////////////////// ////////////////////////////////////////
@ -165,9 +172,15 @@ public class TickTask implements Runnable {
@Override @Override
public void run() { public void run() {
tick ++; tick ++;
final long time = System.currentTimeMillis();
// The isEmpty checks are faster than synchronizing fully always, the actions get delayed one tick at most. // The isEmpty checks are faster than synchronizing fully always, the actions get delayed one tick at most.
if (!delayedActions.isEmpty()) executeActions(); if (!delayedActions.isEmpty()) executeActions();
if (!permissionUpdates.isEmpty()) updatePermissions(); 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;
} }
} }