1
0
mirror of https://github.com/Zrips/Jobs.git synced 2025-01-04 23:37:49 +01:00

Fix for BP?

This commit is contained in:
Zrips 2017-06-22 10:54:27 +03:00
parent fcfd3435ee
commit eda39ed0d3
7 changed files with 110 additions and 72 deletions

View File

@ -846,6 +846,9 @@ public class Jobs extends JavaPlugin {
int numjobs = progression.size(); int numjobs = progression.size();
// no job // no job
if (!isBpOk(jPlayer.getPlayer(), info, block, true))
return;
if (numjobs == 0) { if (numjobs == 0) {
if (noneJob == null) if (noneJob == null)
@ -855,9 +858,6 @@ public class Jobs extends JavaPlugin {
if (jobinfo == null) if (jobinfo == null)
return; return;
if (!isBpOk(jPlayer, info, block))
return;
Double income = jobinfo.getIncome(1, numjobs); Double income = jobinfo.getIncome(1, numjobs);
Double pointAmount = jobinfo.getPoints(1, numjobs); Double pointAmount = jobinfo.getPoints(1, numjobs);
@ -923,8 +923,6 @@ public class Jobs extends JavaPlugin {
if (jobinfo == null) if (jobinfo == null)
continue; continue;
if (!isBpOk(jPlayer, info, block))
return;
Double income = jobinfo.getIncome(level, numjobs); Double income = jobinfo.getIncome(level, numjobs);
Double pointAmount = jobinfo.getPoints(level, numjobs); Double pointAmount = jobinfo.getPoints(level, numjobs);
Double expAmount = jobinfo.getExperience(level, numjobs); Double expAmount = jobinfo.getExperience(level, numjobs);
@ -1062,35 +1060,60 @@ public class Jobs extends JavaPlugin {
} }
} }
private static boolean isBpOk(JobsPlayer jPlayer, ActionInfo info, Block block) { private static boolean isBpOk(Player player, ActionInfo info, Block block, boolean inform) {
if (block != null && Jobs.getGCManager().useBlockProtection) { if ((block != null) && (getGCManager().useBlockProtection)) {
if (info.getType() == ActionType.BREAK || info.getType() == ActionType.PLACE) { if (info.getType() == ActionType.BREAK) {
BlockProtection bp = Jobs.getBpManager().getBp(block.getLocation()); BlockProtection bp = getBpManager().getBp(block.getLocation());
if (bp != null) { if (bp != null) {
Long time = bp.getTime(); Long time = bp.getTime();
if (time == -1) if (time == -1L) {
return false;
Integer cd = Jobs.getBpManager().getBlockDelayTime(block);
if (time > System.currentTimeMillis() && bp.isPaid() && bp.getAction() != DBAction.DELETE) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000);
Jobs.getActionBar().send(jPlayer.getPlayer(),
Jobs.getLanguage().getMessage("message.blocktimer", "[time]", sec));
return false; return false;
} }
//timer expired + already paid Integer cd = getBpManager().getBlockDelayTime(block);
else if (bp.isPaid()) { if ((time < System.currentTimeMillis()) && (bp.getAction() != DBAction.DELETE)) {
Jobs.getBpManager().remove(block); getBpManager().remove(block);
return true;
} }
if (((time > System.currentTimeMillis()) || (bp.isPaid().booleanValue())) && (bp.getAction() != DBAction.DELETE)) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000L);
if (inform) {
getActionBar().send(player, getLanguage().getMessage("message.blocktimer", new Object[] { "[time]", Integer.valueOf(sec) }));
}
return false;
}
getBpManager().add(block, cd);
if ((cd == null) &&
(getGCManager().useGlobalTimer)) {
getBpManager().add(block, Long.valueOf(System.currentTimeMillis() + getGCManager().globalblocktimer * 1000));
}
} else if (getGCManager().useGlobalTimer) {
getBpManager().add(block, Long.valueOf(System.currentTimeMillis() + getGCManager().globalblocktimer * 1000));
}
} else if (info.getType() == ActionType.PLACE) {
BlockProtection bp = getBpManager().getBp(block.getLocation());
if (bp != null) {
Long time = bp.getTime();
if (time != -1L) {
if ((time < System.currentTimeMillis()) && (bp.getAction() != DBAction.DELETE)) {
getBpManager().add(block, getBpManager().getBlockDelayTime(block));
return true;
}
if (((time > System.currentTimeMillis()) || (bp.isPaid().booleanValue())) && (bp.getAction() != DBAction.DELETE)) {
int sec = Math.round((time - System.currentTimeMillis()) / 1000L);
if (cd != null) { Debug.D((time - System.currentTimeMillis()) + " " + bp.isPaid().booleanValue() + bp.getAction());
Jobs.getBpManager().add(block,
System.currentTimeMillis() + (Jobs.getGCManager().globalblocktimer * 1000)); if (inform) {
} else { getActionBar().send(player, getLanguage().getMessage("message.blocktimer", new Object[] { "[time]", Integer.valueOf(sec) }));
Jobs.getBpManager().add(block, cd); }
return false;
}
} else if ((bp.isPaid().booleanValue()) &&
(bp.getTime() == -1L) && (getBpManager().getBlockDelayTime(block) != null) && (getBpManager().getBlockDelayTime(block).intValue() == -1)) {
return false;
} }
} else {
getBpManager().add(block, getBpManager().getBlockDelayTime(block));
} }
} }
} }

