add a command and things

school is finally coming to an end so I'll try to make bigger changes
This commit is contained in:
Minecon724 2024-06-11 16:01:38 +02:00
parent cca6788b4d
commit 8abb6cff93
Signed by: Minecon724
GPG key ID: 3CCC4D267742C8E8
15 changed files with 123 additions and 39 deletions

View file

@ -30,7 +30,7 @@
<dependency> <dependency>
<groupId>eu.m724</groupId> <groupId>eu.m724</groupId>
<artifactId>wtapi</artifactId> <artifactId>wtapi</artifactId>
<version>0.4</version> <version>0.5</version>
</dependency> </dependency>
</dependencies> </dependencies>

View file

@ -3,7 +3,9 @@ package eu.m724.realweather;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import eu.m724.realweather.mapper.Mapper; import eu.m724.realweather.mapper.Mapper;
import eu.m724.realweather.mapper.MapperConfig;
import eu.m724.realweather.thunder.ThunderConfig; import eu.m724.realweather.thunder.ThunderConfig;
import eu.m724.realweather.thunder.ThunderMaster;
import eu.m724.realweather.time.TimeConfig; import eu.m724.realweather.time.TimeConfig;
import eu.m724.realweather.weather.PlayerWeatherDirectory; import eu.m724.realweather.weather.PlayerWeatherDirectory;
import eu.m724.realweather.weather.WeatherConfig; import eu.m724.realweather.weather.WeatherConfig;
@ -12,6 +14,10 @@ public class GlobalConstants {
static WeatherConfig weatherConfig; static WeatherConfig weatherConfig;
static TimeConfig timeConfig; static TimeConfig timeConfig;
static ThunderConfig thunderConfig; static ThunderConfig thunderConfig;
static MapperConfig mapperConfig;
static ThunderMaster thunderMaster;
static Mapper mapper; static Mapper mapper;
static Plugin plugin; static Plugin plugin;
static PlayerWeatherDirectory playerWeatherDirectory; static PlayerWeatherDirectory playerWeatherDirectory;
@ -25,6 +31,12 @@ public class GlobalConstants {
public static ThunderConfig getThunderConfig() { public static ThunderConfig getThunderConfig() {
return thunderConfig; return thunderConfig;
} }
public static MapperConfig getMapperConfig() {
return mapperConfig;
}
public static ThunderMaster getThunderMaster() {
return thunderMaster;
}
public static Mapper getMapper() { public static Mapper getMapper() {
return mapper; return mapper;
} }

View file

@ -11,11 +11,11 @@ import org.bukkit.plugin.java.JavaPlugin;
import com.google.common.base.Charsets; import com.google.common.base.Charsets;
import eu.m724.realweather.commands.AdminCommand;
import eu.m724.realweather.commands.GeoCommand; import eu.m724.realweather.commands.GeoCommand;
import eu.m724.realweather.commands.LocalTimeCommand; import eu.m724.realweather.commands.LocalTimeCommand;
import eu.m724.realweather.mapper.Mapper; import eu.m724.realweather.mapper.Mapper;
import eu.m724.realweather.mapper.MapperConfig; import eu.m724.realweather.mapper.MapperConfig;
import eu.m724.realweather.mapper.MapperEventHandler;
import eu.m724.realweather.object.UserException; import eu.m724.realweather.object.UserException;
import eu.m724.realweather.thunder.ThunderConfig; import eu.m724.realweather.thunder.ThunderConfig;
import eu.m724.realweather.thunder.ThunderMaster; import eu.m724.realweather.thunder.ThunderMaster;
@ -26,7 +26,6 @@ import eu.m724.realweather.weather.WeatherMaster;
import eu.m724.wtapi.provider.exception.ProviderException; import eu.m724.wtapi.provider.exception.ProviderException;
public class RealWeatherPlugin extends JavaPlugin { public class RealWeatherPlugin extends JavaPlugin {
private Mapper mapper;
private WeatherMaster weatherMaster; private WeatherMaster weatherMaster;
private ThunderMaster thunderMaster; private ThunderMaster thunderMaster;
private TimeMaster timeMaster; private TimeMaster timeMaster;
@ -81,8 +80,8 @@ public class RealWeatherPlugin extends JavaPlugin {
GlobalConstants.plugin = this; GlobalConstants.plugin = this;
DebugLogger.info("loading mapper", 1); DebugLogger.info("loading mapper", 1);
GlobalConstants.mapper = new Mapper( GlobalConstants.mapperConfig = MapperConfig.fromConfiguration(mapConfiguration);
MapperConfig.fromConfiguration(mapConfiguration)); GlobalConstants.mapper = new Mapper();
GlobalConstants.mapper.registerEvents(this); GlobalConstants.mapper.registerEvents(this);
try { try {
@ -117,6 +116,9 @@ public class RealWeatherPlugin extends JavaPlugin {
return; return;
} }
GlobalConstants.thunderMaster = thunderMaster;
getCommand("rwadmin").setExecutor(new AdminCommand());
getCommand("geo").setExecutor(new GeoCommand()); getCommand("geo").setExecutor(new GeoCommand());
if (GlobalConstants.timeConfig.enabled) if (GlobalConstants.timeConfig.enabled)

View file

@ -0,0 +1,97 @@
package eu.m724.realweather.commands;
import java.time.Duration;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.plugin.Plugin;
import eu.m724.realweather.GlobalConstants;
import eu.m724.realweather.mapper.MapperConfig;
import eu.m724.realweather.thunder.ThunderConfig;
import eu.m724.realweather.thunder.ThunderMaster;
import eu.m724.realweather.time.TimeConfig;
import eu.m724.realweather.weather.WeatherConfig;
import net.md_5.bungee.api.ChatColor;
import net.md_5.bungee.api.chat.BaseComponent;
import net.md_5.bungee.api.chat.ComponentBuilder;
import net.md_5.bungee.api.chat.TextComponent;
public class AdminCommand implements CommandExecutor {
private Plugin plugin = GlobalConstants.getPlugin();
private WeatherConfig weatherConfig = GlobalConstants.getWeatherConfig();
private TimeConfig timeConfig = GlobalConstants.getTimeConfig();
private ThunderConfig thunderConfig = GlobalConstants.getThunderConfig();
private MapperConfig mapperConfig = GlobalConstants.getMapperConfig();
private ThunderMaster thunderMaster = GlobalConstants.getThunderMaster();
private BaseComponent enabledComponent = TextComponent.fromLegacy("YES\n", ChatColor.GREEN);
private BaseComponent disabledComponent = TextComponent.fromLegacy("NO\n", ChatColor.RED);
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
ComponentBuilder componentBuilder =
new ComponentBuilder("\nRealWeather " + plugin.getDescription().getVersion() + "\n\n")
.color(ChatColor.YELLOW);
componentBuilder.append("Coordinate scale: ").color(ChatColor.GOLD);
componentBuilder.append(String.format("%d, %d blocks / deg\n", mapperConfig.scaleLatitude, mapperConfig.scaleLongitude)).color(ChatColor.AQUA);
componentBuilder.append("\nWeather: ").color(ChatColor.GOLD);
componentBuilder.append(weatherConfig.enabled ? enabledComponent : disabledComponent);
if (weatherConfig.enabled) {
componentBuilder.append(" Provider: ").color(ChatColor.GOLD);
componentBuilder.append(weatherConfig.provider + "\n").color(ChatColor.AQUA);
componentBuilder.append(" Dynamic: ").color(ChatColor.GOLD);
componentBuilder.append(weatherConfig.dynamic ? enabledComponent : disabledComponent);
}
componentBuilder.append("\nTime: ").color(ChatColor.GOLD);
componentBuilder.append(timeConfig.enabled ? enabledComponent : disabledComponent);
if (timeConfig.enabled) {
componentBuilder.append(" Scale: ").color(ChatColor.GOLD);
componentBuilder.append(Double.toString(timeConfig.scale) + "\n").color(ChatColor.AQUA);
long worldTime = timeConfig.calculateWorldTimeSeconds();
Duration worldTimeDuration = Duration.ofSeconds(worldTime);
String worldTimeFormatted = String.format("%d:%02d:%02d\n",
worldTimeDuration.toHours(),
worldTimeDuration.toMinutesPart(),
worldTimeDuration.toSecondsPart());
componentBuilder.append(" World time: ").color(ChatColor.GOLD);
componentBuilder.append(worldTimeFormatted).color(ChatColor.AQUA);
componentBuilder.append(" Dynamic: ").color(ChatColor.GOLD);
componentBuilder.append(timeConfig.dynamic ? enabledComponent : disabledComponent);
}
componentBuilder.append("\nThunder: ").color(ChatColor.GOLD);
componentBuilder.append(thunderConfig.enabled ? enabledComponent : disabledComponent);
if (thunderConfig.enabled) {
componentBuilder.append(" Provider: ").color(ChatColor.GOLD);
componentBuilder.append(thunderConfig.provider + "\n").color(ChatColor.AQUA);
componentBuilder.append(" Refresh: ").color(ChatColor.GOLD);
componentBuilder.append(String.format("%d ticks\n", thunderConfig.refresh)).color(ChatColor.AQUA);
componentBuilder.append(" Latency: ").color(ChatColor.GOLD);
componentBuilder.append(String.format("avg %dms\n", thunderMaster.getLatency())).color(ChatColor.AQUA);
}
sender.spigot().sendMessage(componentBuilder.create());
return true;
}
}

View file

@ -12,7 +12,6 @@ import eu.m724.wtapi.object.Coordinates;
import net.md_5.bungee.api.ChatColor; import net.md_5.bungee.api.ChatColor;
import net.md_5.bungee.api.chat.BaseComponent; import net.md_5.bungee.api.chat.BaseComponent;
import net.md_5.bungee.api.chat.ComponentBuilder; import net.md_5.bungee.api.chat.ComponentBuilder;
import net.md_5.bungee.api.chat.TextComponent;
public class GeoCommand implements CommandExecutor { public class GeoCommand implements CommandExecutor {

View file

@ -2,8 +2,6 @@ package eu.m724.realweather.commands;
import java.time.Duration; import java.time.Duration;
import java.time.temporal.ChronoUnit; import java.time.temporal.ChronoUnit;
import java.time.temporal.TemporalUnit;
import org.bukkit.command.Command; import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor; import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender; import org.bukkit.command.CommandSender;

View file

@ -1,31 +1,24 @@
package eu.m724.realweather.mapper; package eu.m724.realweather.mapper;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.concurrent.Callable;
import java.util.function.Consumer; import java.util.function.Consumer;
import org.bukkit.GameRule;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import eu.m724.realweather.GlobalConstants;
import eu.m724.wtapi.object.Coordinates; import eu.m724.wtapi.object.Coordinates;
public class Mapper { public class Mapper {
private MapperConfig config; private MapperConfig config = GlobalConstants.getMapperConfig();
private List<World> worlds = new ArrayList<>(); private List<World> worlds = new ArrayList<>();
private List<Consumer<World>> worldLoadConsumers = new ArrayList<>(); private List<Consumer<World>> worldLoadConsumers = new ArrayList<>();
private List<Consumer<World>> worldUnloadConsumers = new ArrayList<>(); private List<Consumer<World>> worldUnloadConsumers = new ArrayList<>();
// TODO game rules // TODO game rules
public Mapper(MapperConfig config) {
this.config = config;
}
/** /**
* Registers a consumer which will be called on world load * Registers a consumer which will be called on world load
* @param consumer * @param consumer

View file

@ -7,8 +7,6 @@ import org.bukkit.configuration.ConfigurationSection;
import eu.m724.wtapi.object.Coordinates; import eu.m724.wtapi.object.Coordinates;
public class MapperConfig { public class MapperConfig {
public boolean enabled;
public boolean worldBlacklist; public boolean worldBlacklist;
public List<String> worlds; public List<String> worlds;
@ -20,8 +18,6 @@ public class MapperConfig {
public static MapperConfig fromConfiguration(ConfigurationSection configuration) { public static MapperConfig fromConfiguration(ConfigurationSection configuration) {
MapperConfig mapperConfig = new MapperConfig(); MapperConfig mapperConfig = new MapperConfig();
mapperConfig.enabled = configuration.getBoolean("enabled");
mapperConfig.worldBlacklist = configuration.getBoolean("worldBlacklist"); mapperConfig.worldBlacklist = configuration.getBoolean("worldBlacklist");
mapperConfig.worlds = configuration.getStringList("worlds"); mapperConfig.worlds = configuration.getStringList("worlds");

View file

@ -1,12 +1,9 @@
package eu.m724.realweather.thunder; package eu.m724.realweather.thunder;
import java.util.ArrayList;
import org.bukkit.plugin.Plugin; import org.bukkit.plugin.Plugin;
import eu.m724.realweather.DebugLogger; import eu.m724.realweather.DebugLogger;
import eu.m724.realweather.GlobalConstants; import eu.m724.realweather.GlobalConstants;
import eu.m724.realweather.mapper.Mapper;
import eu.m724.realweather.object.UserException; import eu.m724.realweather.object.UserException;
import eu.m724.wtapi.provider.exception.ProviderException; import eu.m724.wtapi.provider.exception.ProviderException;
import eu.m724.wtapi.thunder.ThunderProvider; import eu.m724.wtapi.thunder.ThunderProvider;
@ -17,7 +14,6 @@ public class ThunderMaster {
private ThunderProvider provider; private ThunderProvider provider;
private ThunderTask thunderTask; private ThunderTask thunderTask;
private Mapper mapper = GlobalConstants.getMapper();
private Plugin plugin = GlobalConstants.getPlugin(); private Plugin plugin = GlobalConstants.getPlugin();
public ThunderMaster(ThunderConfig config) { public ThunderMaster(ThunderConfig config) {
@ -55,4 +51,8 @@ public class ThunderMaster {
return null; return null;
} }
public long getLatency() {
return provider.getLatency();
}
} }

View file

@ -3,7 +3,6 @@ package eu.m724.realweather.thunder;
import java.util.ArrayList; import java.util.ArrayList;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.entity.EntityType;
import org.bukkit.scheduler.BukkitRunnable; import org.bukkit.scheduler.BukkitRunnable;
import eu.m724.realweather.DebugLogger; import eu.m724.realweather.DebugLogger;

View file

@ -7,13 +7,9 @@ import org.bukkit.scheduler.BukkitRunnable;
import eu.m724.realweather.DebugLogger; import eu.m724.realweather.DebugLogger;
import eu.m724.realweather.GlobalConstants; import eu.m724.realweather.GlobalConstants;
import eu.m724.realweather.mapper.Mapper; import eu.m724.realweather.mapper.Mapper;
import eu.m724.realweather.weather.PlayerWeatherDirectory;
import eu.m724.wtapi.object.Coordinates; import eu.m724.wtapi.object.Coordinates;
import eu.m724.wtapi.object.Weather;
public class AsyncPlayerTimeTask extends BukkitRunnable { public class AsyncPlayerTimeTask extends BukkitRunnable {
private PlayerWeatherDirectory playerWeatherDirectory =
GlobalConstants.getPlayerWeatherDirectory();
private Server server = GlobalConstants.getPlugin().getServer(); private Server server = GlobalConstants.getPlugin().getServer();
private Mapper mapper = GlobalConstants.getMapper(); private Mapper mapper = GlobalConstants.getMapper();

View file

@ -5,7 +5,6 @@ import org.bukkit.plugin.Plugin;
import eu.m724.realweather.DebugLogger; import eu.m724.realweather.DebugLogger;
import eu.m724.realweather.GlobalConstants; import eu.m724.realweather.GlobalConstants;
import eu.m724.realweather.commands.LocalTimeCommand;
import eu.m724.realweather.mapper.Mapper; import eu.m724.realweather.mapper.Mapper;
import eu.m724.realweather.object.UserException; import eu.m724.realweather.object.UserException;

View file

@ -3,7 +3,6 @@ package eu.m724.realweather.weather;
import java.util.List; import java.util.List;
import java.util.concurrent.CompletableFuture; import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionException; import java.util.concurrent.CompletionException;
import java.util.concurrent.ExecutionException;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import org.bukkit.Server; import org.bukkit.Server;

View file

@ -10,8 +10,6 @@ public class WeatherConfig {
// state is per player // state is per player
public boolean dynamic; public boolean dynamic;
// prevent other stuff from changing weather
public boolean lock;
public static WeatherConfig fromConfiguration(ConfigurationSection configuration) { public static WeatherConfig fromConfiguration(ConfigurationSection configuration) {
WeatherConfig weatherConfig = new WeatherConfig(); WeatherConfig weatherConfig = new WeatherConfig();
@ -22,7 +20,6 @@ public class WeatherConfig {
weatherConfig.apiKey = configuration.getString("apiKey"); weatherConfig.apiKey = configuration.getString("apiKey");
weatherConfig.dynamic = configuration.getBoolean("dynamic"); weatherConfig.dynamic = configuration.getBoolean("dynamic");
weatherConfig.lock = configuration.getBoolean("lock");
return weatherConfig; return weatherConfig;
} }

View file

@ -14,6 +14,3 @@ apiKey: REPLACE ME
# - dynamic (true): weather is per player, however it's only cosmetical so it will not match mobs spawning etc # - dynamic (true): weather is per player, however it's only cosmetical so it will not match mobs spawning etc
# settings for both are in map.yml # settings for both are in map.yml
dynamic: true dynamic: true
# prevent the game, players or other plugins from changing the weather
lock: true