mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-22 21:26:45 +01:00
Add account age expiry filter
This commit is contained in:
parent
6ed6f607b5
commit
3039331976
@ -26,6 +26,7 @@ import java.util.List;
|
|||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.World;
|
import org.bukkit.World;
|
||||||
|
import org.bukkit.entity.Player;
|
||||||
|
|
||||||
public class FileUUIDHandler extends UUIDHandlerImplementation {
|
public class FileUUIDHandler extends UUIDHandlerImplementation {
|
||||||
|
|
||||||
@ -101,8 +102,10 @@ public class FileUUIDHandler extends UUIDHandlerImplementation {
|
|||||||
NbtFactory.NbtCompound bukkit = (NbtFactory.NbtCompound) compound.get("bukkit");
|
NbtFactory.NbtCompound bukkit = (NbtFactory.NbtCompound) compound.get("bukkit");
|
||||||
String name = (String) bukkit.get("lastKnownName");
|
String name = (String) bukkit.get("lastKnownName");
|
||||||
long last = (long) bukkit.get("lastPlayed");
|
long last = (long) bukkit.get("lastPlayed");
|
||||||
|
long first = (long) bukkit.get("firstPlayed");
|
||||||
if (ExpireManager.IMP != null) {
|
if (ExpireManager.IMP != null) {
|
||||||
ExpireManager.IMP.storeDate(uuid, last);
|
ExpireManager.IMP.storeDate(uuid, last);
|
||||||
|
ExpireManager.IMP.storeAccountAge(uuid, last - first);
|
||||||
}
|
}
|
||||||
toAdd.put(new StringWrapper(name), uuid);
|
toAdd.put(new StringWrapper(name), uuid);
|
||||||
}
|
}
|
||||||
@ -168,6 +171,7 @@ public class FileUUIDHandler extends UUIDHandlerImplementation {
|
|||||||
StringWrapper wrap = new StringWrapper(name);
|
StringWrapper wrap = new StringWrapper(name);
|
||||||
if (!toAdd.containsKey(wrap)) {
|
if (!toAdd.containsKey(wrap)) {
|
||||||
long last = (long) bukkit.get("lastPlayed");
|
long last = (long) bukkit.get("lastPlayed");
|
||||||
|
long first = (long) bukkit.get("firstPlayed");
|
||||||
if (Settings.UUID.OFFLINE) {
|
if (Settings.UUID.OFFLINE) {
|
||||||
if (Settings.UUID.FORCE_LOWERCASE && !name.toLowerCase().equals(name)) {
|
if (Settings.UUID.FORCE_LOWERCASE && !name.toLowerCase().equals(name)) {
|
||||||
uuid = FileUUIDHandler.this.uuidWrapper.getUUID(name);
|
uuid = FileUUIDHandler.this.uuidWrapper.getUUID(name);
|
||||||
@ -179,6 +183,7 @@ public class FileUUIDHandler extends UUIDHandlerImplementation {
|
|||||||
}
|
}
|
||||||
if (ExpireManager.IMP != null) {
|
if (ExpireManager.IMP != null) {
|
||||||
ExpireManager.IMP.storeDate(uuid, last);
|
ExpireManager.IMP.storeDate(uuid, last);
|
||||||
|
ExpireManager.IMP.storeAccountAge(uuid, last - first);
|
||||||
}
|
}
|
||||||
toAdd.put(wrap, uuid);
|
toAdd.put(wrap, uuid);
|
||||||
}
|
}
|
||||||
|
@ -158,8 +158,10 @@ public class Settings extends Config {
|
|||||||
public int REQUIRED_PLOTS = -1;
|
public int REQUIRED_PLOTS = -1;
|
||||||
public boolean CONFIRMATION = true;
|
public boolean CONFIRMATION = true;
|
||||||
public int DAYS = 7;
|
public int DAYS = 7;
|
||||||
|
public int SKIP_ACCOUNT_AGE_DAYS = -1;
|
||||||
public List<String> WORLDS = new ArrayList<>(Collections.singletonList("*"));
|
public List<String> WORLDS = new ArrayList<>(Collections.singletonList("*"));
|
||||||
|
|
||||||
|
|
||||||
@Comment("See: https://github.com/IntellectualSites/PlotSquared/wiki/Plot-analysis")
|
@Comment("See: https://github.com/IntellectualSites/PlotSquared/wiki/Plot-analysis")
|
||||||
public static final class CALIBRATION {
|
public static final class CALIBRATION {
|
||||||
public int VARIETY = 0;
|
public int VARIETY = 0;
|
||||||
|
@ -35,6 +35,7 @@ public class ExpireManager {
|
|||||||
|
|
||||||
public static ExpireManager IMP;
|
public static ExpireManager IMP;
|
||||||
private final ConcurrentHashMap<UUID, Long> dates_cache;
|
private final ConcurrentHashMap<UUID, Long> dates_cache;
|
||||||
|
private final ConcurrentHashMap<UUID, Long> account_age_cache;
|
||||||
private volatile HashSet<Plot> plotsToDelete;
|
private volatile HashSet<Plot> plotsToDelete;
|
||||||
private ArrayDeque<ExpiryTask> tasks;
|
private ArrayDeque<ExpiryTask> tasks;
|
||||||
/**
|
/**
|
||||||
@ -45,6 +46,7 @@ public class ExpireManager {
|
|||||||
public ExpireManager() {
|
public ExpireManager() {
|
||||||
tasks = new ArrayDeque<>();
|
tasks = new ArrayDeque<>();
|
||||||
dates_cache = new ConcurrentHashMap<>();
|
dates_cache = new ConcurrentHashMap<>();
|
||||||
|
account_age_cache = new ConcurrentHashMap<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addTask(ExpiryTask task) {
|
public void addTask(ExpiryTask task) {
|
||||||
@ -73,6 +75,16 @@ public class ExpireManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the account last joined - first joined (or Long.MAX_VALUE)
|
||||||
|
* @param uuid
|
||||||
|
* @return result
|
||||||
|
*/
|
||||||
|
public long getAccountAge(UUID uuid) {
|
||||||
|
Long value = this.account_age_cache.get(uuid);
|
||||||
|
return value == null ? Long.MAX_VALUE : value;
|
||||||
|
}
|
||||||
|
|
||||||
public long getTimestamp(UUID uuid) {
|
public long getTimestamp(UUID uuid) {
|
||||||
Long value = this.dates_cache.get(uuid);
|
Long value = this.dates_cache.get(uuid);
|
||||||
return value == null ? 0 : value;
|
return value == null ? 0 : value;
|
||||||
@ -163,6 +175,8 @@ public class ExpireManager {
|
|||||||
if (applicable.isEmpty()) {
|
if (applicable.isEmpty()) {
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
boolean shouldCheckAccountAge = false;
|
||||||
|
|
||||||
long diff = getAge(plot);
|
long diff = getAge(plot);
|
||||||
if (diff == 0) {
|
if (diff == 0) {
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
@ -172,11 +186,26 @@ public class ExpireManager {
|
|||||||
ExpiryTask et = applicable.poll();
|
ExpiryTask et = applicable.poll();
|
||||||
if (et.applies(diff)) {
|
if (et.applies(diff)) {
|
||||||
applicable.add(et);
|
applicable.add(et);
|
||||||
|
shouldCheckAccountAge |= et.getSettings().SKIP_ACCOUNT_AGE_DAYS != -1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (applicable.isEmpty()) {
|
if (applicable.isEmpty()) {
|
||||||
return new ArrayList<>();
|
return new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
// Check account age
|
||||||
|
if (shouldCheckAccountAge) {
|
||||||
|
long accountAge = getAge(plot);
|
||||||
|
for (int i = 0; i < applicable.size(); i++) {
|
||||||
|
ExpiryTask et = applicable.poll();
|
||||||
|
if (et.appliesAccountAge(accountAge)) {
|
||||||
|
applicable.add(et);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (applicable.isEmpty()) {
|
||||||
|
return new ArrayList<>();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Run applicable non confirming tasks
|
// Run applicable non confirming tasks
|
||||||
for (int i = 0; i < applicable.size(); i++) {
|
for (int i = 0; i < applicable.size(); i++) {
|
||||||
ExpiryTask expiryTask = applicable.poll();
|
ExpiryTask expiryTask = applicable.poll();
|
||||||
@ -334,7 +363,19 @@ public class ExpireManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void storeDate(UUID uuid, long time) {
|
public void storeDate(UUID uuid, long time) {
|
||||||
this.dates_cache.put(uuid, time);
|
Long existing = this.dates_cache.put(uuid, time);
|
||||||
|
if (existing != null) {
|
||||||
|
long diff = time - existing;
|
||||||
|
if (diff > 0) {
|
||||||
|
Long account_age = this.account_age_cache.get(uuid);
|
||||||
|
if (account_age != null)
|
||||||
|
this.account_age_cache.put(uuid, account_age + diff);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void storeAccountAge(UUID uuid, long time) {
|
||||||
|
this.account_age_cache.put(uuid, time);
|
||||||
}
|
}
|
||||||
|
|
||||||
public HashSet<Plot> getPendingExpired() {
|
public HashSet<Plot> getPendingExpired() {
|
||||||
@ -399,6 +440,18 @@ public class ExpireManager {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public long getAccountAge(Plot plot) {
|
||||||
|
if (!plot.hasOwner() || Objects.equals(DBFunc.everyone, plot.owner) || UUIDHandler.getPlayer(plot.owner) != null || plot.getRunning() > 0) {
|
||||||
|
return Long.MAX_VALUE;
|
||||||
|
}
|
||||||
|
long max = 0;
|
||||||
|
for (UUID owner : plot.getOwners()) {
|
||||||
|
long age = getAccountAge(owner);
|
||||||
|
max = Math.max(age, max);
|
||||||
|
}
|
||||||
|
return max;
|
||||||
|
}
|
||||||
|
|
||||||
public long getAge(Plot plot) {
|
public long getAge(Plot plot) {
|
||||||
if (!plot.hasOwner() || Objects.equals(DBFunc.everyone, plot.owner) || UUIDHandler.getPlayer(plot.owner) != null || plot.getRunning() > 0) {
|
if (!plot.hasOwner() || Objects.equals(DBFunc.everyone, plot.owner) || UUIDHandler.getPlayer(plot.owner) != null || plot.getRunning() > 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -18,6 +18,10 @@ public class ExpiryTask {
|
|||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Settings.Auto_Clear getSettings() {
|
||||||
|
return settings;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean allowsArea(PlotArea area) {
|
public boolean allowsArea(PlotArea area) {
|
||||||
return settings.WORLDS.contains(area.toString()) || settings.WORLDS.contains(area.worldname) || settings.WORLDS.contains("*");
|
return settings.WORLDS.contains(area.toString()) || settings.WORLDS.contains(area.worldname) || settings.WORLDS.contains("*");
|
||||||
}
|
}
|
||||||
@ -99,6 +103,12 @@ public class ExpiryTask {
|
|||||||
return diff > TimeUnit.DAYS.toMillis(settings.DAYS) && diff > cutoffThreshold;
|
return diff > TimeUnit.DAYS.toMillis(settings.DAYS) && diff > cutoffThreshold;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean appliesAccountAge(long accountAge) {
|
||||||
|
if (settings.SKIP_ACCOUNT_AGE_DAYS != -1)
|
||||||
|
return accountAge <= TimeUnit.DAYS.toMillis(settings.SKIP_ACCOUNT_AGE_DAYS);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean needsAnalysis() {
|
public boolean needsAnalysis() {
|
||||||
return settings.THRESHOLD > 0;
|
return settings.THRESHOLD > 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user