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

Block protection change by wysohn to resolve some current issues

This commit is contained in:
Zrips 2017-05-11 17:20:36 +03:00
parent c83000c7db
commit e0f2ffb25f

View File

@ -842,7 +842,7 @@ public class Jobs extends JavaPlugin {
if (jobinfo == null)
return;
if (!isBpOk(jPlayer.getPlayer(), info.getType(), block, true))
if (!isBpOk(jPlayer, info, block))
return;
Double income = jobinfo.getIncome(1, numjobs);
@ -910,7 +910,7 @@ public class Jobs extends JavaPlugin {
if (jobinfo == null)
continue;
if (!isBpOk(jPlayer.getPlayer(), info.getType(), block, true))
if (!isBpOk(jPlayer, info, block))
return;
Double income = jobinfo.getIncome(level, numjobs);
Double pointAmount = jobinfo.getPoints(level, numjobs);
@ -1039,65 +1039,44 @@ public class Jobs extends JavaPlugin {
if (prog.addExperience(expAmount))
pManager.performLevelUp(jPlayer, prog.getJob(), oldLevel);
}
//need to update bp
BlockProtection bp = BpManager.getBp(block.getLocation());
if (bp != null)
bp.setPaid(true);
}
}
private static boolean isBpOk(Player player, ActionType type, Block block, boolean inform) {
private static boolean isBpOk(JobsPlayer jPlayer, ActionInfo info, Block block) {
if (block != null && Jobs.getGCManager().useBlockProtection) {
if (type == ActionType.BREAK) {
if (info.getType() == ActionType.BREAK || info.getType() == ActionType.PLACE) {
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) {
if (time > System.currentTimeMillis() && bp.isPaid() && bp.getAction() != DBAction.DELETE) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000);
if (inform)
Jobs.getActionBar().send(player, Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
Jobs.getActionBar().send(jPlayer.getPlayer(),
Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
return false;
}
//timer expired + already paid
else if (bp.isPaid()) {
Jobs.getBpManager().remove(block);
}
Jobs.getBpManager().add(block, cd);
if (cd == null) {
if (Jobs.getGCManager().useGlobalTimer) {
Jobs.getBpManager().add(block, System.currentTimeMillis() + (Jobs.getGCManager().globalblocktimer * 1000));
}
}
if (cd != null) {
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));
Jobs.getBpManager().add(block, cd);
}
}
} else if (type == ActionType.PLACE) {
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) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000);
if (inform)
Jobs.getActionBar().send(player, Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
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;