153 lines
5.2 KiB
Java
153 lines
5.2 KiB
Java
/*
|
|
* Player Analytics Bukkit plugin for monitoring server activity.
|
|
* Copyright (C) 2017 Risto Lahtela / Rsl1122
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the Plan License. (LICENSE)
|
|
* Modified software can only be redistributed if allowed in the licence.
|
|
*
|
|
* 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
|
|
* License for more details.
|
|
*
|
|
* You should have received a copy of the License
|
|
* along with this program.
|
|
* If not it should be visible on the distribution page.
|
|
* Or here
|
|
* https://github.com/Rsl1122/Plan-PlayerAnalytics/blob/master/Plan/src/main/resources/LICENSE
|
|
*/
|
|
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;
|
|
}
|
|
} |