mirror of
https://github.com/IntellectualSites/PlotSquared.git
synced 2024-11-22 21:26:45 +01:00
Fixes #1064
This commit is contained in:
parent
480453b716
commit
b2b90a8d17
@ -153,6 +153,7 @@ public class Settings extends Config {
|
|||||||
@Create // This value has to be generated since an instance isn't static
|
@Create // This value has to be generated since an instance isn't static
|
||||||
public CALIBRATION CALIBRATION = null;
|
public CALIBRATION CALIBRATION = null;
|
||||||
public int THRESHOLD = 1;
|
public int THRESHOLD = 1;
|
||||||
|
public int REQUIRED_PLOTS = -1;
|
||||||
public boolean CONFIRMATION = true;
|
public boolean CONFIRMATION = true;
|
||||||
public int DAYS = 7;
|
public int DAYS = 7;
|
||||||
public List<String> WORLDS = new ArrayList<>(Collections.singletonList("*"));
|
public List<String> WORLDS = new ArrayList<>(Collections.singletonList("*"));
|
||||||
|
@ -1,8 +1,14 @@
|
|||||||
package com.intellectualcrafters.plot.util.expiry;
|
package com.intellectualcrafters.plot.util.expiry;
|
||||||
|
|
||||||
|
import com.intellectualcrafters.plot.PS;
|
||||||
import com.intellectualcrafters.plot.config.Settings;
|
import com.intellectualcrafters.plot.config.Settings;
|
||||||
|
import com.intellectualcrafters.plot.object.Plot;
|
||||||
import com.intellectualcrafters.plot.object.PlotArea;
|
import com.intellectualcrafters.plot.object.PlotArea;
|
||||||
|
import com.intellectualcrafters.plot.object.PlotFilter;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collections;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
public class ExpiryTask {
|
public class ExpiryTask {
|
||||||
@ -12,12 +18,85 @@ public class ExpiryTask {
|
|||||||
this.settings = settings;
|
this.settings = settings;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean applies(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("*");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean applies(PlotArea area) {
|
||||||
|
if (allowsArea(area)) {
|
||||||
|
if (settings.REQUIRED_PLOTS <= 0) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
Set<Plot> plots = null;
|
||||||
|
if (cutoffThreshold != Long.MAX_VALUE && area.getPlots().size() > settings.REQUIRED_PLOTS || (plots = getPlotsToCheck()).size() > settings.REQUIRED_PLOTS) {
|
||||||
|
// calculate cutoff
|
||||||
|
if (cutoffThreshold == Long.MIN_VALUE) {
|
||||||
|
plots = plots != null ? plots : getPlotsToCheck();
|
||||||
|
int diff = settings.REQUIRED_PLOTS;
|
||||||
|
boolean min = true;
|
||||||
|
if (settings.REQUIRED_PLOTS - plots.size() < settings.REQUIRED_PLOTS) {
|
||||||
|
min = false;
|
||||||
|
diff = settings.REQUIRED_PLOTS - plots.size();
|
||||||
|
}
|
||||||
|
List<Long> entireList = new ArrayList<>();
|
||||||
|
for (Plot plot : plots) {
|
||||||
|
entireList.add(ExpireManager.IMP.getAge(plot));
|
||||||
|
}
|
||||||
|
List<Long> top = new ArrayList<>(diff + 1);
|
||||||
|
if (diff > 1000) {
|
||||||
|
Collections.sort(entireList);
|
||||||
|
cutoffThreshold = entireList.get(settings.REQUIRED_PLOTS);
|
||||||
|
} else {
|
||||||
|
loop:
|
||||||
|
for (long num : entireList) {
|
||||||
|
int size = top.size();
|
||||||
|
if (size == 0) {
|
||||||
|
top.add(num);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
long end = top.get(size - 1);
|
||||||
|
if (min ? num < end : num > end) {
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
|
long existing = top.get(i);
|
||||||
|
if (min ? num < existing : num > existing) {
|
||||||
|
top.add(i, num);
|
||||||
|
if (size == diff) {
|
||||||
|
top.remove(size);
|
||||||
|
}
|
||||||
|
continue loop;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (size < diff) {
|
||||||
|
top.add(num);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cutoffThreshold = top.get(top.size() - 1);
|
||||||
|
}
|
||||||
|
// Add half a day, as expiry is performed each day
|
||||||
|
cutoffThreshold += (TimeUnit.DAYS.toMillis(1) / 2);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
cutoffThreshold = Long.MAX_VALUE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<Plot> getPlotsToCheck() {
|
||||||
|
return PS.get().getPlots(new PlotFilter() {
|
||||||
|
@Override
|
||||||
|
public boolean allowsArea(PlotArea area) {
|
||||||
|
return ExpiryTask.this.allowsArea(area);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
private long cutoffThreshold = Long.MIN_VALUE;
|
||||||
|
|
||||||
public boolean applies(long diff) {
|
public boolean applies(long diff) {
|
||||||
return diff > TimeUnit.DAYS.toMillis(settings.DAYS);
|
return diff > TimeUnit.DAYS.toMillis(settings.DAYS) && diff > cutoffThreshold;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean needsAnalysis() {
|
public boolean needsAnalysis() {
|
||||||
@ -31,4 +110,6 @@ public class ExpiryTask {
|
|||||||
public boolean requiresConfirmation() {
|
public boolean requiresConfirmation() {
|
||||||
return settings.CONFIRMATION;
|
return settings.CONFIRMATION;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user