AlttdGriefPrevention/src/main/java/me/ryanhamshire/GriefPrevention/alttd/config/AlttdConfig.java

75 lines
2.8 KiB
Java
Raw Normal View History

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
}
}