1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-20 07:01:22 +01:00
Jobs/com/gamingmesh/jobs/Jobs.java

1161 lines
33 KiB
Java
Raw Normal View History

2015-08-21 15:10:08 +02:00
/**
* Jobs Plugin for Bukkit
* Copyright (C) 2011 Zak Ford <zak.j.ford@gmail.com>
*
* 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 <http://www.gnu.org/licenses/>.
*/
package com.gamingmesh.jobs;
import java.io.File;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
2015-08-21 15:10:08 +02:00
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
2015-08-21 15:10:08 +02:00
import java.util.List;
2016-08-05 12:28:31 +02:00
import java.util.Map.Entry;
import java.util.UUID;
2015-08-21 15:10:08 +02:00
import java.util.WeakHashMap;
import java.util.logging.Logger;
import org.bukkit.Bukkit;
import org.bukkit.ChatColor;
2016-09-29 16:24:29 +02:00
import org.bukkit.block.Block;
import org.bukkit.command.ConsoleCommandSender;
import org.bukkit.entity.Entity;
import org.bukkit.entity.LivingEntity;
2015-08-21 15:10:08 +02:00
import org.bukkit.entity.Player;
import org.bukkit.plugin.java.JavaPlugin;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.Gui.GuiManager;
import com.gamingmesh.jobs.Signs.SignUtil;
2016-04-03 16:22:44 +02:00
import com.gamingmesh.jobs.api.JobsExpGainEvent;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.commands.JobsCommands;
2016-09-29 16:24:29 +02:00
import com.gamingmesh.jobs.config.BlockProtectionManager;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.config.BossBarManager;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.config.ConfigManager;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.config.ExploreManager;
import com.gamingmesh.jobs.config.GeneralConfigManager;
import com.gamingmesh.jobs.config.LanguageManager;
import com.gamingmesh.jobs.config.NameTranslatorManager;
import com.gamingmesh.jobs.config.RestrictedAreaManager;
import com.gamingmesh.jobs.config.RestrictedBlockManager;
import com.gamingmesh.jobs.config.ScboardManager;
import com.gamingmesh.jobs.config.ScheduleManager;
import com.gamingmesh.jobs.config.ShopManager;
import com.gamingmesh.jobs.config.TitleManager;
import com.gamingmesh.jobs.config.YmlMaker;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.container.ActionInfo;
2016-09-29 16:24:29 +02:00
import com.gamingmesh.jobs.container.ActionType;
import com.gamingmesh.jobs.container.BlockProtection;
import com.gamingmesh.jobs.container.Boost;
import com.gamingmesh.jobs.container.CurrencyType;
2016-09-29 16:24:29 +02:00
import com.gamingmesh.jobs.container.DBAction;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.container.Job;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.container.JobInfo;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.container.JobProgression;
import com.gamingmesh.jobs.container.JobsPlayer;
2016-08-05 12:28:31 +02:00
import com.gamingmesh.jobs.container.PlayerInfo;
import com.gamingmesh.jobs.container.FastPayment;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.dao.JobsDAO;
import com.gamingmesh.jobs.economy.BufferedEconomy;
import com.gamingmesh.jobs.economy.BufferedPayment;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.economy.Economy;
import com.gamingmesh.jobs.i18n.Language;
import com.gamingmesh.jobs.listeners.JobsListener;
import com.gamingmesh.jobs.listeners.JobsPaymentListener;
2016-06-25 14:51:21 +02:00
import com.gamingmesh.jobs.listeners.McMMOlistener;
2016-03-30 15:42:36 +02:00
import com.gamingmesh.jobs.listeners.MythicMobsListener;
2016-06-25 14:51:21 +02:00
import com.gamingmesh.jobs.listeners.PistonProtectionListener;
import com.gamingmesh.jobs.selection.SelectionManager;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.stuff.ActionBar;
import com.gamingmesh.jobs.stuff.JobsClassLoader;
import com.gamingmesh.jobs.stuff.Loging;
import com.gamingmesh.jobs.stuff.TabComplete;
2015-08-21 15:10:08 +02:00
import com.gamingmesh.jobs.tasks.BufferedPaymentThread;
import com.gamingmesh.jobs.tasks.DatabaseSaveThread;
public class Jobs extends JavaPlugin {
// public static Jobs plugin = new Jobs();
2016-09-23 17:06:43 +02:00
private static String version = "";
2016-04-05 16:43:55 +02:00
private static PlayerManager pManager = null;
2016-03-30 15:42:36 +02:00
private static JobsCommands cManager = null;
private static Language lManager = null;
private static LanguageManager lmManager = null;
private static SignUtil signManager = null;
private static ScboardManager scboardManager = null;
private static ScheduleManager scheduleManager = null;
private static NameTranslatorManager NameTranslatorManager = null;
private static GuiManager GUIManager = null;
private static ExploreManager exploreManager = null;
private static TitleManager titleManager = null;
private static RestrictedBlockManager RBManager = null;
private static RestrictedAreaManager RAManager = null;
private static BossBarManager BBManager;
private static ShopManager shopManager;
2016-06-25 17:56:59 +02:00
private static Loging loging;
2016-09-29 16:24:29 +02:00
private static BlockProtectionManager BpManager = null;
2016-03-30 15:42:36 +02:00
2016-06-25 14:51:21 +02:00
private static PistonProtectionListener PistonProtectionListener = null;
private static McMMOlistener McMMOlistener = null;
2016-03-30 15:42:36 +02:00
private static MythicMobsListener MythicManager;
private static ConfigManager configManager;
private static GeneralConfigManager GconfigManager;
2015-09-10 12:41:19 +02:00
private static Logger pLogger;
private static File dataFolder;
private static JobsClassLoader classLoader;
2015-09-10 12:41:19 +02:00
private static JobsDAO dao = null;
private static List<Job> jobs = null;
private static Job noneJob = null;
private static WeakHashMap<Job, Integer> usedSlots = new WeakHashMap<Job, Integer>();
public static WeakHashMap<String, Boolean> actionbartoggle = new WeakHashMap<String, Boolean>();
2016-03-30 15:42:36 +02:00
public static WeakHashMap<String, Boolean> BossBartoggle = new WeakHashMap<String, Boolean>();
2015-08-21 15:10:08 +02:00
// public static WeakHashMap<String, Double> GlobalBoost = new WeakHashMap<String, Double>();
2015-09-10 12:41:19 +02:00
private static BufferedEconomy economy;
private static PermissionHandler permissionHandler;
2017-01-11 18:21:33 +01:00
private static PermissionManager permissionManager;
2015-09-10 12:41:19 +02:00
public static BufferedPaymentThread paymentThread = null;
private static DatabaseSaveThread saveTask = null;
public static HashMap<String, FastPayment> FastPayment = new HashMap<String, FastPayment>();
2016-03-30 15:42:36 +02:00
private static NMS nms;
private static ActionBar actionbar;
private boolean running = false;
2016-03-30 15:42:36 +02:00
protected static SelectionManager smanager;
public void setMcMMOlistener() {
McMMOlistener = new McMMOlistener(this);
2016-06-25 14:51:21 +02:00
}
public static McMMOlistener getMcMMOlistener() {
return McMMOlistener;
}
2016-03-30 15:42:36 +02:00
public void setPistonProtectionListener() {
PistonProtectionListener = new PistonProtectionListener(this);
2016-03-30 15:42:36 +02:00
}
2016-06-25 14:51:21 +02:00
public static PistonProtectionListener getPistonProtectionListener() {
return PistonProtectionListener;
2016-03-30 15:42:36 +02:00
}
public void setMythicManager() {
MythicManager = new MythicMobsListener(this);
2016-03-30 15:42:36 +02:00
}
public static MythicMobsListener getMythicManager() {
return MythicManager;
}
public void setLoging() {
2016-06-25 17:56:59 +02:00
loging = new Loging();
}
public static Loging getLoging() {
return loging;
}
2016-09-29 16:24:29 +02:00
public void setBpManager() {
BpManager = new BlockProtectionManager();
}
public static BlockProtectionManager getBpManager() {
return BpManager;
}
public static void setShopManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
shopManager = new ShopManager(plugin);
}
public static ShopManager getShopManager() {
return shopManager;
}
2015-09-10 12:41:19 +02:00
public void setConfigManager() {
configManager = new ConfigManager(this);
2016-03-30 15:42:36 +02:00
}
public static ConfigManager getConfigManager() {
return configManager;
}
public void setGCManager() {
GconfigManager = new GeneralConfigManager(this);
2016-03-30 15:42:36 +02:00
}
public static GeneralConfigManager getGCManager() {
return GconfigManager;
}
public void setActionBar() {
actionbar = new ActionBar();
2016-03-30 15:42:36 +02:00
}
public static ActionBar getActionBar() {
return actionbar;
}
public static void setNms(NMS newNms) {
nms = newNms;
}
public static NMS getNms() {
return nms;
2015-09-10 12:41:19 +02:00
}
/**
* Returns player manager
* @return the player manager
*/
public static PlayerManager getPlayerManager() {
return pManager;
}
public void setPlayerManager() {
pManager = new PlayerManager(this);
2016-04-05 16:43:55 +02:00
}
public static void setRestrictedBlockManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
RBManager = new RestrictedBlockManager(plugin);
}
public static RestrictedBlockManager getRestrictedBlockManager() {
return RBManager;
}
public static void setRestrictedAreaManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
RAManager = new RestrictedAreaManager(plugin);
}
public static RestrictedAreaManager getRestrictedAreaManager() {
return RAManager;
}
public static void setTitleManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
titleManager = new TitleManager(plugin);
}
public static TitleManager gettitleManager() {
return titleManager;
}
public void setBBManager() {
BBManager = new BossBarManager(this);
2016-03-30 15:42:36 +02:00
}
public static BossBarManager getBBManager() {
return BBManager;
}
public static WeakHashMap<String, Boolean> getActionbarToggleList() {
return actionbartoggle;
}
public static WeakHashMap<String, Boolean> getBossBarToggleList() {
return BossBartoggle;
}
/**
* Returns schedule manager
* @return the schedule manager
*/
2016-03-30 15:42:36 +02:00
public static ScheduleManager getScheduleManager() {
return scheduleManager;
}
public static void setScheduleManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
scheduleManager = new ScheduleManager(plugin);
}
2016-03-30 15:42:36 +02:00
public static NameTranslatorManager getNameTranslatorManager() {
return NameTranslatorManager;
}
public static void setNameTranslatorManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
NameTranslatorManager = new NameTranslatorManager(plugin);
}
public static GuiManager getGUIManager() {
return GUIManager;
}
public void setGUIManager() {
2016-03-30 15:42:36 +02:00
GUIManager = new GuiManager();
}
public static JobsCommands getCommandManager() {
return cManager;
}
public void setCommandManager() {
cManager = new JobsCommands(this);
2016-03-30 15:42:36 +02:00
}
public static ExploreManager getExplore() {
2016-01-09 13:58:33 +01:00
return exploreManager;
}
public void setExplore() {
2016-03-30 15:42:36 +02:00
exploreManager = new ExploreManager();
2016-01-09 13:58:33 +01:00
}
/**
* Returns scoreboard manager
* @return the scoreboard manager
*/
2016-03-30 15:42:36 +02:00
public static ScboardManager getScboard() {
return scboardManager;
}
public void setScboard() {
scboardManager = new ScboardManager(this);
}
/**
* Returns sign manager
* @return the sign manager
*/
public static SignUtil getSignUtil() {
return signManager;
}
public static void setSignUtil(Jobs plugin) {
signManager = new SignUtil(plugin);
}
/**
* Returns language manager
* @return the language manager
*/
public static Language getLanguage() {
return lManager;
}
public void setLanguage() {
lManager = new Language(this);
}
2016-03-30 15:42:36 +02:00
public static LanguageManager getLanguageManager() {
return lmManager;
}
public static void setLanguageManager(Jobs plugin) {
2016-03-30 15:42:36 +02:00
lmManager = new LanguageManager(plugin);
}
2015-09-10 12:41:19 +02:00
/**
* Sets the plugin logger
*/
public void setPluginLogger(Logger logger) {
2015-09-10 12:41:19 +02:00
pLogger = logger;
}
/**
* Retrieves the plugin logger
* @return the plugin logger
*/
public static Logger getPluginLogger() {
return pLogger;
}
/**
* Sets the data folder
* @param dir - the data folder
*/
public void setDataFolder(File dir) {
2015-09-10 12:41:19 +02:00
dataFolder = dir;
}
/**
* Retrieves the data folder
* @return data folder
*/
public static File getFolder() {
2015-09-10 12:41:19 +02:00
return dataFolder;
}
/**
* Sets the Data Access Object
* @param dao - the DAO
*/
public static void setDAO(JobsDAO value) {
dao = value;
}
/**
* Get the Data Access Object
* @return the DAO
*/
public static JobsDAO getJobsDAO() {
return dao;
}
/**
* Sets the list of jobs
* @param jobs - list of jobs
*/
public static void setJobs(List<Job> list) {
jobs = list;
}
/**
* Retrieves the list of active jobs
* @return list of jobs
*/
public static List<Job> getJobs() {
return Collections.unmodifiableList(jobs);
}
/**
* Sets the none job
* @param noneJob - the none job
*/
public static void setNoneJob(Job job) {
noneJob = job;
}
/**
* Retrieves the "none" job
* @return the none job
*/
public static Job getNoneJob() {
return noneJob;
}
/**
* Function to return the job information that matches the jobName given
* @param jobName - the ame of the job given
* @return the job that matches the name
*/
public static Job getJob(String jobName) {
for (Job job : jobs) {
if (job.getName().equalsIgnoreCase(jobName))
return job;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
return null;
}
/**
* Executes startup
* @throws IOException
*/
public void startup() {
2016-08-05 12:28:31 +02:00
try {
reload();
} catch (IOException e1) {
e1.printStackTrace();
2016-06-09 17:35:24 +02:00
}
Bukkit.getScheduler().runTaskAsynchronously(this, new Runnable() {
@Override
public void run() {
int i = 0;
int y = 0;
int total = Jobs.getPlayerManager().getMapSize();
long time = System.currentTimeMillis();
2017-02-04 17:30:13 +01:00
// Cloning to avoid issues
HashMap<UUID, PlayerInfo> temp = new HashMap<UUID, PlayerInfo>(Jobs.getPlayerManager().getPlayersInfoUUIDMap());
Iterator<Entry<UUID, PlayerInfo>> it = temp.entrySet().iterator();
while (it.hasNext()) {
Entry<UUID, PlayerInfo> one = it.next();
if (!running)
return;
try {
JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayerOffline(one.getValue());
if (jPlayer == null)
continue;
Jobs.getPlayerManager().addPlayerToCache(jPlayer);
} catch (Exception e) {
}
i++;
y++;
if (y >= 1000) {
Bukkit.getConsoleSender().sendMessage(ChatColor.YELLOW + "[Jobs] Loaded " + i + "/" + total + " players data");
y = 0;
}
}
dao.getMap().clear();
Bukkit.getConsoleSender().sendMessage(ChatColor.YELLOW + "[Jobs] Preloaded " + i + " players data in " + ((int) (((System.currentTimeMillis() - time)
/ 1000d) * 100) / 100D));
return;
}
});
2015-09-10 12:41:19 +02:00
// add all online players
for (Player online : Bukkit.getServer().getOnlinePlayers()) {
Jobs.getPlayerManager().playerJoin(online);
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
/**
* Reloads all data
* @throws IOException
*/
public static void reload() throws IOException {
if (saveTask != null) {
saveTask.shutdown();
saveTask = null;
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
if (paymentThread != null) {
paymentThread.shutdown();
paymentThread = null;
2015-08-21 15:10:08 +02:00
}
smanager = new SelectionManager();
2015-09-10 12:41:19 +02:00
if (dao != null) {
dao.closeConnections();
2015-08-21 15:10:08 +02:00
}
GconfigManager.reload();
lManager.reload();
2016-03-30 15:42:36 +02:00
Jobs.getConfigManager().reload();
2015-09-10 12:41:19 +02:00
usedSlots.clear();
for (Job job : jobs) {
usedSlots.put(job, getJobsDAO().getSlotsTaken(job));
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
pManager.reload();
permissionHandler.registerPermissions();
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
// set the system to auto save
if (GconfigManager.getSavePeriod() > 0) {
saveTask = new DatabaseSaveThread(GconfigManager.getSavePeriod());
2015-09-10 12:41:19 +02:00
saveTask.start();
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
// schedule payouts to buffered payments
paymentThread = new BufferedPaymentThread(GconfigManager.getEconomyBatchDelay());
2015-09-10 12:41:19 +02:00
paymentThread.start();
2015-08-21 15:10:08 +02:00
2016-03-30 15:42:36 +02:00
Jobs.getJobsDAO().loadPlayerData();
2016-04-03 16:22:44 +02:00
// Schedule
Jobs.getScheduleManager().load();
if (GconfigManager.useGlobalBoostScheduler)
Jobs.getScheduleManager().start();
2017-01-11 18:21:33 +01:00
permissionManager = new PermissionManager();
2015-09-10 12:41:19 +02:00
}
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
/**
* Executes clean shutdown
*/
public static void shutdown() {
if (saveTask != null)
saveTask.shutdown();
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if (paymentThread != null)
paymentThread.shutdown();
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
pManager.saveAll();
2015-08-21 15:10:08 +02:00
2015-09-10 12:41:19 +02:00
if (dao != null) {
dao.closeConnections();
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
/**
* Executes close connections
*/
public static void ChangeDatabase() {
if (dao != null) {
dao.closeConnections();
2015-08-21 15:10:08 +02:00
}
if (GconfigManager.storageMethod.equals("mysql"))
GconfigManager.startSqlite();
2015-09-10 12:41:19 +02:00
else
GconfigManager.startMysql();
2015-09-10 12:41:19 +02:00
pManager.reload();
}
/**
* Function to get the number of slots used on the server for this job
* @param job - the job
* @return the number of slots
*/
public static int getUsedSlots(Job job) {
2016-06-25 09:13:06 +02:00
if (usedSlots.containsKey(job))
return usedSlots.get(job);
2016-06-25 15:27:01 +02:00
return 0;
2015-09-10 12:41:19 +02:00
}
/**
* Function to increase the number of used slots for a job
* @param job - the job someone is taking
*/
public static void takeSlot(Job job) {
2016-06-25 09:13:06 +02:00
if (usedSlots.containsKey(job))
usedSlots.put(job, usedSlots.get(job) + 1);
2015-09-10 12:41:19 +02:00
}
/**
* Function to decrease the number of used slots for a job
* @param job - the job someone is leaving
*/
public static void leaveSlot(Job job) {
2016-06-25 09:13:06 +02:00
if (usedSlots.containsKey(job))
usedSlots.put(job, usedSlots.get(job) - 1);
2015-09-10 12:41:19 +02:00
}
/**
* Returns the jobs classloader
* @return the classloader
*/
public static JobsClassLoader getJobsClassloader() {
return classLoader;
}
public void setJobsClassloader() {
classLoader = new JobsClassLoader(this);
}
2015-09-10 12:41:19 +02:00
/**
* Sets the permission handler
* @param h - the permission handler
*/
public void setPermissionHandler(PermissionHandler h) {
2015-09-10 12:41:19 +02:00
permissionHandler = h;
}
/**
* Gets the permission handler
* @return the permission handler
*/
public static PermissionHandler getPermissionHandler() {
return permissionHandler;
}
2017-01-11 18:21:33 +01:00
public static PermissionManager getPermissionManager() {
return permissionManager;
}
2015-09-10 12:41:19 +02:00
/**
* Sets the economy handler
* @param eco - the economy handler
*/
public static void setEconomy(Jobs plugin, Economy eco) {
2015-09-10 12:41:19 +02:00
economy = new BufferedEconomy(plugin, eco);
}
/**
* Gets the economy handler
* @return the economy handler
*/
public static BufferedEconomy getEconomy() {
return economy;
}
@Override
public void onEnable() {
running = true;
String packageName = getServer().getClass().getPackage().getName();
String[] packageSplit = packageName.split("\\.");
2016-09-23 17:06:43 +02:00
version = packageSplit[packageSplit.length - 1].substring(0, packageSplit[packageSplit.length - 1].length() - 3);
try {
Class<?> nmsClass;
nmsClass = Class.forName("com.gamingmesh.jobs.nmsUtil." + version);
if (NMS.class.isAssignableFrom(nmsClass)) {
setNms((NMS) nmsClass.getConstructor().newInstance());
} else {
System.out.println("Something went wrong, please note down version and contact author v:" + version);
this.setEnabled(false);
2016-06-25 15:27:01 +02:00
}
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | IllegalArgumentException | InvocationTargetException | NoSuchMethodException
| SecurityException e) {
System.out.println("Your server version is not compatible with this plugins version! Plugin will be disabled: " + version);
this.setEnabled(false);
e.printStackTrace();
return;
2015-09-10 12:41:19 +02:00
}
2015-08-21 15:10:08 +02:00
try {
setActionBar();
YmlMaker jobConfig = new YmlMaker(this, "jobConfig.yml");
jobConfig.saveDefaultConfig();
YmlMaker jobSigns = new YmlMaker(this, "Signs.yml");
jobSigns.saveDefaultConfig();
YmlMaker jobSchedule = new YmlMaker(this, "schedule.yml");
jobSchedule.saveDefaultConfig();
YmlMaker jobShopItems = new YmlMaker(this, "shopItems.yml");
jobShopItems.saveDefaultConfig();
setPermissionHandler(new PermissionHandler(this));
setJobsClassloader();
setPlayerManager();
setScboard();
setLanguage();
setGUIManager();
setExplore();
setBBManager();
setPluginLogger(getLogger());
setDataFolder(getDataFolder());
setLoging();
setGCManager();
setConfigManager();
setCommandManager();
2016-09-29 16:24:29 +02:00
setBpManager();
getCommand("jobs").setExecutor(cManager);
this.getCommand("jobs").setTabCompleter(new TabComplete());
startup();
// register the listeners
getServer().getPluginManager().registerEvents(new JobsListener(this), this);
getServer().getPluginManager().registerEvents(new JobsPaymentListener(this), this);
setMcMMOlistener();
if (McMMOlistener.CheckmcMMO()) {
getServer().getPluginManager().registerEvents(McMMOlistener, this);
}
2015-08-21 15:10:08 +02:00
setMythicManager();
if (MythicManager.Check() && GconfigManager.MythicMobsEnabled) {
getServer().getPluginManager().registerEvents(MythicManager, this);
}
2015-08-21 15:10:08 +02:00
setPistonProtectionListener();
if (GconfigManager.useBlockProtection) {
getServer().getPluginManager().registerEvents(PistonProtectionListener, this);
2016-06-25 15:27:01 +02:00
}
2015-09-10 12:41:19 +02:00
// register economy
Bukkit.getScheduler().runTask(this, new HookEconomyTask(this));
2016-03-30 15:42:36 +02:00
// all loaded properly.
2016-03-30 15:42:36 +02:00
2016-09-29 16:24:29 +02:00
dao.loadBlockProtection();
2017-01-14 13:05:32 +01:00
getExplore().load();
2016-09-29 16:24:29 +02:00
String message = ChatColor.translateAlternateColorCodes('&', "&e[Jobs] Plugin has been enabled succesfully.");
ConsoleCommandSender console = Bukkit.getServer().getConsoleSender();
console.sendMessage(message);
lManager.reload();
2016-03-30 15:42:36 +02:00
cManager.fillCommands();
} catch (Exception e) {
System.out.println("There was some issues when starting plugin. Please contact dev about this. Plugin will be disabled.");
this.setEnabled(false);
e.printStackTrace();
2016-03-30 15:42:36 +02:00
}
}
@Override
public void onDisable() {
running = false;
GUIManager.CloseInventories();
shopManager.CloseInventories();
dao.saveExplore();
2016-09-29 16:24:29 +02:00
dao.saveBlockProtection();
Jobs.shutdown();
String message = ChatColor.translateAlternateColorCodes('&', "&e[Jobs] &2Plugin has been disabled succesfully.");
ConsoleCommandSender console = Bukkit.getServer().getConsoleSender();
console.sendMessage(message);
2016-03-30 15:42:36 +02:00
}
2015-09-10 12:41:19 +02:00
/**
* Performed an action
*
* Give correct experience and income
* @param jPlayer - the player
* @param action - the action
* @param multiplier - the payment/xp multiplier
*/
public static void action(JobsPlayer jPlayer, ActionInfo info) {
action(jPlayer, info, null, null, null);
2016-09-29 16:24:29 +02:00
}
public static void action(JobsPlayer jPlayer, ActionInfo info, Block block) {
action(jPlayer, info, block, null, null);
}
public static void action(JobsPlayer jPlayer, ActionInfo info, Entity ent) {
action(jPlayer, info, null, ent, null);
}
public static void action(JobsPlayer jPlayer, ActionInfo info, Entity ent, LivingEntity victim) {
action(jPlayer, info, null, ent, victim);
}
public static void action(JobsPlayer jPlayer, ActionInfo info, Block block, Entity ent, LivingEntity victim) {
2015-09-10 12:41:19 +02:00
if (jPlayer == null)
return;
List<JobProgression> progression = jPlayer.getJobProgression();
int numjobs = progression.size();
// no job
if (numjobs == 0) {
if (noneJob == null)
return;
JobInfo jobinfo = noneJob.getJobInfo(info, 1);
2016-03-30 15:42:36 +02:00
if (jobinfo == null)
return;
2015-09-10 12:41:19 +02:00
if (!isBpOk(jPlayer.getPlayer(), info.getType(), block, true))
return;
Double income = jobinfo.getIncome(1, numjobs);
Double pointAmount = jobinfo.getPoints(1, numjobs);
2015-09-10 12:41:19 +02:00
if (income != 0D || pointAmount != 0D) {
2016-03-30 15:42:36 +02:00
Boost boost = pManager.getFinalBonus(jPlayer, Jobs.getNoneJob());
2016-04-03 16:22:44 +02:00
// Calculate income
2016-04-03 16:22:44 +02:00
if (income != 0D) {
income = income + (income * boost.getFinal(CurrencyType.MONEY));
if (GconfigManager.useMinimumOveralPayment && income > 0) {
double maxLimit = income * GconfigManager.MinimumOveralPaymentLimit;
if (income < maxLimit) {
income = maxLimit;
2016-04-03 16:22:44 +02:00
}
}
}
2016-03-30 15:42:36 +02:00
// Calculate points
2016-03-30 15:42:36 +02:00
if (pointAmount != 0D) {
pointAmount = pointAmount + (pointAmount * boost.getFinal(CurrencyType.POINTS));
if (GconfigManager.useMinimumOveralPoints && pointAmount > 0) {
double maxLimit = pointAmount * GconfigManager.MinimumOveralPaymentLimit;
if (pointAmount < maxLimit) {
pointAmount = maxLimit;
2016-04-03 16:22:44 +02:00
}
}
}
2016-03-30 15:42:36 +02:00
if (!jPlayer.isUnderLimit(CurrencyType.MONEY, income)) {
income = 0D;
if (GconfigManager.getLimit(CurrencyType.MONEY).getStopWith().contains(CurrencyType.POINTS))
2016-04-03 16:22:44 +02:00
pointAmount = 0D;
}
2016-09-29 16:24:29 +02:00
if (!jPlayer.isUnderLimit(CurrencyType.POINTS, pointAmount)) {
pointAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.POINTS).getStopWith().contains(CurrencyType.MONEY))
income = 0D;
}
2016-09-29 16:24:29 +02:00
if (income == 0D && pointAmount == 0D)
return;
2016-09-29 16:24:29 +02:00
if (info.getType() == ActionType.BREAK && block != null)
Jobs.getBpManager().remove(block);
2016-04-05 14:42:48 +02:00
if (pointAmount != 0D)
jPlayer.setSaved(false);
2015-08-21 15:10:08 +02:00
Jobs.getEconomy().pay(jPlayer, income, pointAmount, 0.0);
if (GconfigManager.LoggingUse)
loging.recordToLog(jPlayer, info, income, 0);
2015-09-10 12:41:19 +02:00
}
2015-09-10 12:41:19 +02:00
} else {
for (JobProgression prog : progression) {
int level = prog.getLevel();
2016-03-30 15:42:36 +02:00
JobInfo jobinfo = prog.getJob().getJobInfo(info, level);
if (jobinfo == null)
continue;
if (!isBpOk(jPlayer.getPlayer(), info.getType(), block, true))
return;
2016-03-30 15:42:36 +02:00
Double income = jobinfo.getIncome(level, numjobs);
Double pointAmount = jobinfo.getPoints(level, numjobs);
Double expAmount = jobinfo.getExperience(level, numjobs);
2016-03-30 15:42:36 +02:00
if (income == 0D && pointAmount == 0D && expAmount == 0D)
2016-03-30 15:42:36 +02:00
continue;
if (GconfigManager.addXpPlayer()) {
2016-09-23 17:06:43 +02:00
Player player = jPlayer.getPlayer();
2016-03-30 15:42:36 +02:00
if (player != null) {
/*
* Minecraft experience is calculated in whole numbers only.
* Calculate the fraction of an experience point and perform a dice roll.
* That way jobs that give fractions of experience points will slowly give
* experience in the aggregate
*/
int expInt = expAmount.intValue();
double remainder = expAmount.doubleValue() - expInt;
2016-03-30 15:42:36 +02:00
if (Math.abs(remainder) > Math.random()) {
if (expAmount.doubleValue() < 0) {
2016-03-30 15:42:36 +02:00
expInt--;
} else {
expInt++;
2015-09-10 12:41:19 +02:00
}
}
2016-09-23 17:06:43 +02:00
if (expInt < 0 && getPlayerExperience(player) < -expInt) {
player.setLevel(0);
player.setTotalExperience(0);
player.setExp(0);
} else
player.giveExp(expInt);
2015-09-10 12:41:19 +02:00
}
2016-03-30 15:42:36 +02:00
}
Boost boost = Jobs.getPlayerManager().getFinalBonus(jPlayer, prog.getJob(), ent, victim);
2016-01-09 13:58:33 +01:00
2016-03-30 15:42:36 +02:00
// Calculate income
if (income != 0D) {
income = boost.getFinalAmount(CurrencyType.MONEY, income);
if (GconfigManager.useMinimumOveralPayment && income > 0) {
double maxLimit = income * GconfigManager.MinimumOveralPaymentLimit;
if (income < maxLimit) {
income = maxLimit;
2015-09-10 12:41:19 +02:00
}
2016-01-09 13:58:33 +01:00
}
2016-03-30 15:42:36 +02:00
}
2016-01-09 13:58:33 +01:00
2016-03-30 15:42:36 +02:00
// Calculate points
if (pointAmount != 0D) {
pointAmount = boost.getFinalAmount(CurrencyType.POINTS, pointAmount);
if (GconfigManager.useMinimumOveralPoints && pointAmount > 0) {
double maxLimit = pointAmount * GconfigManager.MinimumOveralPaymentLimit;
2016-03-30 15:42:36 +02:00
if (pointAmount < maxLimit) {
pointAmount = maxLimit;
2015-12-21 18:31:18 +01:00
}
}
2016-03-30 15:42:36 +02:00
}
2015-12-21 18:31:18 +01:00
2016-03-30 15:42:36 +02:00
// Calculate exp
expAmount = boost.getFinalAmount(CurrencyType.EXP, expAmount);
2015-08-21 15:10:08 +02:00
if (GconfigManager.useMinimumOveralPayment && expAmount > 0) {
double maxLimit = expAmount * GconfigManager.MinimumOveralPaymentLimit;
if (expAmount < maxLimit) {
expAmount = maxLimit;
2015-09-10 12:41:19 +02:00
}
2016-03-30 15:42:36 +02:00
}
2015-08-21 15:10:08 +02:00
if (!jPlayer.isUnderLimit(CurrencyType.MONEY, income)) {
income = 0D;
if (GconfigManager.getLimit(CurrencyType.MONEY).getStopWith().contains(CurrencyType.EXP))
2016-03-30 15:42:36 +02:00
expAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.MONEY).getStopWith().contains(CurrencyType.POINTS))
2016-03-30 15:42:36 +02:00
pointAmount = 0D;
}
2015-12-21 18:31:18 +01:00
if (!jPlayer.isUnderLimit(CurrencyType.EXP, expAmount)) {
2016-03-30 15:42:36 +02:00
expAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.EXP).getStopWith().contains(CurrencyType.MONEY))
income = 0D;
if (GconfigManager.getLimit(CurrencyType.EXP).getStopWith().contains(CurrencyType.POINTS))
2016-03-30 15:42:36 +02:00
pointAmount = 0D;
}
2015-08-21 15:10:08 +02:00
if (!jPlayer.isUnderLimit(CurrencyType.POINTS, pointAmount)) {
2016-03-30 15:42:36 +02:00
pointAmount = 0D;
if (GconfigManager.getLimit(CurrencyType.POINTS).getStopWith().contains(CurrencyType.MONEY))
income = 0D;
if (GconfigManager.getLimit(CurrencyType.POINTS).getStopWith().contains(CurrencyType.EXP))
2016-03-30 15:42:36 +02:00
expAmount = 0D;
}
2015-08-21 15:10:08 +02:00
if (income == 0D && pointAmount == 0D && expAmount == 0D)
2016-03-30 15:42:36 +02:00
continue;
2015-08-21 15:10:08 +02:00
try {
2017-01-10 15:25:02 +01:00
if (expAmount != 0D && GconfigManager.BossBarEnabled)
if (GconfigManager.BossBarShowOnEachAction) {
Jobs.getBBManager().ShowJobProgression(jPlayer, prog);
2017-01-10 15:25:02 +01:00
} else
jPlayer.getUpdateBossBarFor().add(prog.getJob().getName());
} catch (Exception e) {
Bukkit.getConsoleSender().sendMessage("[Jobs] Some issues with boss bar feature accured, try disabling it to avoid it.");
}
2015-08-21 15:10:08 +02:00
// JobsPayment event
JobsExpGainEvent JobsExpGainEvent = new JobsExpGainEvent(jPlayer.getPlayer(), prog.getJob(), expAmount);
Bukkit.getServer().getPluginManager().callEvent(JobsExpGainEvent);
// If event is canceled, don't do anything
if (JobsExpGainEvent.isCancelled())
expAmount = 0D;
else
expAmount = JobsExpGainEvent.getExp();
FastPayment.clear();
FastPayment.put(jPlayer.getUserName(), new FastPayment(jPlayer, info, new BufferedPayment(jPlayer.getPlayer(), income, pointAmount, expAmount), prog
.getJob()));
economy.pay(jPlayer, income, pointAmount, expAmount);
2016-03-30 15:42:36 +02:00
int oldLevel = prog.getLevel();
2015-08-21 15:10:08 +02:00
if (GconfigManager.LoggingUse)
loging.recordToLog(jPlayer, info, income, expAmount);
2016-03-30 15:42:36 +02:00
if (prog.addExperience(expAmount))
pManager.performLevelUp(jPlayer, prog.getJob(), oldLevel);
2015-09-10 12:41:19 +02:00
}
2015-08-21 15:10:08 +02:00
}
2015-09-10 12:41:19 +02:00
}
private static boolean isBpOk(Player player, ActionType type, Block block, boolean inform) {
2016-09-29 16:24:29 +02:00
if (block != null && Jobs.getGCManager().useBlockProtection) {
if (type == ActionType.BREAK) {
2016-09-29 16:24:29 +02:00
BlockProtection bp = Jobs.getBpManager().getBp(block.getLocation());
if (bp != null) {
Long time = bp.getTime();
if (time == -1)
return false;
Integer cd = Jobs.getBpManager().getBlockDelayTime(block);
if (time < System.currentTimeMillis() && bp.getAction() != DBAction.DELETE) {
Jobs.getBpManager().remove(block);
return true;
}
if ((time > System.currentTimeMillis() || bp.isPaid()) && bp.getAction() != DBAction.DELETE) {
2016-09-29 16:24:29 +02:00
int sec = Math.round((time - System.currentTimeMillis()) / 1000);
if (inform)
Jobs.getActionBar().send(player, Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
2016-09-29 16:24:29 +02:00
return false;
}
Jobs.getBpManager().add(block, cd);
if (cd == null) {
if (Jobs.getGCManager().useGlobalTimer) {
Jobs.getBpManager().add(block, System.currentTimeMillis() + (Jobs.getGCManager().globalblocktimer * 1000));
}
}
} else {
if (Jobs.getGCManager().useGlobalTimer) {
Jobs.getBpManager().add(block, System.currentTimeMillis() + (Jobs.getGCManager().globalblocktimer * 1000));
}
}
} else if (type == ActionType.PLACE) {
2016-09-29 16:24:29 +02:00
BlockProtection bp = Jobs.getBpManager().getBp(block.getLocation());
if (bp != null) {
Long time = bp.getTime();
if (time != -1) {
if (time < System.currentTimeMillis() && bp.getAction() != DBAction.DELETE) {
Jobs.getBpManager().remove(block);
return true;
}
if ((time > System.currentTimeMillis() || bp.isPaid()) && bp.getAction() != DBAction.DELETE) {
2016-09-29 16:24:29 +02:00
int sec = Math.round((time - System.currentTimeMillis()) / 1000);
if (inform)
Jobs.getActionBar().send(player, Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
2016-09-29 16:24:29 +02:00
return false;
}
} else if (bp.isPaid()) {
if (bp.getTime() == -1 && Jobs.getBpManager().getBlockDelayTime(block) != null && Jobs.getBpManager().getBlockDelayTime(block) == -1)
return false;
}
} else
Jobs.getBpManager().add(block, Jobs.getBpManager().getBlockDelayTime(block));
}
}
return true;
}
2016-09-23 17:06:43 +02:00
private static int getPlayerExperience(Player player) {
int bukkitExp = (ExpToLevel(player.getLevel()) + Math.round(deltaLevelToExp(player.getLevel()) * player.getExp()));
return bukkitExp;
}
// total xp calculation based by lvl
private static int ExpToLevel(int level) {
if (version.equals("1_7")) {
if (level <= 16) {
return 17 * level;
} else if (level <= 31) {
return ((3 * level * level) / 2) - ((59 * level) / 2) + 360;
} else {
return ((7 * level * level) / 2) - ((303 * level) / 2) + 2220;
}
}
if (level <= 16) {
return (level * level) + (6 * level);
} else if (level <= 31) {
return (int) ((2.5 * level * level) - (40.5 * level) + 360);
} else {
return (int) ((4.5 * level * level) - (162.5 * level) + 2220);
}
}
// xp calculation for one current lvl
private static int deltaLevelToExp(int level) {
if (version.equals("1_7")) {
if (level <= 16) {
return 17;
} else if (level <= 31) {
return 3 * level - 31;
} else {
return 7 * level - 155;
}
}
if (level <= 16) {
return 2 * level + 7;
} else if (level <= 31) {
return 5 * level - 38;
} else {
return 9 * level - 158;
}
}
public static void perform(JobsPlayer jPlayer, ActionInfo info, BufferedPayment payment, Job job) {
// JobsPayment event
JobsExpGainEvent JobsExpGainEvent = new JobsExpGainEvent(payment.getOfflinePlayer(), job, payment.getExp());
Bukkit.getServer().getPluginManager().callEvent(JobsExpGainEvent);
// If event is canceled, don't do anything
if (JobsExpGainEvent.isCancelled())
2016-09-29 16:24:29 +02:00
return;
if (!jPlayer.isUnderLimit(CurrencyType.MONEY, payment.getAmount()))
return;
if (!jPlayer.isUnderLimit(CurrencyType.EXP, payment.getExp()))
return;
if (!jPlayer.isUnderLimit(CurrencyType.POINTS, payment.getPoints()))
return;
2016-09-29 16:24:29 +02:00
economy.pay(jPlayer, payment.getAmount(), payment.getPoints(), payment.getExp());
JobProgression prog = jPlayer.getJobProgression(job);
int oldLevel = prog.getLevel();
if (GconfigManager.LoggingUse)
2016-09-29 16:24:29 +02:00
loging.recordToLog(jPlayer, info, payment.getAmount(), payment.getExp());
2016-09-29 16:24:29 +02:00
if (prog.addExperience(payment.getExp()))
pManager.performLevelUp(jPlayer, prog.getJob(), oldLevel);
}
public static void consoleMsg(String msg) {
Bukkit.getServer().getConsoleSender().sendMessage(ChatColor.translateAlternateColorCodes('&', msg));
}
public static SelectionManager getSelectionManager() {
return smanager;
}
2015-08-21 15:10:08 +02:00
}