150 lines
5.1 KiB
Java
150 lines
5.1 KiB
Java
/*
|
|
* This file is part of Player Analytics (Plan).
|
|
*
|
|
* Plan is free software: you can redistribute it and/or modify
|
|
* it under the terms of the LGNU Lesser General Public License v3 as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Plan 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
|
|
* LGNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* along with Plan. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
package com.djrapitops.plan;
|
|
|
|
import com.djrapitops.plan.api.exceptions.EnableException;
|
|
import com.djrapitops.plan.command.PlanCommand;
|
|
import com.djrapitops.plan.system.PlanSystem;
|
|
import com.djrapitops.plan.system.locale.Locale;
|
|
import com.djrapitops.plan.system.locale.lang.PluginLang;
|
|
import com.djrapitops.plan.system.settings.theme.PlanColorScheme;
|
|
import com.djrapitops.plan.utilities.metrics.BStatsBukkit;
|
|
import com.djrapitops.plugin.BukkitPlugin;
|
|
import com.djrapitops.plugin.benchmarking.Benchmark;
|
|
import com.djrapitops.plugin.command.ColorScheme;
|
|
import org.bukkit.configuration.file.FileConfiguration;
|
|
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
|
|
/**
|
|
* Main class for Bukkit that manages the plugin.
|
|
*
|
|
* @author Rsl1122
|
|
* @since 1.0.0
|
|
*/
|
|
public class Plan extends BukkitPlugin implements PlanPlugin {
|
|
|
|
private PlanSystem system;
|
|
private Locale locale;
|
|
|
|
@Override
|
|
public void onEnable() {
|
|
PlanBukkitComponent component = DaggerPlanBukkitComponent.builder().plan(this).build();
|
|
try {
|
|
timings.start("Enable");
|
|
system = component.system();
|
|
locale = system.getLocaleSystem().getLocale();
|
|
system.enable();
|
|
|
|
new BStatsBukkit(this).registerMetrics();
|
|
|
|
logger.debug("Verbose debug messages are enabled.");
|
|
String benchTime = " (" + timings.end("Enable").map(Benchmark::toDurationString).orElse("-") + ")";
|
|
logger.info(locale.getString(PluginLang.ENABLED) + benchTime);
|
|
} catch (AbstractMethodError e) {
|
|
logger.error("Plugin ran into AbstractMethodError - Server restart is required. Likely cause is updating the jar without a restart.");
|
|
} catch (EnableException e) {
|
|
logger.error("----------------------------------------");
|
|
logger.error("Error: " + e.getMessage());
|
|
logger.error("----------------------------------------");
|
|
logger.error("Plugin Failed to Initialize Correctly. If this issue is caused by config settings you can use /plan reload");
|
|
onDisable();
|
|
} catch (Exception e) {
|
|
Logger.getGlobal().log(Level.SEVERE, this.getClass().getSimpleName() + "-v" + getVersion(), e);
|
|
logger.error("Plugin Failed to Initialize Correctly. If this issue is caused by config settings you can use /plan reload");
|
|
logger.error("This error should be reported at https://github.com/Rsl1122/Plan-PlayerAnalytics/issues");
|
|
onDisable();
|
|
}
|
|
PlanCommand command = component.planCommand();
|
|
command.registerCommands();
|
|
registerCommand("plan", command);
|
|
}
|
|
|
|
@Override
|
|
public ColorScheme getColorScheme() {
|
|
return PlanColorScheme.create(system.getConfigSystem().getConfig(), logger);
|
|
}
|
|
|
|
/**
|
|
* Disables the plugin.
|
|
*/
|
|
@Override
|
|
public void onDisable() {
|
|
if (system != null) {
|
|
system.disable();
|
|
}
|
|
|
|
logger.info(locale != null ? locale.getString(PluginLang.DISABLED) : PluginLang.DISABLED.getDefault());
|
|
}
|
|
|
|
@Override
|
|
public String getVersion() {
|
|
return getDescription().getVersion();
|
|
}
|
|
|
|
@Override
|
|
public void onReload() {
|
|
// Nothing to be done, systems are disabled
|
|
}
|
|
|
|
@Override
|
|
public boolean isReloading() {
|
|
return reloading;
|
|
}
|
|
|
|
/**
|
|
* @deprecated Deprecated due to use of APF Config
|
|
*/
|
|
@Override
|
|
@Deprecated
|
|
public void reloadConfig() {
|
|
throw new IllegalStateException("This method should be used on this plugin. Use onReload() instead");
|
|
}
|
|
|
|
/**
|
|
* @deprecated Deprecated due to use of APF Config
|
|
*/
|
|
@Override
|
|
@Deprecated
|
|
public FileConfiguration getConfig() {
|
|
throw new IllegalStateException("This method should be used on this plugin. Use getMainConfig() instead");
|
|
}
|
|
|
|
/**
|
|
* @deprecated Deprecated due to use of APF Config
|
|
*/
|
|
@Override
|
|
@Deprecated
|
|
public void saveConfig() {
|
|
throw new IllegalStateException("This method should be used on this plugin. Use getMainConfig().save() instead");
|
|
}
|
|
|
|
/**
|
|
* @deprecated Deprecated due to use of APF Config
|
|
*/
|
|
@Override
|
|
@Deprecated
|
|
public void saveDefaultConfig() {
|
|
throw new IllegalStateException("This method should be used on this plugin.");
|
|
}
|
|
|
|
@Override
|
|
public PlanSystem getSystem() {
|
|
return system;
|
|
}
|
|
} |