View File

@ -13,6 +13,7 @@ import com.gamingmesh.jobs.Jobs;
import com.gamingmesh.jobs.commands.Cmd; import com.gamingmesh.jobs.commands.Cmd;
import com.gamingmesh.jobs.commands.JobCommand; import com.gamingmesh.jobs.commands.JobCommand;
import com.gamingmesh.jobs.container.BlockProtection; import com.gamingmesh.jobs.container.BlockProtection;
import com.gamingmesh.jobs.container.DBAction;
public class bp implements Cmd { public class bp implements Cmd {
@ -39,12 +40,12 @@ public class bp implements Cmd {
BlockProtection bp = Jobs.getBpManager().getBp(l); BlockProtection bp = Jobs.getBpManager().getBp(l);
if (bp != null) { if (bp != null) {
Long time = bp.getTime(); Long time = bp.getTime();
// if (bp.getAction() == DBAction.DELETE) if (bp.getAction() == DBAction.DELETE)
// continue; continue;
// if (time != -1 && time < System.currentTimeMillis()) { if (time != -1 && time < System.currentTimeMillis()) {
// Jobs.getBpManager().remove(l); Jobs.getBpManager().remove(l);
// continue; continue;
// } }
changedBlocks.add(l.getBlock()); changedBlocks.add(l.getBlock());
if (time == -1) if (time == -1)
player.sendBlockChange(l, Material.STAINED_GLASS, (byte) 15); player.sendBlockChange(l, Material.STAINED_GLASS, (byte) 15);

View File

@ -13,23 +13,24 @@ import com.gamingmesh.jobs.Jobs;
import com.gamingmesh.jobs.container.BlockProtection; import com.gamingmesh.jobs.container.BlockProtection;
import com.gamingmesh.jobs.container.DBAction; import com.gamingmesh.jobs.container.DBAction;
import com.gamingmesh.jobs.listeners.JobsPaymentListener; import com.gamingmesh.jobs.listeners.JobsPaymentListener;
import com.gamingmesh.jobs.stuff.Debug;
public class BlockProtectionManager { public class BlockProtectionManager {
private HashMap<World, HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>> map = private HashMap<World, HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>> map =
new HashMap<World, HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>>(); new HashMap<World, HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>>();
public Long timer = 0L; public Long timer = 0L;
public HashMap<World, HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>> getMap() { public HashMap<World, HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>> getMap() {
return this.map; return this.map;
} }
public int getSize() { public int getSize() {
int i = 0; int i = 0;
for (Entry<World, HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>> worlds : map.entrySet()) { for (Entry<World, HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>> worlds : map.entrySet()) {
for (Entry<String, HashMap<String, HashMap<Vector, BlockProtection>>> regions : worlds.getValue().entrySet()) { for (Entry<String, HashMap<String, HashMap<String, BlockProtection>>> regions : worlds.getValue().entrySet()) {
for (Entry<String, HashMap<Vector, BlockProtection>> chunks : regions.getValue().entrySet()) { for (Entry<String, HashMap<String, BlockProtection>> chunks : regions.getValue().entrySet()) {
i += chunks.getValue().size(); i += chunks.getValue().size();
} }
} }
@ -71,23 +72,23 @@ public class BlockProtectionManager {
} }
public BlockProtection add(Location loc, Long time, boolean paid) { public BlockProtection add(Location loc, Long time, boolean paid) {
Vector v = new Vector(loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()); String v = loc.getBlockX() + ":" + loc.getBlockY() + ":" + loc.getBlockZ();
HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>> regions = map.get(loc.getWorld()); HashMap<String, HashMap<String, HashMap<String, BlockProtection>>> regions = map.get(loc.getWorld());
if (regions == null) if (regions == null)
regions = new HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>(); regions = new HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>();
String region = locToRegion(loc); String region = locToRegion(loc);
HashMap<String, HashMap<Vector, BlockProtection>> chunks = regions.get(region); HashMap<String, HashMap<String, BlockProtection>> chunks = regions.get(region);
if (chunks == null) if (chunks == null)
chunks = new HashMap<String, HashMap<Vector, BlockProtection>>(); chunks = new HashMap<String, HashMap<String, BlockProtection>>();
String chunk = locToChunk(loc); String chunk = locToChunk(loc);
HashMap<Vector, BlockProtection> Bpm = chunks.get(chunk); HashMap<String, BlockProtection> Bpm = chunks.get(chunk);
if (Bpm == null) if (Bpm == null)
Bpm = new HashMap<Vector, BlockProtection>(); Bpm = new HashMap<String, BlockProtection>();
BlockProtection Bp = Bpm.get(v); BlockProtection Bp = Bpm.get(v);
if (Bp == null) if (Bp == null)
Bp = new BlockProtection(DBAction.INSERT); Bp = new BlockProtection(DBAction.INSERT, new Vector(loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()));
else else
Bp.setAction(DBAction.UPDATE); Bp.setAction(DBAction.UPDATE);
@ -105,16 +106,16 @@ public class BlockProtectionManager {
} }
public BlockProtection remove(Location loc) { public BlockProtection remove(Location loc) {
HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>> world = map.get(loc.getWorld()); HashMap<String, HashMap<String, HashMap<String, BlockProtection>>> world = map.get(loc.getWorld());
if (world == null) if (world == null)
return null; return null;
HashMap<String, HashMap<Vector, BlockProtection>> region = world.get(locToRegion(loc)); HashMap<String, HashMap<String, BlockProtection>> region = world.get(locToRegion(loc));
if (region == null) if (region == null)
return null; return null;
HashMap<Vector, BlockProtection> chunk = region.get(locToChunk(loc)); HashMap<String, BlockProtection> chunk = region.get(locToChunk(loc));
if (chunk == null) if (chunk == null)
return null; return null;
Vector v = new Vector(loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()); String v = loc.getBlockX() + ":" + loc.getBlockY() + ":" + loc.getBlockZ();
BlockProtection bp = chunk.get(v); BlockProtection bp = chunk.get(v);
if (bp != null) if (bp != null)
bp.setAction(DBAction.DELETE); bp.setAction(DBAction.DELETE);
@ -133,19 +134,25 @@ public class BlockProtectionManager {
} }
public BlockProtection getBp(Location loc) { public BlockProtection getBp(Location loc) {
HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>> world = map.get(loc.getWorld()); HashMap<String, HashMap<String, HashMap<String, BlockProtection>>> world = map.get(loc.getWorld());
if (world == null) if (world == null)
return null; return null;
HashMap<String, HashMap<Vector, BlockProtection>> region = world.get(locToRegion(loc)); HashMap<String, HashMap<String, BlockProtection>> region = world.get(locToRegion(loc));
if (region == null) if (region == null)
return null; return null;
HashMap<Vector, BlockProtection> chunk = region.get(locToChunk(loc)); HashMap<String, BlockProtection> chunk = region.get(locToChunk(loc));
if (chunk == null) if (chunk == null)
return null; return null;
Vector v = new Vector(loc.getBlockX(), loc.getBlockY(), loc.getBlockZ()); String v = loc.getBlockX() + ":" + loc.getBlockY() + ":" + loc.getBlockZ();
BlockProtection Bp = chunk.get(v); BlockProtection Bp = chunk.get(v);
if (Bp == null) if (Bp == null)
return null; return null;
Debug.D("by " + v);
Debug.D("got " + Bp.getPos().toString());
for (Entry<String, BlockProtection> one : chunk.entrySet()) {
Debug.D("g " + one.getKey());
}
return Bp; return Bp;
} }

View File

@ -499,7 +499,7 @@ public class GeneralConfigManager {
c.getW().addComment("broadcast.on-level-up.levels", "For what levels you want to broadcast message? Keep it at 0 if you want for all of them"); c.getW().addComment("broadcast.on-level-up.levels", "For what levels you want to broadcast message? Keep it at 0 if you want for all of them");
BroadcastingLevelUpLevels = c.getIntList("broadcast.on-level-up.levels", Arrays.asList(0)); BroadcastingLevelUpLevels = c.getIntList("broadcast.on-level-up.levels", Arrays.asList(0));
c.getW().addComment("max-jobs", "Maximum number of jobs a player can join.", "Use 0 for no maximum"); c.getW().addComment("max-jobs", "Maximum number of jobs a player can join.", "Use 0 for no maximum", "Keep in mind that jobs.max.[amount] will bypass this setting");
maxJobs = c.get("max-jobs", 3); maxJobs = c.get("max-jobs", 3);
c.getW().addComment("hide-jobs-without-permission", "Hide jobs from player if they lack the permission to join the job"); c.getW().addComment("hide-jobs-without-permission", "Hide jobs from player if they lack the permission to join the job");

View File

@ -1,5 +1,7 @@
package com.gamingmesh.jobs.container; package com.gamingmesh.jobs.container;
import org.bukkit.util.Vector;
public class BlockProtection { public class BlockProtection {
private int id; private int id;
@ -7,12 +9,15 @@ public class BlockProtection {
private Long recorded; private Long recorded;
private DBAction action = DBAction.INSERT; private DBAction action = DBAction.INSERT;
private Boolean paid = true; private Boolean paid = true;
private Vector pos;
public BlockProtection() { public BlockProtection(Vector pos) {
this.pos = pos;
} }
public BlockProtection(DBAction action) { public BlockProtection(DBAction action, Vector pos) {
this.action = action; this.action = action;
this.pos = pos;
} }
public Long getTime() { public Long getTime() {
@ -55,4 +60,12 @@ public class BlockProtection {
public void setId(int id) { public void setId(int id) {
this.id = id; this.id = id;
} }
public Vector getPos() {
return pos;
}
public void setPos(Vector pos) {
this.pos = pos;
}
} }

View File

@ -1133,10 +1133,10 @@ public abstract class JobsDAO {
Long mark = System.currentTimeMillis() - (Jobs.getGCManager().BlockProtectionDays * 24L * 60L * 60L * 1000L); Long mark = System.currentTimeMillis() - (Jobs.getGCManager().BlockProtectionDays * 24L * 60L * 60L * 1000L);
ConsoleCommandSender console = Bukkit.getServer().getConsoleSender(); ConsoleCommandSender console = Bukkit.getServer().getConsoleSender();
for (Entry<World, HashMap<String, HashMap<String, HashMap<Vector, BlockProtection>>>> worlds : Jobs.getBpManager().getMap().entrySet()) { for (Entry<World, HashMap<String, HashMap<String, HashMap<String, BlockProtection>>>> worlds : Jobs.getBpManager().getMap().entrySet()) {
for (Entry<String, HashMap<String, HashMap<Vector, BlockProtection>>> regions : worlds.getValue().entrySet()) { for (Entry<String, HashMap<String, HashMap<String, BlockProtection>>> regions : worlds.getValue().entrySet()) {
for (Entry<String, HashMap<Vector, BlockProtection>> chunks : regions.getValue().entrySet()) { for (Entry<String, HashMap<String, BlockProtection>> chunks : regions.getValue().entrySet()) {
for (Entry<Vector, BlockProtection> block : chunks.getValue().entrySet()) { for (Entry<String, BlockProtection> block : chunks.getValue().entrySet()) {
if (block.getValue() == null) if (block.getValue() == null)
continue; continue;
switch (block.getValue().getAction()) { switch (block.getValue().getAction()) {
@ -1155,9 +1155,9 @@ public abstract class JobsDAO {
if (block.getValue().getTime() < current && block.getValue().getTime() != -1) if (block.getValue().getTime() < current && block.getValue().getTime() != -1)
continue; continue;
insert.setString(1, worlds.getKey().getName()); insert.setString(1, worlds.getKey().getName());
insert.setInt(2, block.getKey().getBlockX()); insert.setInt(2, block.getValue().getPos().getBlockX());
insert.setInt(3, block.getKey().getBlockY()); insert.setInt(3, block.getValue().getPos().getBlockY());
insert.setInt(4, block.getKey().getBlockZ()); insert.setInt(4, block.getValue().getPos().getBlockZ());
insert.setLong(5, block.getValue().getRecorded()); insert.setLong(5, block.getValue().getRecorded());
insert.setLong(6, block.getValue().getTime()); insert.setLong(6, block.getValue().getTime());
insert.addBatch(); insert.addBatch();

View File

@ -333,12 +333,6 @@ public class JobsPaymentListener implements Listener {
if (!Jobs.getPermissionHandler().hasWorldPermission(player, player.getLocation().getWorld().getName())) if (!Jobs.getPermissionHandler().hasWorldPermission(player, player.getLocation().getWorld().getName()))
return; return;
if (Jobs.getGCManager().useBlockProtection) {
BlockProtection bp = Jobs.getBpManager().getBp(block.getLocation());
if (bp == null || bp.getAction() == DBAction.DELETE)
Jobs.getBpManager().add(block, Jobs.getBpManager().getBlockDelayTime(block), false);
}
JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayer(player); JobsPlayer jPlayer = Jobs.getPlayerManager().getJobsPlayer(player);
if (jPlayer == null) if (jPlayer == null)
return; return;