/* * This file is part of spark. * * Copyright (c) lucko (Luck) * Copyright (c) contributors * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ package me.lucko.spark.waterdog; import me.lucko.spark.common.SparkPlatform; import me.lucko.spark.common.SparkPlugin; import me.lucko.spark.common.monitor.ping.PlayerPingProvider; import me.lucko.spark.common.platform.PlatformInfo; import me.lucko.spark.common.sampler.source.ClassSourceLookup; import me.lucko.spark.common.sampler.source.SourceMetadata; import dev.waterdog.waterdogpe.ProxyServer; import dev.waterdog.waterdogpe.command.Command; import dev.waterdog.waterdogpe.command.CommandSender; import dev.waterdog.waterdogpe.plugin.Plugin; import java.nio.file.Path; import java.util.Collection; import java.util.logging.Level; import java.util.stream.Stream; public class WaterdogSparkPlugin extends Plugin implements SparkPlugin { private SparkPlatform platform; public ProxyServer getProxy() { return ProxyServer.getInstance(); } @Override public void onEnable() { this.platform = new SparkPlatform(this); this.platform.enable(); getProxy().getCommandMap().registerCommand(new SparkCommand(this)); } @Override public void onDisable() { this.platform.disable(); } @Override public String getVersion() { return getDescription().getVersion(); } @Override public Path getPluginDirectory() { return getDataFolder().toPath(); } @Override public String getCommandName() { return "sparkw"; } @Override public Stream getCommandSenders() { return Stream.concat( getProxy().getPlayers().values().stream(), Stream.of(getProxy().getConsoleSender()) ).map(WaterdogCommandSender::new); } @Override public void executeAsync(Runnable task) { getProxy().getScheduler().scheduleAsync(task); } @Override public void log(Level level, String msg) { if (level == Level.INFO) { getLogger().info(msg); } else if (level == Level.WARNING) { getLogger().warn(msg); } else if (level == Level.SEVERE) { getLogger().error(msg); } else { throw new IllegalArgumentException(level.getName()); } } @Override public ClassSourceLookup createClassSourceLookup() { return new WaterdogClassSourceLookup(getProxy()); } @Override public Collection getKnownSources() { return SourceMetadata.gather( getProxy().getPluginManager().getPlugins(), Plugin::getName, plugin -> plugin.getDescription().getVersion(), plugin -> plugin.getDescription().getAuthor() ); } @Override public PlayerPingProvider createPlayerPingProvider() { return new WaterdogPlayerPingProvider(getProxy()); } @Override public PlatformInfo getPlatformInfo() { return new WaterdogPlatformInfo(); } private static final class SparkCommand extends Command { private final WaterdogSparkPlugin plugin; SparkCommand(WaterdogSparkPlugin plugin) { super("sparkw"); this.plugin = plugin; } @Override public boolean onExecute(CommandSender sender, String alias, String[] args) { this.plugin.platform.executeCommand(new WaterdogCommandSender(sender), args); return true; } } }