mirror of
https://github.com/Zrips/Jobs.git
synced 2025-01-02 14:29:07 +01:00
Merge pull request #1688 from DersWasTaken/master
Fix hunter job payouts not being applied
This commit is contained in:
commit
ddc9000f8f
1
.gitignore
vendored
1
.gitignore
vendored
@ -6,3 +6,4 @@
|
|||||||
src/main/resources/locale/messages_en.yml
|
src/main/resources/locale/messages_en.yml
|
||||||
.classpath
|
.classpath
|
||||||
.project
|
.project
|
||||||
|
/build/
|
||||||
|
7
pom.xml
7
pom.xml
@ -226,11 +226,6 @@
|
|||||||
<!-- Temporary solution for replacing repository -->
|
<!-- Temporary solution for replacing repository -->
|
||||||
<systemPath>${basedir}/libs/mypet-3.11-20210318.180552-1.jar</systemPath>
|
<systemPath>${basedir}/libs/mypet-3.11-20210318.180552-1.jar</systemPath>
|
||||||
</dependency>
|
</dependency>
|
||||||
<dependency>
|
|
||||||
<groupId>CMILib</groupId>
|
|
||||||
<artifactId>CMILib</artifactId>
|
|
||||||
<version>1.4.3.1</version>
|
|
||||||
</dependency>
|
|
||||||
</dependencies>
|
</dependencies>
|
||||||
<repositories>
|
<repositories>
|
||||||
<!-- MythicMobs -->
|
<!-- MythicMobs -->
|
||||||
@ -293,7 +288,7 @@
|
|||||||
<artifactId>maven-jar-plugin</artifactId>
|
<artifactId>maven-jar-plugin</artifactId>
|
||||||
<version>2.3.1</version>
|
<version>2.3.1</version>
|
||||||
<configuration>
|
<configuration>
|
||||||
<outputDirectory>D:\MC\Server 1.20\plugins\</outputDirectory>
|
<outputDirectory>build/jar</outputDirectory>
|
||||||
</configuration>
|
</configuration>
|
||||||
</plugin>
|
</plugin>
|
||||||
</plugins>
|
</plugins>
|
||||||
|
@ -151,6 +151,11 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
.expireAfterWrite(10, TimeUnit.SECONDS)
|
.expireAfterWrite(10, TimeUnit.SECONDS)
|
||||||
.weakKeys()
|
.weakKeys()
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
|
private final Cache<UUID, Player> entityLastDamager = CacheBuilder.newBuilder()
|
||||||
|
.expireAfterWrite(5, TimeUnit.MINUTES)
|
||||||
|
.weakKeys()
|
||||||
|
.build();
|
||||||
private Cache<UUID, Long> cowMilkingTimer;
|
private Cache<UUID, Long> cowMilkingTimer;
|
||||||
|
|
||||||
public JobsPaymentListener(Jobs plugin) {
|
public JobsPaymentListener(Jobs plugin) {
|
||||||
@ -1227,7 +1232,7 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||||
public void onEntityDamageByPlayer(EntityDamageEvent event) {
|
public void onEntityDamageByPlayer(EntityDamageEvent event) {
|
||||||
if (!Jobs.getGCManager().MonsterDamageUse || !(event instanceof EntityDamageByEntityEvent)
|
if (!(event instanceof EntityDamageByEntityEvent)
|
||||||
|| !Jobs.getGCManager().canPerformActionInWorld(event.getEntity().getWorld()))
|
|| !Jobs.getGCManager().canPerformActionInWorld(event.getEntity().getWorld()))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -1238,6 +1243,11 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
if (!(((EntityDamageByEntityEvent) event).getDamager() instanceof Player))
|
if (!(((EntityDamageByEntityEvent) event).getDamager() instanceof Player))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
//Gross but works
|
||||||
|
entityLastDamager.put(ent.getUniqueId(), (Player) ((EntityDamageByEntityEvent) event).getDamager());
|
||||||
|
|
||||||
|
if(!Jobs.getGCManager().MonsterDamageUse) return;
|
||||||
|
|
||||||
double damage = event.getFinalDamage();
|
double damage = event.getFinalDamage();
|
||||||
double s = ((Damageable) ent).getHealth();
|
double s = ((Damageable) ent).getHealth();
|
||||||
if (damage > s)
|
if (damage > s)
|
||||||
@ -1274,6 +1284,7 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
damage = s;
|
damage = s;
|
||||||
|
|
||||||
if (((Projectile) event.getDamager()).getShooter() instanceof Player) {
|
if (((Projectile) event.getDamager()).getShooter() instanceof Player) {
|
||||||
|
entityLastDamager.put(ent.getUniqueId(), (Player) ((Projectile) event.getDamager()).getShooter());
|
||||||
Double damageDealt = damageDealtByPlayers.getIfPresent(entUUID);
|
Double damageDealt = damageDealtByPlayers.getIfPresent(entUUID);
|
||||||
if (damageDealt != null) {
|
if (damageDealt != null) {
|
||||||
damageDealtByPlayers.put(entUUID, damageDealt + damage);
|
damageDealtByPlayers.put(entUUID, damageDealt + damage);
|
||||||
@ -1285,17 +1296,18 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
|
|
||||||
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
@EventHandler(priority = EventPriority.MONITOR, ignoreCancelled = true)
|
||||||
public void onEntityDeath(EntityDeathEvent event) {
|
public void onEntityDeath(EntityDeathEvent event) {
|
||||||
if (!(event.getEntity().getLastDamageCause() instanceof EntityDamageByEntityEvent) ||
|
if(!Jobs.getGCManager().canPerformActionInWorld(event.getEntity().getWorld()))
|
||||||
!Jobs.getGCManager().canPerformActionInWorld(event.getEntity().getWorld()))
|
|
||||||
return;
|
return;
|
||||||
|
|
||||||
EntityDamageByEntityEvent e = (EntityDamageByEntityEvent) event.getEntity().getLastDamageCause();
|
LivingEntity lVictim = event.getEntity();
|
||||||
|
Entity killer;
|
||||||
|
|
||||||
// Entity that died must be living
|
if(!(event.getEntity().getLastDamageCause() instanceof EntityDamageByEntityEvent)) {
|
||||||
if (!(e.getEntity() instanceof LivingEntity))
|
if(entityLastDamager.getIfPresent(event.getEntity().getUniqueId()) == null) return;
|
||||||
return;
|
killer = entityLastDamager.getIfPresent(event.getEntity().getUniqueId());
|
||||||
|
} else {
|
||||||
LivingEntity lVictim = (LivingEntity) e.getEntity();
|
killer = ((EntityDamageByEntityEvent) event.getEntity().getLastDamageCause()).getDamager();
|
||||||
|
}
|
||||||
|
|
||||||
// mob spawner, no payment or experience
|
// mob spawner, no payment or experience
|
||||||
if (!Jobs.getGCManager().payNearSpawner() && lVictim.hasMetadata(Jobs.getPlayerManager().getMobSpawnerMetadata())) {
|
if (!Jobs.getGCManager().payNearSpawner() && lVictim.hasMetadata(Jobs.getPlayerManager().getMobSpawnerMetadata())) {
|
||||||
@ -1326,7 +1338,7 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//extra check for Citizens 2 sentry kills
|
//extra check for Citizens 2 sentry kills
|
||||||
if (e.getDamager() instanceof Player && e.getDamager().hasMetadata("NPC"))
|
if (killer.hasMetadata("NPC"))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (Jobs.getGCManager().MythicMobsEnabled && HookManager.getMythicManager() != null
|
if (Jobs.getGCManager().MythicMobsEnabled && HookManager.getMythicManager() != null
|
||||||
@ -1336,26 +1348,21 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
|
|
||||||
Player pDamager = null;
|
Player pDamager = null;
|
||||||
|
|
||||||
boolean isTameable = e.getDamager() instanceof Tameable;
|
boolean isTameable = killer instanceof Tameable;
|
||||||
boolean isMyPet = HookManager.getMyPetManager() != null && HookManager.getMyPetManager().isMyPet(e.getDamager(), null);
|
boolean isMyPet = HookManager.getMyPetManager() != null && HookManager.getMyPetManager().isMyPet(killer, null);
|
||||||
|
|
||||||
if (e.getDamager() instanceof Player) { // Checking if killer is player
|
if (killer instanceof Player) { // Checking if killer is player
|
||||||
pDamager = (Player) e.getDamager();
|
pDamager = (Player) killer;
|
||||||
} else if (isMyPet) { // Checking if killer is MyPet animal
|
} else if (isMyPet) { // Checking if killer is MyPet animal
|
||||||
UUID uuid = HookManager.getMyPetManager().getOwnerOfPet(e.getDamager());
|
UUID uuid = HookManager.getMyPetManager().getOwnerOfPet(killer);
|
||||||
|
|
||||||
if (uuid != null)
|
if (uuid != null)
|
||||||
pDamager = Bukkit.getPlayer(uuid);
|
pDamager = Bukkit.getPlayer(uuid);
|
||||||
} else if (isTameable) { // Checking if killer is tamed animal
|
} else if (isTameable) { // Checking if killer is tamed animal
|
||||||
Tameable t = (Tameable) e.getDamager();
|
Tameable t = (Tameable) killer;
|
||||||
|
|
||||||
if (t.isTamed() && t.getOwner() instanceof Player)
|
if (t.isTamed() && t.getOwner() instanceof Player)
|
||||||
pDamager = (Player) t.getOwner();
|
pDamager = (Player) t.getOwner();
|
||||||
} else if (e.getDamager() instanceof Projectile) {
|
|
||||||
Projectile pr = (Projectile) e.getDamager();
|
|
||||||
|
|
||||||
if (pr.getShooter() instanceof Player)
|
|
||||||
pDamager = (Player) pr.getShooter();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pDamager == null)
|
if (pDamager == null)
|
||||||
@ -1396,18 +1403,18 @@ public final class JobsPaymentListener implements Listener {
|
|||||||
if (Jobs.getGCManager().payForStackedEntities) {
|
if (Jobs.getGCManager().payForStackedEntities) {
|
||||||
if (JobsHook.WildStacker.isEnabled()) {
|
if (JobsHook.WildStacker.isEnabled()) {
|
||||||
for (int i = 0; i < HookManager.getWildStackerHandler().getEntityAmount(lVictim) - 1; i++) {
|
for (int i = 0; i < HookManager.getWildStackerHandler().getEntityAmount(lVictim) - 1; i++) {
|
||||||
Jobs.action(jDamager, new EntityActionInfo(lVictim, ActionType.KILL), e.getDamager(), lVictim);
|
Jobs.action(jDamager, new EntityActionInfo(lVictim, ActionType.KILL), killer, lVictim);
|
||||||
}
|
}
|
||||||
} else if (JobsHook.StackMob.isEnabled() && HookManager.getStackMobHandler().isStacked(lVictim)) {
|
} else if (JobsHook.StackMob.isEnabled() && HookManager.getStackMobHandler().isStacked(lVictim)) {
|
||||||
for (uk.antiperson.stackmob.entity.StackEntity stacked : HookManager.getStackMobHandler().getStackEntities()) {
|
for (uk.antiperson.stackmob.entity.StackEntity stacked : HookManager.getStackMobHandler().getStackEntities()) {
|
||||||
if (stacked.getEntity().getType() == lVictim.getType()) {
|
if (stacked.getEntity().getType() == lVictim.getType()) {
|
||||||
Jobs.action(jDamager, new EntityActionInfo(stacked.getEntity(), ActionType.KILL), e.getDamager(), stacked.getEntity());
|
Jobs.action(jDamager, new EntityActionInfo(stacked.getEntity(), ActionType.KILL), killer, stacked.getEntity());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Jobs.action(jDamager, new EntityActionInfo(lVictim, ActionType.KILL), e.getDamager(), lVictim);
|
Jobs.action(jDamager, new EntityActionInfo(lVictim, ActionType.KILL), killer, lVictim);
|
||||||
|
|
||||||
// Payment for killing player with particular job, except NPC's
|
// Payment for killing player with particular job, except NPC's
|
||||||
if (notNpc) {
|
if (notNpc) {
|
||||||
|
Loading…
Reference in New Issue
Block a user