2022-02-14 09:18:03 +00:00
|
|
|
package me.ryanhamshire.GriefPrevention.alttd.config;
|
|
|
|
|
|
|
|
|
|
import com.alttd.galaxy.configuration.AbstractConfiguration;
|
|
|
|
|
import me.ryanhamshire.GriefPrevention.GriefPrevention;
|
2022-02-15 13:07:31 +00:00
|
|
|
import me.ryanhamshire.GriefPrevention.alttd.util.Logger;
|
|
|
|
|
import org.spongepowered.configurate.ConfigurationNode;
|
|
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
|
import java.util.Map;
|
|
|
|
|
import java.util.concurrent.TimeUnit;
|
2022-02-14 09:18:03 +00:00
|
|
|
|
|
|
|
|
@SuppressWarnings("unused")
|
|
|
|
|
public class AlttdConfig extends AbstractConfiguration
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
private AlttdConfig() {
|
|
|
|
|
super(GriefPrevention.instance.getDataFolder(),"alttdconfig.yml");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static AlttdConfig config;
|
|
|
|
|
static int version;
|
|
|
|
|
|
|
|
|
|
public static void reload() {
|
|
|
|
|
config = new AlttdConfig();
|
|
|
|
|
|
|
|
|
|
version = config.getInt("config-version", 1);
|
|
|
|
|
config.set("config-version", 1);
|
|
|
|
|
|
|
|
|
|
config.readConfig(AlttdConfig.class, null);
|
|
|
|
|
}
|
|
|
|
|
|
2022-02-15 13:07:31 +00:00
|
|
|
private HashMap<Long, Long> getMap(String path, HashMap<Long, Long> def) {
|
|
|
|
|
set(path, def);
|
|
|
|
|
ConfigurationNode node = config.getNode(path);
|
|
|
|
|
HashMap<Long, Long> map = new HashMap<>();
|
|
|
|
|
for (Map.Entry<Object, ? extends ConfigurationNode> entry : node.childrenMap().entrySet()) {
|
|
|
|
|
try {
|
|
|
|
|
map.put(Long.parseLong(entry.getKey().toString()), Long.parseLong(entry.getValue().getString()));
|
|
|
|
|
} catch (NumberFormatException exception) {
|
|
|
|
|
// handle
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return map;
|
|
|
|
|
}
|
|
|
|
|
|
2022-02-14 09:18:03 +00:00
|
|
|
public static boolean DEBUG_MODE = false;
|
2022-02-15 13:07:31 +00:00
|
|
|
public static boolean alternativeClaimExpiring = false;
|
|
|
|
|
public static int alternativeClaimExpireDays = 1;
|
|
|
|
|
public static int expireCheckRate = 1200;
|
|
|
|
|
public static HashMap<Long, Long> expiringClaims = new HashMap<>();
|
2022-02-14 09:18:03 +00:00
|
|
|
private static void settings() {
|
2022-02-15 13:07:31 +00:00
|
|
|
String node = "alternative-claim-expiring";
|
2022-02-14 09:18:03 +00:00
|
|
|
DEBUG_MODE = config.getBoolean("debug-mode", DEBUG_MODE);
|
2022-02-15 13:07:31 +00:00
|
|
|
alternativeClaimExpiring = config.getBoolean(node + ".enabled", alternativeClaimExpiring);
|
|
|
|
|
alternativeClaimExpireDays = config.getInt(node + ".days", alternativeClaimExpireDays);
|
|
|
|
|
expireCheckRate = config.getInt(node + ".expire-check-rate", expireCheckRate);
|
|
|
|
|
// todo create an alternative way of loading these in
|
|
|
|
|
expiringClaims.clear();
|
|
|
|
|
config.getMap(node + ".claims", new HashMap<>())
|
|
|
|
|
.forEach((key, value) -> {
|
|
|
|
|
try {
|
|
|
|
|
expiringClaims.put(Long.parseLong(key.toString()), value);
|
|
|
|
|
} catch (NumberFormatException ignored) {}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public static void addExpiringClaim(Long id) {
|
|
|
|
|
expiringClaims.put(id, System.currentTimeMillis() + TimeUnit.DAYS.toMillis(alternativeClaimExpireDays));
|
|
|
|
|
config.set("alternative-claim-expiring.claims", expiringClaims);
|
|
|
|
|
config.saveConfig();
|
2022-02-14 09:18:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|