All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.shynixn.petblocks.bukkit.PetBlocksPlugin Maven / Gradle / Ivy

There is a newer version: 8.29.0
Show newest version
package com.github.shynixn.petblocks.bukkit;

import com.github.shynixn.petblocks.api.PetBlocksApi;
import com.github.shynixn.petblocks.api.business.controller.PetBlockController;
import com.github.shynixn.petblocks.api.persistence.controller.PetMetaController;
import com.github.shynixn.petblocks.bukkit.nms.NMSRegistry;
import com.github.shynixn.petblocks.bukkit.nms.VersionSupport;
import com.github.shynixn.petblocks.bukkit.logic.business.PetBlockManager;
import com.github.shynixn.petblocks.bukkit.logic.business.configuration.Config;
import com.github.shynixn.petblocks.bukkit.lib.ReflectionUtils;
import com.github.shynixn.petblocks.bukkit.lib.UpdateUtils;
import org.bstats.bukkit.Metrics;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
import org.bukkit.plugin.java.JavaPlugin;

import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.logging.Level;
import java.util.logging.Logger;

/**
 * Main class of the plugin PetBlocks.
 * 

* Version 1.2 *

* MIT License *

* Copyright (c) 2018 by Shynixn *

* Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: *

* The above copyright notice and this permission notice shall be included in all * copies or substantial portions of the Software. *

* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE * SOFTWARE. */ public final class PetBlocksPlugin extends JavaPlugin { public static final String PREFIX_CONSOLE = ChatColor.AQUA + "[PetBlocks] "; private static final long SPIGOT_RESOURCEID = 12056; private static final String PLUGIN_NAME = "PetBlocks"; private static Logger logger; private boolean disabled; private PetBlockManager petBlockManager; /** * Enables the plugin PetBlocks. */ @Override public void onEnable() { this.saveDefaultConfig(); logger = this.getLogger(); if (!VersionSupport.isServerVersionSupported(PLUGIN_NAME, PREFIX_CONSOLE)) { this.disabled = true; Bukkit.getPluginManager().disablePlugin(this); } else { Bukkit.getServer().getConsoleSender().sendMessage(PREFIX_CONSOLE + ChatColor.GREEN + "Loading PetBlocks ..."); Config.getInstance().reload(); if (Config.getInstance().isMetricsEnabled()) { new Metrics(this); } this.getServer().getScheduler().runTaskAsynchronously(this, () -> { try { UpdateUtils.checkPluginUpToDateAndPrintMessage(SPIGOT_RESOURCEID, PREFIX_CONSOLE, PLUGIN_NAME, PetBlocksPlugin.this); } catch (final IOException e) { PetBlocksPlugin.logger().log(Level.WARNING, "Failed to check for updates."); } }); NMSRegistry.registerAll(); try { this.petBlockManager = new PetBlockManager(this); ReflectionUtils.invokeMethodByClass(PetBlocksApi.class, "initialize", new Class[]{PetMetaController.class, PetBlockController.class}, new Object[]{this.petBlockManager.getPetMetaController(), this.petBlockManager.getPetBlockController()}); Bukkit.getServer().getConsoleSender().sendMessage(PREFIX_CONSOLE + ChatColor.GREEN + "Enabled PetBlocks " + this.getDescription().getVersion() + " by Shynixn"); } catch (NoSuchMethodException | InvocationTargetException | IllegalAccessException e) { PetBlocksPlugin.logger().log(Level.WARNING, "Failed to enable plugin.", e); } } } /** * Disables the plugin PetBlocks. */ @Override public void onDisable() { if (!this.disabled) { try { NMSRegistry.unregisterCustomEntities(); this.petBlockManager.close(); } catch (final Exception e) { PetBlocksPlugin.logger().log(Level.WARNING, "Failed to disable petblocks.", e); } } } /** * Returns the logger of the petblocks plugin. * * @return logger */ public static Logger logger() { return logger; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy