mirror of
https://github.com/NoCheatPlus/NoCheatPlus.git
synced 2025-01-20 06:21:23 +01:00
Delete data and history if system time ran backwards.
This commit is contained in:
parent
a209b806c8
commit
3d981241eb
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user