1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-02 14:29:07 +01:00

Added wildStacker and stackMob support to pay for stacked entities

Closes #923
This commit is contained in:
montlikadani 2020-09-21 17:42:20 +02:00
parent a85a54aa5d
commit c91f88858a
10 changed files with 168 additions and 33 deletions

12
pom.xml
View File

@ -18,7 +18,7 @@
<dependency>
<groupId>org.spigotmc</groupId>
<artifactId>spigot-api</artifactId>
<version>1.16.2-R0.1-SNAPSHOT</version>
<version>1.16.3-R0.1-SNAPSHOT</version>
<scope>provided</scope>
</dependency>
<!-- Boss -->
@ -164,6 +164,16 @@
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>com.github.OmerBenGera</groupId>
<artifactId>WildStackerAPI</artifactId>
<version>master-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.github.Nathat23</groupId>
<artifactId>StackMob-5</artifactId>
<version>master-SNAPSHOT</version>
</dependency>
</dependencies>
<repositories>
<!-- WorldGuard & WorldEdit -->

View File

@ -49,7 +49,7 @@ public class JobsCommands implements CommandExecutor {
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
if (sender instanceof Player && !Jobs.getGCManager().canPerformActionInWorld(((Player) sender).getWorld()) && !sender.hasPermission("jobs.disabledworld.commands")) {
if (sender instanceof Player && !Jobs.getGCManager().canPerformActionInWorld(((Player) sender).getWorld())) {
sender.sendMessage(Jobs.getLanguage().getMessage("general.error.worldisdisabled"));
return true;
}

View File

@ -52,10 +52,10 @@ public class GeneralConfigManager {
*/
@Deprecated public List<Schedule> BoostSchedule = new ArrayList<>();
public HashMap<CMIMaterial, HashMap<Enchantment, Integer>> whiteListedItems = new HashMap<>();
private HashMap<CurrencyType, CurrencyLimit> currencyLimitUse = new HashMap<>();
private HashMap<CurrencyType, Double> generalMulti = new HashMap<>();
private HashMap<String, List<String>> commandArgs = new HashMap<>();
public final HashMap<CMIMaterial, HashMap<Enchantment, Integer>> whiteListedItems = new HashMap<>();
private final HashMap<CurrencyType, CurrencyLimit> currencyLimitUse = new HashMap<>();
private final HashMap<CurrencyType, Double> generalMulti = new HashMap<>();
private final HashMap<String, List<String>> commandArgs = new HashMap<>();
protected Locale locale;
private ConfigReader c = null;
@ -101,7 +101,7 @@ public class GeneralConfigManager {
hideJobsInfoWithoutPermission, UseTaxes, TransferToServerAccount, TakeFromPlayersPayment, AutoJobJoinUse, AllowDelevel,
BossBarEnabled, BossBarShowOnEachAction, BossBarsMessageByDefault, ExploreCompact, DBCleaningJobsUse, DBCleaningUsersUse,
DisabledWorldsUse, UseAsWhiteListWorldList, PaymentMethodsMoney, PaymentMethodsPoints, PaymentMethodsExp, MythicMobsEnabled,
LoggingUse, payForCombiningItems, BlastFurnacesReassign, SmokerReassign;
LoggingUse, payForCombiningItems, BlastFurnacesReassign, SmokerReassign, payForStackedEntities;
public ItemStack guiBackButton, guiNextButton, guiFiller;
@ -497,6 +497,9 @@ public class GeneralConfigManager {
"This option is only related to: sugar_cane, cactus, kelp, bamboo");
preventCropResizePayment = c.get("prevent-crop-resize-payment", false);
c.addComment("pay-for-stacked-entities", "Allows to pay for stacked entities for each one. Requires StackMob or WildStacker.");
payForStackedEntities = c.get("pay-for-stacked-entities", false);
c.addComment("allow-pay-for-durability-loss", "Allows, when losing maximum durability of item then it does not pay the player until it is repaired.",
"E.g. the player wants to enchant a item with enchanting table and the item has durability loss then not paying.");
c.addComment("allow-pay-for-durability-loss.Use", "Do not disable this if you don't know what mean this option.");

View File

@ -12,16 +12,20 @@ import com.gamingmesh.jobs.hooks.MythicMobs.MythicMobInterface;
import com.gamingmesh.jobs.hooks.MythicMobs.MythicMobs2;
import com.gamingmesh.jobs.hooks.MythicMobs.MythicMobs4;
import com.gamingmesh.jobs.hooks.WorldGuard.WorldGuardManager;
import com.gamingmesh.jobs.hooks.stackMob.StackMobHandler;
import com.gamingmesh.jobs.hooks.wildStacker.WildStackerHandler;
public class HookManager {
private static McMMOManager McMMOManager = null;
private static MythicMobInterface MythicManager = null;
private static MyPetManager myPetManager = null;
private static WorldGuardManager worldGuardManager = null;
private static BossManager bossManager = null;
private static McMMOManager McMMOManager;
private static MythicMobInterface MythicManager;
private static MyPetManager myPetManager;
private static WorldGuardManager worldGuardManager;
private static BossManager bossManager;
private static StackMobHandler stackMobHandler;
private static WildStackerHandler wildStackerHandler;
private static PluginManager pm = null;
private static PluginManager pm;
public static void loadHooks() {
pm = Jobs.getInstance().getServer().getPluginManager();
@ -33,11 +37,29 @@ public class HookManager {
setWorldGuard();
setMythicManager();
setBossManager();
setStackMobHandler();
setWildStackerHandler();
if (checkMythicMobs())
MythicManager.registerListener();
}
public static StackMobHandler getStackMobHandler() {
if (stackMobHandler == null) {
setStackMobHandler();
}
return stackMobHandler;
}
public static WildStackerHandler getWildStackerHandler() {
if (wildStackerHandler == null) {
setWildStackerHandler();
}
return wildStackerHandler;
}
public static MyPetManager getMyPetManager() {
if (myPetManager == null) {
setMyPetManager();
@ -77,7 +99,7 @@ public class HookManager {
}
private static boolean setWorldGuard() {
if (pm.getPlugin("WorldGuard") != null && pm.isPluginEnabled("WorldGuard")) {
if (isPluginEnabled("WorldGuard")) {
worldGuardManager = new WorldGuardManager();
Jobs.consoleMsg("&e[Jobs] WorldGuard detected.");
return true;
@ -87,7 +109,7 @@ public class HookManager {
}
private static void setMythicManager() {
if (pm.getPlugin("MythicMobs") == null)
if (!isPluginEnabled("MythicMobs"))
return;
try {
@ -122,16 +144,32 @@ public class HookManager {
}
private static void setMyPetManager() {
if (pm.getPlugin("MyPet") != null && pm.isPluginEnabled("MyPet")) {
if (isPluginEnabled("MyPet")) {
myPetManager = new MyPetManager();
Jobs.consoleMsg("&e[Jobs] MyPet detected.");
}
}
private static void setBossManager() {
if (pm.getPlugin("Boss") != null && pm.isPluginEnabled("Boss")) {
if (isPluginEnabled("Boss")) {
bossManager = new BossManager();
Jobs.consoleMsg("&e[Jobs] Boss detected.");
}
}
private static void setStackMobHandler() {
if (isPluginEnabled("StackMob")) {
stackMobHandler = new StackMobHandler();
}
}
private static void setWildStackerHandler() {
if (isPluginEnabled("WildStacker")) {
wildStackerHandler = new WildStackerHandler();
}
}
public static boolean isPluginEnabled(String name) {
return pm.getPlugin(name) != null && pm.isPluginEnabled(name);
}
}

View File

@ -0,0 +1,8 @@
package com.gamingmesh.jobs.hooks;
import org.bukkit.plugin.java.JavaPlugin;
public abstract class HookPlugin {
public abstract JavaPlugin getPlugin();
}

View File

@ -27,10 +27,7 @@ public class MythicMobs2 implements MythicMobInterface {
@Override
public boolean isMythicMob(LivingEntity lVictim) {
if (MMAPI == null || lVictim == null)
return false;
return MMAPI.getMobAPI().isMythicMob(lVictim);
return MMAPI != null && lVictim != null && MMAPI.getMobAPI().isMythicMob(lVictim);
}
@Override

View File

@ -26,10 +26,7 @@ public class MythicMobs4 implements MythicMobInterface {
@Override
public boolean isMythicMob(LivingEntity lVictim) {
if (MMAPI == null || lVictim == null)
return false;
return MMAPI.isMythicMob(lVictim);
return MMAPI != null && lVictim != null && MMAPI.isMythicMob(lVictim);
}
@Override

View File

@ -0,0 +1,29 @@
package com.gamingmesh.jobs.hooks.stackMob;
import java.util.HashSet;
import org.bukkit.entity.LivingEntity;
import org.bukkit.plugin.java.JavaPlugin;
import com.gamingmesh.jobs.hooks.HookPlugin;
import uk.antiperson.stackmob.StackMob;
import uk.antiperson.stackmob.entity.StackEntity;
public class StackMobHandler extends HookPlugin {
public boolean isStacked(LivingEntity entity) {
return getPlugin().getEntityManager().isStackedEntity(entity);
}
public HashSet<StackEntity> getStackEntities() {
return new HashSet<>();
// waiting for the author to fix build issue
//return getPlugin().getEntityManager().getStackEntities();
}
@Override
public StackMob getPlugin() {
return JavaPlugin.getPlugin(StackMob.class);
}
}

View File

@ -0,0 +1,19 @@
package com.gamingmesh.jobs.hooks.wildStacker;
import java.util.List;
import org.bukkit.entity.LivingEntity;
import com.bgsoftware.wildstacker.api.WildStackerAPI;
import com.bgsoftware.wildstacker.api.objects.StackedEntity;
public class WildStackerHandler {
public boolean isStackedEntity(LivingEntity entity) {
return WildStackerAPI.getStackedEntity(entity) != null;
}
public List<StackedEntity> getStackedEntities() {
return WildStackerAPI.getWildStacker().getSystemManager().getStackedEntities();
}
}

View File

@ -87,8 +87,12 @@ import org.bukkit.metadata.FixedMetadataValue;
import org.bukkit.metadata.MetadataValue;
import org.bukkit.projectiles.ProjectileSource;
import java.util.*;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.UUID;
public class JobsPaymentListener implements Listener {
@ -278,6 +282,17 @@ public class JobsPaymentListener implements Listener {
if (jDamager == null || sheep.getColor() == null)
return;
if (Jobs.getGCManager().payForStackedEntities && HookManager.isPluginEnabled("WildStacker")
&& HookManager.getWildStackerHandler().isStackedEntity(sheep)) {
for (com.bgsoftware.wildstacker.api.objects.StackedEntity stacked : HookManager.getWildStackerHandler().getStackedEntities()) {
if (stacked.getType() == sheep.getType()) {
Jobs.action(jDamager, new CustomKillInfo(((Sheep) stacked.getLivingEntity()).getColor().name(), ActionType.SHEAR));
}
}
return;
}
Jobs.action(jDamager, new CustomKillInfo(sheep.getColor().name(), ActionType.SHEAR));
}
@ -462,7 +477,7 @@ public class JobsPaymentListener implements Listener {
if (!payForItemDurabilityLoss(player))
return;
if (event.getState().equals(PlayerFishEvent.State.CAUGHT_FISH) && event.getCaught() instanceof Item) {
if (event.getState() == PlayerFishEvent.State.CAUGHT_FISH && event.getCaught() instanceof Item) {
JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayer(player);
if (jPlayer == null)
return;
@ -511,6 +526,17 @@ public class JobsPaymentListener implements Listener {
if (jDamager == null)
return;
if (Jobs.getGCManager().payForStackedEntities && HookManager.isPluginEnabled("WildStacker")
&& HookManager.getWildStackerHandler().isStackedEntity(animal)) {
for (com.bgsoftware.wildstacker.api.objects.StackedEntity stacked : HookManager.getWildStackerHandler().getStackedEntities()) {
if (stacked.getType() == animal.getType()) {
Jobs.action(jDamager, new EntityActionInfo(stacked.getLivingEntity(), ActionType.TAME));
}
}
return;
}
Jobs.action(jDamager, new EntityActionInfo(animal, ActionType.TAME));
}
@ -851,7 +877,7 @@ public class JobsPaymentListener implements Listener {
return;
}
if (Jobs.getGCManager().PayForEnchantingOnAnvil && inv.getItem(1) != null && inv.getItem(1).getType().equals(Material.ENCHANTED_BOOK)) {
if (Jobs.getGCManager().PayForEnchantingOnAnvil && inv.getItem(1) != null && inv.getItem(1).getType() == Material.ENCHANTED_BOOK) {
Map<Enchantment, Integer> enchants = resultStack.getEnchantments();
for (Entry<Enchantment, Integer> oneEnchant : enchants.entrySet()) {
Enchantment enchant = oneEnchant.getKey();
@ -1090,10 +1116,7 @@ public class JobsPaymentListener implements Listener {
return;
}
if (!(damager instanceof Projectile))
return;
if (!(ent instanceof Damageable))
if (!(damager instanceof Projectile) || !(ent instanceof Damageable))
return;
Projectile projectile = (Projectile) damager;
@ -1205,6 +1228,17 @@ public class JobsPaymentListener implements Listener {
return;
}
if (Jobs.getGCManager().payForStackedEntities && HookManager.isPluginEnabled("WildStacker")
&& HookManager.getWildStackerHandler().isStackedEntity(lVictim)) {
for (com.bgsoftware.wildstacker.api.objects.StackedEntity stacked : HookManager.getWildStackerHandler().getStackedEntities()) {
if (stacked.getType() == lVictim.getType()) {
Jobs.action(jDamager, new EntityActionInfo(stacked.getLivingEntity(), ActionType.KILL), pDamager, stacked.getLivingEntity());
}
}
return;
}
Jobs.action(jDamager, new EntityActionInfo(lVictim, ActionType.KILL), pDamager, lVictim);
// Payment for killing player with particular job, except NPC's
@ -1298,7 +1332,7 @@ public class JobsPaymentListener implements Listener {
return;
Location loc = event.getLocation();
Collection<Entity> ents = Version.isCurrentEqualOrLower(Version.v1_8_R1) || loc.getWorld() == null
java.util.Collection<Entity> ents = Version.isCurrentEqualOrLower(Version.v1_8_R1) || loc.getWorld() == null
? null : loc.getWorld().getNearbyEntities(loc, 4, 4, 4);
if (ents == null) {
return;