2012-01-15 23:58:19 +01:00
|
|
|
package org.dynmap.bukkit;
|
|
|
|
|
|
|
|
import java.io.File;
|
2012-10-15 08:19:18 +02:00
|
|
|
import java.lang.reflect.InvocationTargetException;
|
|
|
|
import java.lang.reflect.Method;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.net.InetSocketAddress;
|
2012-03-31 05:07:33 +02:00
|
|
|
import java.util.HashMap;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.util.HashSet;
|
2012-02-22 15:07:13 +01:00
|
|
|
import java.util.LinkedList;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.util.List;
|
2012-03-31 05:07:33 +02:00
|
|
|
import java.util.Map;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.util.Set;
|
2018-02-14 02:11:16 +01:00
|
|
|
import java.util.UUID;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.util.concurrent.Callable;
|
2012-09-04 03:43:30 +02:00
|
|
|
import java.util.concurrent.CancellationException;
|
2013-01-11 22:59:55 +01:00
|
|
|
import java.util.concurrent.ExecutionException;
|
2012-01-15 23:58:19 +01:00
|
|
|
import java.util.concurrent.Future;
|
2021-07-18 03:19:56 +02:00
|
|
|
import java.util.concurrent.atomic.AtomicBoolean;
|
2012-01-15 23:58:19 +01:00
|
|
|
|
2019-12-01 03:38:05 +01:00
|
|
|
import org.bstats.bukkit.Metrics;
|
2021-11-13 00:44:33 +01:00
|
|
|
import org.bstats.charts.CustomChart;
|
|
|
|
import org.bstats.json.JsonObjectBuilder;
|
|
|
|
import org.bstats.json.JsonObjectBuilder.JsonObject;
|
2013-09-08 07:00:25 +02:00
|
|
|
import org.bukkit.Bukkit;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.ChatColor;
|
|
|
|
import org.bukkit.Chunk;
|
2013-01-08 07:10:53 +01:00
|
|
|
import org.bukkit.ChunkSnapshot;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.Location;
|
2012-02-22 15:07:13 +01:00
|
|
|
import org.bukkit.Material;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.OfflinePlayer;
|
|
|
|
import org.bukkit.World;
|
|
|
|
import org.bukkit.block.Block;
|
|
|
|
import org.bukkit.block.BlockFace;
|
2012-02-14 03:06:37 +01:00
|
|
|
import org.bukkit.block.BlockState;
|
2019-10-04 00:51:57 +02:00
|
|
|
import org.bukkit.block.Sign;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.command.Command;
|
|
|
|
import org.bukkit.command.CommandSender;
|
|
|
|
import org.bukkit.entity.Player;
|
2012-02-12 06:02:23 +01:00
|
|
|
import org.bukkit.event.EventHandler;
|
|
|
|
import org.bukkit.event.EventPriority;
|
|
|
|
import org.bukkit.event.Listener;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.block.BlockBreakEvent;
|
|
|
|
import org.bukkit.event.block.BlockBurnEvent;
|
|
|
|
import org.bukkit.event.block.BlockFadeEvent;
|
|
|
|
import org.bukkit.event.block.BlockFormEvent;
|
|
|
|
import org.bukkit.event.block.BlockFromToEvent;
|
2012-02-29 06:40:52 +01:00
|
|
|
import org.bukkit.event.block.BlockGrowEvent;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.block.BlockPhysicsEvent;
|
|
|
|
import org.bukkit.event.block.BlockPistonExtendEvent;
|
|
|
|
import org.bukkit.event.block.BlockPistonRetractEvent;
|
|
|
|
import org.bukkit.event.block.BlockPlaceEvent;
|
2012-07-11 09:09:51 +02:00
|
|
|
import org.bukkit.event.block.BlockRedstoneEvent;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.block.BlockSpreadEvent;
|
|
|
|
import org.bukkit.event.block.LeavesDecayEvent;
|
|
|
|
import org.bukkit.event.block.SignChangeEvent;
|
|
|
|
import org.bukkit.event.entity.EntityExplodeEvent;
|
2012-08-05 06:02:24 +02:00
|
|
|
import org.bukkit.event.player.AsyncPlayerChatEvent;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.player.PlayerBedLeaveEvent;
|
|
|
|
import org.bukkit.event.player.PlayerJoinEvent;
|
|
|
|
import org.bukkit.event.player.PlayerMoveEvent;
|
|
|
|
import org.bukkit.event.player.PlayerQuitEvent;
|
2012-10-05 07:10:32 +02:00
|
|
|
import org.bukkit.event.server.PluginEnableEvent;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.world.ChunkPopulateEvent;
|
|
|
|
import org.bukkit.event.world.SpawnChangeEvent;
|
2012-02-14 03:06:37 +01:00
|
|
|
import org.bukkit.event.world.StructureGrowEvent;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.event.world.WorldLoadEvent;
|
|
|
|
import org.bukkit.event.world.WorldUnloadEvent;
|
2012-03-31 05:07:33 +02:00
|
|
|
import org.bukkit.permissions.Permission;
|
|
|
|
import org.bukkit.permissions.PermissionDefault;
|
2012-01-22 23:24:02 +01:00
|
|
|
import org.bukkit.plugin.Plugin;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.bukkit.plugin.PluginDescriptionFile;
|
|
|
|
import org.bukkit.plugin.PluginManager;
|
|
|
|
import org.bukkit.plugin.java.JavaPlugin;
|
2013-01-04 04:58:58 +01:00
|
|
|
import org.bukkit.potion.PotionEffectType;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.dynmap.DynmapAPI;
|
2012-05-19 22:50:20 +02:00
|
|
|
import org.dynmap.DynmapChunk;
|
2013-03-21 05:59:50 +01:00
|
|
|
import org.dynmap.DynmapCommonAPIListener;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.dynmap.DynmapCore;
|
|
|
|
import org.dynmap.DynmapLocation;
|
|
|
|
import org.dynmap.DynmapWebChatEvent;
|
|
|
|
import org.dynmap.DynmapWorld;
|
|
|
|
import org.dynmap.Log;
|
|
|
|
import org.dynmap.MapManager;
|
2012-08-25 05:37:48 +02:00
|
|
|
import org.dynmap.MapType;
|
2012-01-22 17:48:43 +01:00
|
|
|
import org.dynmap.PlayerList;
|
2018-08-08 08:39:51 +02:00
|
|
|
import org.dynmap.bukkit.helper.BukkitVersionHelper;
|
|
|
|
import org.dynmap.bukkit.helper.BukkitWorld;
|
|
|
|
import org.dynmap.bukkit.helper.SnapshotCache;
|
2012-01-16 06:19:01 +01:00
|
|
|
import org.dynmap.bukkit.permissions.BukkitPermissions;
|
|
|
|
import org.dynmap.bukkit.permissions.NijikokunPermissions;
|
|
|
|
import org.dynmap.bukkit.permissions.OpPermissions;
|
2012-03-24 04:02:13 +01:00
|
|
|
import org.dynmap.bukkit.permissions.PEXPermissions;
|
|
|
|
import org.dynmap.bukkit.permissions.PermBukkitPermissions;
|
2013-05-10 08:31:30 +02:00
|
|
|
import org.dynmap.bukkit.permissions.GroupManagerPermissions;
|
2012-01-16 06:19:01 +01:00
|
|
|
import org.dynmap.bukkit.permissions.PermissionProvider;
|
2020-01-27 05:42:05 +01:00
|
|
|
import org.dynmap.bukkit.permissions.VaultPermissions;
|
2012-03-24 04:02:13 +01:00
|
|
|
import org.dynmap.bukkit.permissions.bPermPermissions;
|
2019-03-20 06:54:52 +01:00
|
|
|
import org.dynmap.bukkit.permissions.LuckPermsPermissions;
|
2019-12-15 19:53:50 +01:00
|
|
|
import org.dynmap.bukkit.permissions.LuckPerms5Permissions;
|
2012-01-16 06:19:01 +01:00
|
|
|
import org.dynmap.common.BiomeMap;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.dynmap.common.DynmapCommandSender;
|
|
|
|
import org.dynmap.common.DynmapPlayer;
|
|
|
|
import org.dynmap.common.DynmapServerInterface;
|
2021-12-05 08:57:59 +01:00
|
|
|
import org.dynmap.common.chunk.GenericChunkCache;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.dynmap.common.DynmapListenerManager.EventType;
|
2012-08-25 05:37:48 +02:00
|
|
|
import org.dynmap.hdmap.HDMap;
|
2012-01-15 23:58:19 +01:00
|
|
|
import org.dynmap.markers.MarkerAPI;
|
2013-12-01 05:51:48 +01:00
|
|
|
import org.dynmap.modsupport.ModSupportImpl;
|
2019-12-20 05:34:32 +01:00
|
|
|
import org.dynmap.renderer.DynmapBlockState;
|
2012-05-19 22:50:20 +02:00
|
|
|
import org.dynmap.utils.MapChunkCache;
|
2015-02-15 19:40:30 +01:00
|
|
|
import org.dynmap.utils.Polygon;
|
2013-02-16 00:59:07 +01:00
|
|
|
import org.dynmap.utils.VisibilityLimit;
|
2021-03-04 20:49:47 +01:00
|
|
|
import net.skinsrestorer.bukkit.SkinsRestorer;
|
2012-01-15 23:58:19 +01:00
|
|
|
|
|
|
|
public class DynmapPlugin extends JavaPlugin implements DynmapAPI {
|
|
|
|
private DynmapCore core;
|
|
|
|
private PermissionProvider permissions;
|
|
|
|
private String version;
|
2012-01-22 17:48:43 +01:00
|
|
|
public PlayerList playerList;
|
2012-01-15 23:58:19 +01:00
|
|
|
private MapManager mapManager;
|
|
|
|
public static DynmapPlugin plugin;
|
2012-02-12 06:02:23 +01:00
|
|
|
public PluginManager pm;
|
2012-08-24 07:07:06 +02:00
|
|
|
private Metrics metrics;
|
2012-10-05 07:10:32 +02:00
|
|
|
private BukkitEnableCoreCallback enabCoreCB = new BukkitEnableCoreCallback();
|
2012-10-15 08:19:18 +02:00
|
|
|
private Method ismodloaded;
|
2013-08-16 09:17:10 +02:00
|
|
|
private Method instance;
|
|
|
|
private Method getindexedmodlist;
|
|
|
|
private Method getversion;
|
2012-10-18 02:42:37 +02:00
|
|
|
private HashMap<String, BukkitWorld> world_by_name = new HashMap<String, BukkitWorld>();
|
2012-12-18 04:08:39 +01:00
|
|
|
private HashSet<String> modsused = new HashSet<String>();
|
2013-06-20 06:20:38 +02:00
|
|
|
// TPS calculator
|
|
|
|
private double tps;
|
|
|
|
private long lasttick;
|
|
|
|
private long perTickLimit;
|
|
|
|
private long cur_tick_starttime;
|
|
|
|
private long avgticklen = 50000000;
|
2013-06-14 08:49:49 +02:00
|
|
|
|
2013-06-20 06:20:38 +02:00
|
|
|
private int chunks_in_cur_tick = 0;
|
|
|
|
private long cur_tick;
|
|
|
|
private long prev_tick;
|
|
|
|
|
2013-06-14 08:49:49 +02:00
|
|
|
private HashMap<String, Integer> sortWeights = new HashMap<String, Integer>();
|
2012-10-18 02:42:37 +02:00
|
|
|
/* Lookup cache */
|
|
|
|
private World last_world;
|
|
|
|
private BukkitWorld last_bworld;
|
2012-12-10 05:28:21 +01:00
|
|
|
|
2013-03-30 03:46:06 +01:00
|
|
|
private BukkitVersionHelper helper;
|
2021-03-04 20:49:47 +01:00
|
|
|
|
2012-10-18 02:42:37 +02:00
|
|
|
private final BukkitWorld getWorldByName(String name) {
|
|
|
|
if((last_world != null) && (last_world.getName().equals(name))) {
|
|
|
|
return last_bworld;
|
|
|
|
}
|
|
|
|
return world_by_name.get(name);
|
|
|
|
}
|
|
|
|
private final BukkitWorld getWorld(World w) {
|
|
|
|
if(last_world == w) {
|
|
|
|
return last_bworld;
|
|
|
|
}
|
|
|
|
BukkitWorld bw = world_by_name.get(w.getName());
|
|
|
|
if(bw == null) {
|
|
|
|
bw = new BukkitWorld(w);
|
|
|
|
world_by_name.put(w.getName(), bw);
|
|
|
|
}
|
2012-11-11 06:47:40 +01:00
|
|
|
else if(bw.isLoaded() == false) {
|
|
|
|
bw.setWorldLoaded(w);
|
|
|
|
}
|
2012-10-18 02:42:37 +02:00
|
|
|
last_world = w;
|
|
|
|
last_bworld = bw;
|
|
|
|
|
|
|
|
return bw;
|
|
|
|
}
|
2013-09-19 00:17:23 +02:00
|
|
|
final void removeWorld(World w) {
|
2012-10-18 02:42:37 +02:00
|
|
|
world_by_name.remove(w.getName());
|
|
|
|
if(w == last_world) {
|
|
|
|
last_world = null;
|
|
|
|
last_bworld = null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-18 03:19:56 +02:00
|
|
|
// Nonblocking thread safety
|
|
|
|
private static final AtomicBoolean tryNativeId = new AtomicBoolean(true);
|
|
|
|
@SuppressWarnings("deprecation")
|
|
|
|
private static final int getBlockIdFromMaterial(Material material) {
|
|
|
|
if (tryNativeId.get()) {
|
|
|
|
try {
|
|
|
|
return material.getId();
|
|
|
|
} catch (NoSuchMethodError e) {
|
|
|
|
// We failed once, no need to retry
|
|
|
|
tryNativeId.set(false);
|
2021-07-18 03:27:59 +02:00
|
|
|
} catch (java.lang.IllegalArgumentException e) {
|
|
|
|
// Ignore this entirely, as modern materials throw
|
|
|
|
// java.lang.IllegalArgumentException: Cannot get ID of Modern Material
|
2021-07-18 03:19:56 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// We're living in a world where numerical IDs have been phased out completely.
|
2021-07-18 03:27:59 +02:00
|
|
|
// Let's return *some* number, because we need one.
|
|
|
|
// Also in that case we are adding a constant to ensure we're not conflicting with the
|
|
|
|
// actual IDs
|
|
|
|
return material.ordinal() + (1 << 20);
|
2021-07-18 03:19:56 +02:00
|
|
|
}
|
|
|
|
private static final int getBlockIdFromBlock(Block block) {
|
|
|
|
return getBlockIdFromMaterial(block.getType());
|
|
|
|
}
|
|
|
|
|
2012-08-08 06:20:00 +02:00
|
|
|
private class BukkitEnableCoreCallback extends DynmapCore.EnableCoreCallbacks {
|
|
|
|
@Override
|
|
|
|
public void configurationLoaded() {
|
2014-10-13 16:41:14 +02:00
|
|
|
File st = new File(core.getDataFolder(), "renderdata/spout-texture.txt");
|
|
|
|
if(st.exists()) {
|
|
|
|
st.delete();
|
2012-08-08 06:20:00 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-22 15:07:13 +01:00
|
|
|
private static class BlockToCheck {
|
|
|
|
Location loc;
|
|
|
|
int typeid;
|
2012-02-23 04:00:13 +01:00
|
|
|
byte data;
|
2012-02-22 15:07:13 +01:00
|
|
|
String trigger;
|
|
|
|
};
|
2012-02-23 04:00:13 +01:00
|
|
|
private LinkedList<BlockToCheck> blocks_to_check = null;
|
|
|
|
private LinkedList<BlockToCheck> blocks_to_check_accum = new LinkedList<BlockToCheck>();
|
2012-02-22 15:07:13 +01:00
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
public DynmapPlugin() {
|
|
|
|
plugin = this;
|
2012-10-15 08:19:18 +02:00
|
|
|
try {
|
|
|
|
Class<?> c = Class.forName("cpw.mods.fml.common.Loader");
|
|
|
|
ismodloaded = c.getMethod("isModLoaded", String.class);
|
2013-08-16 09:17:10 +02:00
|
|
|
instance = c.getMethod("instance");
|
|
|
|
getindexedmodlist = c.getMethod("getIndexedModList");
|
|
|
|
c = Class.forName("cpw.mods.fml.common.ModContainer");
|
|
|
|
getversion = c.getMethod("getVersion");
|
2012-10-15 08:19:18 +02:00
|
|
|
} catch (NoSuchMethodException nsmx) {
|
|
|
|
} catch (ClassNotFoundException e) {
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Server access abstraction class
|
|
|
|
*/
|
2014-02-01 08:16:15 +01:00
|
|
|
public class BukkitServer extends DynmapServerInterface {
|
2012-12-31 19:29:28 +01:00
|
|
|
@Override
|
|
|
|
public int getBlockIDAt(String wname, int x, int y, int z) {
|
|
|
|
World w = getServer().getWorld(wname);
|
|
|
|
if((w != null) && w.isChunkLoaded(x >> 4, z >> 4)) {
|
2021-07-18 03:19:56 +02:00
|
|
|
return getBlockIdFromBlock(w.getBlockAt(x, y, z));
|
2012-12-31 19:29:28 +01:00
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
2019-08-14 13:24:38 +02:00
|
|
|
|
2019-10-04 00:51:57 +02:00
|
|
|
@Override
|
|
|
|
public int isSignAt(String wname, int x, int y, int z) {
|
|
|
|
World w = getServer().getWorld(wname);
|
|
|
|
if((w != null) && w.isChunkLoaded(x >> 4, z >> 4)) {
|
|
|
|
Block b = w.getBlockAt(x, y, z);
|
|
|
|
BlockState s = b.getState();
|
|
|
|
|
|
|
|
if (s instanceof Sign) {
|
|
|
|
return 1;
|
|
|
|
} else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
@Override
|
|
|
|
public void scheduleServerTask(Runnable run, long delay) {
|
|
|
|
getServer().getScheduler().scheduleSyncDelayedTask(DynmapPlugin.this, run, delay);
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public DynmapPlayer[] getOnlinePlayers() {
|
2014-07-10 05:20:33 +02:00
|
|
|
Player[] players = helper.getOnlinePlayers();
|
2012-01-15 23:58:19 +01:00
|
|
|
DynmapPlayer[] dplay = new DynmapPlayer[players.length];
|
|
|
|
for(int i = 0; i < players.length; i++)
|
|
|
|
dplay[i] = new BukkitPlayer(players[i]);
|
|
|
|
return dplay;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public void reload() {
|
|
|
|
PluginManager pluginManager = getServer().getPluginManager();
|
|
|
|
pluginManager.disablePlugin(DynmapPlugin.this);
|
|
|
|
pluginManager.enablePlugin(DynmapPlugin.this);
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public DynmapPlayer getPlayer(String name) {
|
|
|
|
Player p = getServer().getPlayerExact(name);
|
|
|
|
if(p != null) {
|
|
|
|
return new BukkitPlayer(p);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public Set<String> getIPBans() {
|
|
|
|
return getServer().getIPBans();
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public <T> Future<T> callSyncMethod(Callable<T> task) {
|
2013-04-22 04:05:12 +02:00
|
|
|
if(DynmapPlugin.this.isEnabled())
|
|
|
|
return getServer().getScheduler().callSyncMethod(DynmapPlugin.this, task);
|
|
|
|
else
|
|
|
|
return null;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2019-06-09 04:58:00 +02:00
|
|
|
private boolean noservername = false;
|
2012-01-15 23:58:19 +01:00
|
|
|
@Override
|
|
|
|
public String getServerName() {
|
2019-04-28 01:55:19 +02:00
|
|
|
try {
|
2019-06-09 04:58:00 +02:00
|
|
|
if (!noservername)
|
|
|
|
return getServer().getServerName();
|
2019-04-28 01:55:19 +02:00
|
|
|
} catch (NoSuchMethodError x) { // Missing in 1.14 spigot - no idea why removed...
|
2019-06-09 04:58:00 +02:00
|
|
|
noservername = true;
|
2019-04-28 01:55:19 +02:00
|
|
|
}
|
2019-06-09 04:58:00 +02:00
|
|
|
return getServer().getMotd();
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean isPlayerBanned(String pid) {
|
|
|
|
OfflinePlayer p = getServer().getOfflinePlayer(pid);
|
|
|
|
if((p != null) && p.isBanned())
|
|
|
|
return true;
|
|
|
|
return false;
|
|
|
|
}
|
2015-01-06 06:02:09 +01:00
|
|
|
@Override
|
|
|
|
public boolean isServerThread() {
|
|
|
|
return Bukkit.getServer().isPrimaryThread();
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
@Override
|
|
|
|
public String stripChatColor(String s) {
|
|
|
|
return ChatColor.stripColor(s);
|
|
|
|
}
|
|
|
|
private Set<EventType> registered = new HashSet<EventType>();
|
|
|
|
@Override
|
|
|
|
public boolean requestEventNotification(EventType type) {
|
|
|
|
if(registered.contains(type))
|
|
|
|
return true;
|
|
|
|
switch(type) {
|
|
|
|
case WORLD_LOAD:
|
|
|
|
case WORLD_UNLOAD:
|
|
|
|
/* Already called for normal world activation/deactivation */
|
|
|
|
break;
|
|
|
|
case WORLD_SPAWN_CHANGE:
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-17 06:06:31 +01:00
|
|
|
public void onSpawnChange(SpawnChangeEvent evt) {
|
2012-11-11 06:47:40 +01:00
|
|
|
BukkitWorld w = getWorld(evt.getWorld());
|
2012-01-15 23:58:19 +01:00
|
|
|
core.listenerManager.processWorldEvent(EventType.WORLD_SPAWN_CHANGE, w);
|
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
}, DynmapPlugin.this);
|
2012-01-15 23:58:19 +01:00
|
|
|
break;
|
|
|
|
case PLAYER_JOIN:
|
|
|
|
case PLAYER_QUIT:
|
|
|
|
/* Already handled */
|
|
|
|
break;
|
|
|
|
case PLAYER_BED_LEAVE:
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onPlayerBedLeave(PlayerBedLeaveEvent evt) {
|
|
|
|
DynmapPlayer p = new BukkitPlayer(evt.getPlayer());
|
|
|
|
core.listenerManager.processPlayerEvent(EventType.PLAYER_BED_LEAVE, p);
|
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
}, DynmapPlugin.this);
|
2012-01-15 23:58:19 +01:00
|
|
|
break;
|
|
|
|
case PLAYER_CHAT:
|
2013-06-20 06:20:38 +02:00
|
|
|
pm.registerEvents(new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2013-06-20 06:20:38 +02:00
|
|
|
public void onPlayerChat(AsyncPlayerChatEvent evt) {
|
|
|
|
final Player p = evt.getPlayer();
|
|
|
|
final String msg = evt.getMessage();
|
|
|
|
getServer().getScheduler().scheduleSyncDelayedTask(DynmapPlugin.this, new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
DynmapPlayer dp = null;
|
|
|
|
if(p != null)
|
|
|
|
dp = new BukkitPlayer(p);
|
|
|
|
core.listenerManager.processChatEvent(EventType.PLAYER_CHAT, dp, msg);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}, DynmapPlugin.this);
|
2012-01-15 23:58:19 +01:00
|
|
|
break;
|
|
|
|
case BLOCK_BREAK:
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onBlockBreak(BlockBreakEvent evt) {
|
|
|
|
Block b = evt.getBlock();
|
2012-05-23 06:53:29 +02:00
|
|
|
if(b == null) return; /* Work around for stupid mods.... */
|
2012-01-15 23:58:19 +01:00
|
|
|
Location l = b.getLocation();
|
2019-12-20 05:34:32 +01:00
|
|
|
core.listenerManager.processBlockEvent(EventType.BLOCK_BREAK, b.getType().name(),
|
2012-10-18 02:42:37 +02:00
|
|
|
getWorld(l.getWorld()).getName(), l.getBlockX(), l.getBlockY(), l.getBlockZ());
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
}, DynmapPlugin.this);
|
2012-01-15 23:58:19 +01:00
|
|
|
break;
|
|
|
|
case SIGN_CHANGE:
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(new Listener() {
|
2014-03-12 05:58:01 +01:00
|
|
|
@EventHandler(priority=EventPriority.HIGHEST, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onSignChange(SignChangeEvent evt) {
|
|
|
|
Block b = evt.getBlock();
|
|
|
|
Location l = b.getLocation();
|
|
|
|
String[] lines = evt.getLines(); /* Note: changes to this change event - intentional */
|
|
|
|
DynmapPlayer dp = null;
|
|
|
|
Player p = evt.getPlayer();
|
|
|
|
if(p != null) dp = new BukkitPlayer(p);
|
2019-12-20 05:34:32 +01:00
|
|
|
core.listenerManager.processSignChangeEvent(EventType.SIGN_CHANGE, b.getType().name(),
|
2012-10-18 02:42:37 +02:00
|
|
|
getWorld(l.getWorld()).getName(), l.getBlockX(), l.getBlockY(), l.getBlockZ(), lines, dp);
|
2021-08-27 08:15:51 +02:00
|
|
|
|
|
|
|
for (int i = 0; i < 4; i++) {
|
|
|
|
evt.setLine(i, lines[i]);
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
}, DynmapPlugin.this);
|
2012-01-15 23:58:19 +01:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
Log.severe("Unhandled event type: " + type);
|
|
|
|
return false;
|
|
|
|
}
|
2012-02-22 06:34:00 +01:00
|
|
|
registered.add(type);
|
2012-01-15 23:58:19 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean sendWebChatEvent(String source, String name, String msg) {
|
|
|
|
DynmapWebChatEvent evt = new DynmapWebChatEvent(source, name, msg);
|
|
|
|
getServer().getPluginManager().callEvent(evt);
|
2012-02-23 06:10:13 +01:00
|
|
|
return ((evt.isCancelled() == false) && (evt.isProcessed() == false));
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public void broadcastMessage(String msg) {
|
|
|
|
getServer().broadcastMessage(msg);
|
|
|
|
}
|
2012-01-16 06:19:01 +01:00
|
|
|
@Override
|
|
|
|
public String[] getBiomeIDs() {
|
|
|
|
BiomeMap[] b = BiomeMap.values();
|
|
|
|
String[] bname = new String[b.length];
|
|
|
|
for(int i = 0; i < bname.length; i++)
|
|
|
|
bname[i] = b[i].toString();
|
|
|
|
return bname;
|
|
|
|
}
|
2012-01-18 06:58:11 +01:00
|
|
|
@Override
|
|
|
|
public double getCacheHitRate() {
|
2021-12-05 08:57:59 +01:00
|
|
|
return helper.useGenericCache() ? BukkitVersionHelper.gencache.getHitRate() : SnapshotCache.sscache.getHitRate();
|
2012-01-18 06:58:11 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public void resetCacheStats() {
|
2021-12-05 08:57:59 +01:00
|
|
|
if (helper.useGenericCache()) {
|
|
|
|
BukkitVersionHelper.gencache.resetStats();
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
SnapshotCache.sscache.resetStats();
|
|
|
|
}
|
2012-01-18 06:58:11 +01:00
|
|
|
}
|
2012-02-05 22:53:24 +01:00
|
|
|
@Override
|
|
|
|
public DynmapWorld getWorldByName(String wname) {
|
2012-10-18 02:42:37 +02:00
|
|
|
return DynmapPlugin.this.getWorldByName(wname);
|
2012-02-05 22:53:24 +01:00
|
|
|
}
|
2012-02-13 06:10:18 +01:00
|
|
|
@Override
|
|
|
|
public DynmapPlayer getOfflinePlayer(String name) {
|
|
|
|
OfflinePlayer op = getServer().getOfflinePlayer(name);
|
|
|
|
if(op != null) {
|
|
|
|
return new BukkitPlayer(op);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2012-03-25 06:29:31 +02:00
|
|
|
@Override
|
|
|
|
public Set<String> checkPlayerPermissions(String player, Set<String> perms) {
|
|
|
|
OfflinePlayer p = getServer().getOfflinePlayer(player);
|
|
|
|
if(p.isBanned())
|
|
|
|
return new HashSet<String>();
|
|
|
|
Set<String> rslt = permissions.hasOfflinePermissions(player, perms);
|
|
|
|
if (rslt == null) {
|
|
|
|
rslt = new HashSet<String>();
|
|
|
|
if(p.isOp()) {
|
|
|
|
rslt.addAll(perms);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return rslt;
|
|
|
|
}
|
2012-03-25 21:29:49 +02:00
|
|
|
@Override
|
|
|
|
public boolean checkPlayerPermission(String player, String perm) {
|
|
|
|
OfflinePlayer p = getServer().getOfflinePlayer(player);
|
|
|
|
if(p.isBanned())
|
|
|
|
return false;
|
2012-12-30 16:17:35 +01:00
|
|
|
boolean rslt = permissions.hasOfflinePermission(player, perm);
|
|
|
|
return rslt;
|
2012-03-25 21:29:49 +02:00
|
|
|
}
|
2012-05-19 22:50:20 +02:00
|
|
|
/**
|
|
|
|
* Render processor helper - used by code running on render threads to request chunk snapshot cache from server/sync thread
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public MapChunkCache createMapChunkCache(DynmapWorld w, List<DynmapChunk> chunks,
|
|
|
|
boolean blockdata, boolean highesty, boolean biome, boolean rawbiome) {
|
|
|
|
MapChunkCache c = w.getChunkCache(chunks);
|
2012-11-11 06:47:40 +01:00
|
|
|
if(c == null) { /* Can fail if not currently loaded */
|
|
|
|
return null;
|
|
|
|
}
|
2012-05-19 22:50:20 +02:00
|
|
|
if(w.visibility_limits != null) {
|
2013-02-16 00:59:07 +01:00
|
|
|
for(VisibilityLimit limit: w.visibility_limits) {
|
2012-05-19 22:50:20 +02:00
|
|
|
c.setVisibleRange(limit);
|
|
|
|
}
|
|
|
|
c.setHiddenFillStyle(w.hiddenchunkstyle);
|
|
|
|
}
|
|
|
|
if(w.hidden_limits != null) {
|
2013-02-16 00:59:07 +01:00
|
|
|
for(VisibilityLimit limit: w.hidden_limits) {
|
2012-05-19 22:50:20 +02:00
|
|
|
c.setHiddenRange(limit);
|
|
|
|
}
|
|
|
|
c.setHiddenFillStyle(w.hiddenchunkstyle);
|
|
|
|
}
|
|
|
|
if(c.setChunkDataTypes(blockdata, biome, highesty, rawbiome) == false) {
|
|
|
|
Log.severe("CraftBukkit build does not support biome APIs");
|
|
|
|
}
|
|
|
|
if(chunks.size() == 0) { /* No chunks to get? */
|
|
|
|
c.loadChunks(0);
|
|
|
|
return c;
|
|
|
|
}
|
|
|
|
|
|
|
|
final MapChunkCache cc = c;
|
|
|
|
|
|
|
|
while(!cc.isDoneLoading()) {
|
|
|
|
Future<Boolean> f = core.getServer().callSyncMethod(new Callable<Boolean>() {
|
|
|
|
public Boolean call() throws Exception {
|
2013-06-20 06:20:38 +02:00
|
|
|
boolean exhausted = true;
|
|
|
|
|
2014-02-04 05:29:00 +01:00
|
|
|
if (prev_tick != cur_tick) {
|
|
|
|
prev_tick = cur_tick;
|
|
|
|
cur_tick_starttime = System.nanoTime();
|
|
|
|
}
|
|
|
|
if(chunks_in_cur_tick > 0) {
|
|
|
|
boolean done = false;
|
|
|
|
while (!done) {
|
|
|
|
int cnt = chunks_in_cur_tick;
|
|
|
|
if (cnt > 5) cnt = 5;
|
|
|
|
chunks_in_cur_tick -= cc.loadChunks(cnt);
|
|
|
|
exhausted = (chunks_in_cur_tick == 0) || ((System.nanoTime() - cur_tick_starttime) > perTickLimit);
|
|
|
|
done = exhausted || cc.isDoneLoading();
|
2012-11-11 06:47:40 +01:00
|
|
|
}
|
2012-05-19 22:50:20 +02:00
|
|
|
}
|
|
|
|
return exhausted;
|
|
|
|
}
|
|
|
|
});
|
2013-04-22 04:05:12 +02:00
|
|
|
if (f == null) {
|
|
|
|
return null;
|
|
|
|
}
|
2012-05-19 22:50:20 +02:00
|
|
|
Boolean delay;
|
|
|
|
try {
|
|
|
|
delay = f.get();
|
2012-09-04 03:43:30 +02:00
|
|
|
} catch (CancellationException cx) {
|
|
|
|
return null;
|
2013-01-11 22:59:55 +01:00
|
|
|
} catch (ExecutionException ex) {
|
|
|
|
Log.severe("Exception while fetching chunks: ", ex.getCause());
|
|
|
|
return null;
|
2012-05-19 22:50:20 +02:00
|
|
|
} catch (Exception ix) {
|
|
|
|
Log.severe(ix);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
if((delay != null) && delay.booleanValue()) {
|
|
|
|
try { Thread.sleep(25); } catch (InterruptedException ix) {}
|
|
|
|
}
|
|
|
|
}
|
2012-11-11 06:47:40 +01:00
|
|
|
/* If cancelled due to world unload return nothing */
|
|
|
|
if(w.isLoaded() == false)
|
|
|
|
return null;
|
2012-05-19 22:50:20 +02:00
|
|
|
return c;
|
|
|
|
}
|
2012-07-31 04:42:59 +02:00
|
|
|
@Override
|
|
|
|
public int getMaxPlayers() {
|
|
|
|
return getServer().getMaxPlayers();
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public int getCurrentPlayers() {
|
2014-07-10 05:20:33 +02:00
|
|
|
return helper.getOnlinePlayers().length;
|
2012-07-31 04:42:59 +02:00
|
|
|
}
|
2012-10-15 08:19:18 +02:00
|
|
|
@Override
|
|
|
|
public boolean isModLoaded(String name) {
|
|
|
|
if(ismodloaded != null) {
|
|
|
|
try {
|
|
|
|
Object rslt =ismodloaded.invoke(null, name);
|
|
|
|
if(rslt instanceof Boolean) {
|
2012-10-15 15:24:10 +02:00
|
|
|
if(((Boolean)rslt).booleanValue()) {
|
2012-12-18 04:08:39 +01:00
|
|
|
modsused.add(name);
|
2012-10-15 15:24:10 +02:00
|
|
|
return true;
|
|
|
|
}
|
2012-10-15 08:19:18 +02:00
|
|
|
}
|
|
|
|
} catch (IllegalArgumentException iax) {
|
|
|
|
} catch (IllegalAccessException e) {
|
|
|
|
} catch (InvocationTargetException e) {
|
|
|
|
}
|
|
|
|
}
|
2012-10-15 15:24:10 +02:00
|
|
|
return false;
|
2012-10-15 08:19:18 +02:00
|
|
|
}
|
2013-08-16 09:17:10 +02:00
|
|
|
@Override
|
|
|
|
public String getModVersion(String name) {
|
|
|
|
if((instance != null) && (getindexedmodlist != null) && (getversion != null)) {
|
|
|
|
try {
|
|
|
|
Object inst = instance.invoke(null);
|
|
|
|
Map<?,?> modmap = (Map<?,?>) getindexedmodlist.invoke(inst);
|
|
|
|
Object mod = modmap.get(name);
|
|
|
|
if (mod != null) {
|
|
|
|
return (String) getversion.invoke(mod);
|
|
|
|
}
|
|
|
|
} catch (IllegalArgumentException iax) {
|
|
|
|
} catch (IllegalAccessException e) {
|
|
|
|
} catch (InvocationTargetException e) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2013-06-20 06:20:38 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public double getServerTPS() {
|
|
|
|
return tps;
|
|
|
|
}
|
2013-09-08 07:00:25 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getServerIP() {
|
|
|
|
return Bukkit.getServer().getIp();
|
|
|
|
}
|
2014-01-07 04:41:12 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public Map<Integer, String> getBlockIDMap() {
|
2018-08-06 04:27:18 +02:00
|
|
|
String[] bsn = helper.getBlockNames();
|
2014-01-07 04:41:12 +01:00
|
|
|
HashMap<Integer, String> map = new HashMap<Integer, String>();
|
|
|
|
for (int i = 0; i < bsn.length; i++) {
|
|
|
|
if (bsn[i] != null) {
|
2018-08-06 04:27:18 +02:00
|
|
|
if (bsn[i].indexOf(':') < 0)
|
|
|
|
map.put(i, "minecraft:" + bsn[i]);
|
|
|
|
else
|
|
|
|
map.put(i, bsn[i]);
|
2014-01-07 04:41:12 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return map;
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
/**
|
|
|
|
* Player access abstraction class
|
|
|
|
*/
|
|
|
|
public class BukkitPlayer extends BukkitCommandSender implements DynmapPlayer {
|
|
|
|
private Player player;
|
2012-02-13 06:10:18 +01:00
|
|
|
private OfflinePlayer offplayer;
|
2018-02-14 02:11:16 +01:00
|
|
|
private String skinurl;
|
|
|
|
private UUID uuid;
|
2012-01-15 23:58:19 +01:00
|
|
|
|
|
|
|
public BukkitPlayer(Player p) {
|
|
|
|
super(p);
|
|
|
|
player = p;
|
2012-02-13 06:10:18 +01:00
|
|
|
offplayer = p.getPlayer();
|
2018-02-14 02:11:16 +01:00
|
|
|
uuid = p.getUniqueId();
|
|
|
|
skinurl = helper.getSkinURL(p);
|
2012-02-13 06:10:18 +01:00
|
|
|
}
|
|
|
|
public BukkitPlayer(OfflinePlayer p) {
|
|
|
|
super(null);
|
|
|
|
offplayer = p;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean isConnected() {
|
2012-02-13 06:10:18 +01:00
|
|
|
return offplayer.isOnline();
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public String getName() {
|
2012-02-13 06:10:18 +01:00
|
|
|
return offplayer.getName();
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public String getDisplayName() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player != null)
|
|
|
|
return player.getDisplayName();
|
|
|
|
else
|
|
|
|
return offplayer.getName();
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean isOnline() {
|
2012-02-13 06:10:18 +01:00
|
|
|
return offplayer.isOnline();
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public DynmapLocation getLocation() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player == null) {
|
|
|
|
return null;
|
|
|
|
}
|
2012-07-31 04:00:52 +02:00
|
|
|
Location loc = player.getEyeLocation(); // Use eye location, since we show head
|
2012-01-15 23:58:19 +01:00
|
|
|
return toLoc(loc);
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public String getWorld() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player == null) {
|
|
|
|
return null;
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
World w = player.getWorld();
|
|
|
|
if(w != null)
|
2012-10-18 02:42:37 +02:00
|
|
|
return DynmapPlugin.this.getWorld(w).getName();
|
2012-01-15 23:58:19 +01:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public InetSocketAddress getAddress() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player != null)
|
|
|
|
return player.getAddress();
|
|
|
|
return null;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean isSneaking() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player != null)
|
|
|
|
return player.isSneaking();
|
|
|
|
return false;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
2014-10-13 16:41:14 +02:00
|
|
|
public double getHealth() {
|
2018-12-08 04:33:35 +01:00
|
|
|
if(player != null) {
|
|
|
|
return Math.ceil(2.0 * player.getHealth() / player.getMaxHealth() * player.getHealthScale()) / 2.0;
|
|
|
|
}
|
2012-02-13 06:10:18 +01:00
|
|
|
else
|
|
|
|
return 0;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public int getArmorPoints() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(player != null)
|
|
|
|
return Armor.getArmorPoints(player);
|
|
|
|
else
|
|
|
|
return 0;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public DynmapLocation getBedSpawnLocation() {
|
2012-02-13 06:10:18 +01:00
|
|
|
Location loc = offplayer.getBedSpawnLocation();
|
2012-01-15 23:58:19 +01:00
|
|
|
if(loc != null) {
|
|
|
|
return toLoc(loc);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
2012-02-13 06:10:18 +01:00
|
|
|
@Override
|
|
|
|
public long getLastLoginTime() {
|
|
|
|
return offplayer.getLastPlayed();
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public long getFirstLoginTime() {
|
|
|
|
return offplayer.getFirstPlayed();
|
|
|
|
}
|
2013-01-04 04:58:58 +01:00
|
|
|
@Override
|
|
|
|
public boolean isInvisible() {
|
|
|
|
if(player != null) {
|
|
|
|
return player.hasPotionEffect(PotionEffectType.INVISIBILITY);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2013-06-14 08:49:49 +02:00
|
|
|
@Override
|
|
|
|
public int getSortWeight() {
|
|
|
|
Integer wt = sortWeights.get(getName());
|
|
|
|
if (wt != null)
|
|
|
|
return wt;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public void setSortWeight(int wt) {
|
|
|
|
if (wt == 0) {
|
|
|
|
sortWeights.remove(getName());
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
sortWeights.put(getName(), wt);
|
|
|
|
}
|
|
|
|
}
|
2018-02-14 02:11:16 +01:00
|
|
|
@Override
|
|
|
|
public String getSkinURL() {
|
|
|
|
return skinurl;
|
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public UUID getUUID() {
|
|
|
|
return uuid;
|
|
|
|
}
|
2020-05-25 20:55:36 +02:00
|
|
|
/**
|
|
|
|
* Send title and subtitle text (called from server thread)
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public void sendTitleText(String title, String subtitle, int fadeInTicks, int stayTicks, int fadeOutTIcks) {
|
|
|
|
if (player != null) {
|
|
|
|
helper.sendTitleText(player, title, subtitle, fadeInTicks, stayTicks, fadeOutTIcks);
|
|
|
|
}
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
/* Handler for generic console command sender */
|
|
|
|
public class BukkitCommandSender implements DynmapCommandSender {
|
|
|
|
private CommandSender sender;
|
|
|
|
|
|
|
|
public BukkitCommandSender(CommandSender send) {
|
|
|
|
sender = send;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean hasPrivilege(String privid) {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(sender != null)
|
|
|
|
return permissions.has(sender, privid);
|
|
|
|
return false;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void sendMessage(String msg) {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(sender != null)
|
|
|
|
sender.sendMessage(msg);
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isConnected() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(sender != null)
|
|
|
|
return true;
|
|
|
|
return false;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
@Override
|
|
|
|
public boolean isOp() {
|
2012-02-13 06:10:18 +01:00
|
|
|
if(sender != null)
|
|
|
|
return sender.isOp();
|
|
|
|
else
|
|
|
|
return false;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2013-06-14 08:49:49 +02:00
|
|
|
@Override
|
|
|
|
public boolean hasPermissionNode(String node) {
|
|
|
|
if (sender != null) {
|
|
|
|
return sender.hasPermission(node);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
2014-08-23 06:15:57 +02:00
|
|
|
public void loadExtraBiomes(String mcver) {
|
2012-11-10 04:00:37 +01:00
|
|
|
int cnt = 0;
|
|
|
|
|
2014-08-23 06:15:57 +02:00
|
|
|
BiomeMap.loadWellKnownByVersion(mcver);
|
2012-12-10 05:28:21 +01:00
|
|
|
/* Find array of biomes in biomebase */
|
|
|
|
Object[] biomelist = helper.getBiomeBaseList();
|
2020-08-13 04:40:06 +02:00
|
|
|
//Log.info("biomelist length = " + biomelist.length);
|
2014-08-23 06:15:57 +02:00
|
|
|
/* Loop through list, skipping well known biomes */
|
|
|
|
for(int i = 0; i < biomelist.length; i++) {
|
2012-12-10 05:28:21 +01:00
|
|
|
Object bb = biomelist[i];
|
2012-11-10 04:00:37 +01:00
|
|
|
if(bb != null) {
|
2021-12-03 05:18:03 +01:00
|
|
|
String rl = helper.getBiomeBaseResourceLocsation(bb);
|
2012-12-10 05:28:21 +01:00
|
|
|
float tmp = helper.getBiomeBaseTemperature(bb);
|
|
|
|
float hum = helper.getBiomeBaseHumidity(bb);
|
2018-08-21 07:34:04 +02:00
|
|
|
int watermult = helper.getBiomeBaseWaterMult(bb);
|
2021-12-03 05:18:03 +01:00
|
|
|
Log.verboseinfo("biome[" + i + "]: hum=" + hum + ", tmp=" + tmp + ", mult=" + Integer.toHexString(watermult));
|
2019-06-06 02:36:54 +02:00
|
|
|
|
2021-12-05 06:01:13 +01:00
|
|
|
BiomeMap bmap = BiomeMap.NULL;
|
|
|
|
if (rl != null) { // If resource location, lookup by this
|
|
|
|
bmap = BiomeMap.byBiomeResourceLocation(rl);
|
|
|
|
}
|
2021-12-05 08:57:59 +01:00
|
|
|
else {
|
2021-12-05 06:01:13 +01:00
|
|
|
bmap = BiomeMap.byBiomeID(i);
|
|
|
|
}
|
2021-12-05 12:01:59 +01:00
|
|
|
if (bmap.isDefault() || (bmap == BiomeMap.NULL)) {
|
2015-01-04 00:23:40 +01:00
|
|
|
String id = helper.getBiomeBaseIDString(bb);
|
2021-12-05 12:01:59 +01:00
|
|
|
if (id == null) {
|
2015-01-04 00:23:40 +01:00
|
|
|
id = "BIOME_" + i;
|
|
|
|
}
|
2021-12-05 06:01:13 +01:00
|
|
|
bmap = new BiomeMap((rl != null) ? BiomeMap.NO_INDEX : i, id, tmp, hum, rl);
|
2021-12-03 05:18:03 +01:00
|
|
|
Log.verboseinfo("Add custom biome [" + bmap.toString() + "] (" + i + ") rl=" + rl);
|
2021-12-05 12:01:59 +01:00
|
|
|
//Log.info(String.format("rl=%s, bmap=%s", rl, bmap));
|
2015-01-04 00:23:40 +01:00
|
|
|
cnt++;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
bmap.setTemperature(tmp);
|
|
|
|
bmap.setRainfall(hum);
|
|
|
|
}
|
2018-08-21 07:34:04 +02:00
|
|
|
if (watermult != -1) {
|
|
|
|
bmap.setWaterColorMultiplier(watermult);
|
2021-12-03 05:18:03 +01:00
|
|
|
Log.verboseinfo("Set watercolormult for " + bmap.toString() + " (" + i + ") to " + Integer.toHexString(watermult));
|
2018-08-21 07:34:04 +02:00
|
|
|
}
|
2012-11-10 04:00:37 +01:00
|
|
|
}
|
|
|
|
}
|
2012-12-10 05:28:21 +01:00
|
|
|
if(cnt > 0) {
|
|
|
|
Log.info("Added " + cnt + " custom biome mappings");
|
|
|
|
}
|
2012-11-10 04:00:37 +01:00
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
@Override
|
2013-03-30 03:46:06 +01:00
|
|
|
public void onLoad() {
|
|
|
|
Log.setLogger(this.getLogger(), "");
|
2012-02-12 06:02:23 +01:00
|
|
|
|
2018-08-08 08:39:51 +02:00
|
|
|
helper = Helper.getHelper();
|
2013-03-30 03:46:06 +01:00
|
|
|
pm = this.getServer().getPluginManager();
|
2013-12-01 05:51:48 +01:00
|
|
|
|
|
|
|
ModSupportImpl.init();
|
2013-03-30 03:46:06 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onEnable() {
|
2019-06-01 20:03:10 +02:00
|
|
|
if(core != null){
|
2019-06-02 13:27:19 +02:00
|
|
|
if(core.getMarkerAPI() != null){
|
2019-06-01 20:03:10 +02:00
|
|
|
getLogger().info("Starting Scheduled Write Job (markerAPI).");
|
2019-06-02 13:27:19 +02:00
|
|
|
core.restartMarkerSaveJob();
|
2019-06-01 20:03:10 +02:00
|
|
|
}
|
|
|
|
}
|
2013-03-30 03:46:06 +01:00
|
|
|
if (helper == null) {
|
|
|
|
Log.info("Dynmap is disabled (unsupported platform)");
|
|
|
|
return;
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
PluginDescriptionFile pdfFile = this.getDescription();
|
|
|
|
version = pdfFile.getVersion();
|
|
|
|
|
2014-08-23 06:15:57 +02:00
|
|
|
/* Get MC version */
|
|
|
|
String bukkitver = getServer().getVersion();
|
|
|
|
String mcver = "1.0.0";
|
|
|
|
int idx = bukkitver.indexOf("(MC: ");
|
|
|
|
if(idx > 0) {
|
|
|
|
mcver = bukkitver.substring(idx+5);
|
|
|
|
idx = mcver.indexOf(")");
|
|
|
|
if(idx > 0) mcver = mcver.substring(0, idx);
|
|
|
|
}
|
|
|
|
|
2018-08-05 21:38:13 +02:00
|
|
|
// Initialize block states
|
|
|
|
helper.initializeBlockStates();
|
|
|
|
|
2012-11-10 04:00:37 +01:00
|
|
|
/* Load extra biomes, if any */
|
2014-08-23 06:15:57 +02:00
|
|
|
loadExtraBiomes(mcver);
|
2012-01-24 06:11:23 +01:00
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Set up player login/quit event handler */
|
|
|
|
registerPlayerLoginListener();
|
|
|
|
|
2012-03-31 05:07:33 +02:00
|
|
|
/* Build default permissions from our plugin */
|
|
|
|
Map<String, Boolean> perdefs = new HashMap<String, Boolean>();
|
|
|
|
List<Permission> pd = plugin.getDescription().getPermissions();
|
|
|
|
for(Permission p : pd) {
|
|
|
|
perdefs.put(p.getName(), p.getDefault() == PermissionDefault.TRUE);
|
|
|
|
}
|
|
|
|
|
2020-01-27 05:42:05 +01:00
|
|
|
|
2012-03-24 04:02:13 +01:00
|
|
|
permissions = PEXPermissions.create(getServer(), "dynmap");
|
|
|
|
if (permissions == null)
|
2012-03-31 05:07:33 +02:00
|
|
|
permissions = bPermPermissions.create(getServer(), "dynmap", perdefs);
|
2012-03-24 04:02:13 +01:00
|
|
|
if (permissions == null)
|
2012-03-31 07:23:22 +02:00
|
|
|
permissions = PermBukkitPermissions.create(getServer(), "dynmap", perdefs);
|
2012-03-24 04:02:13 +01:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = NijikokunPermissions.create(getServer(), "dynmap");
|
2013-07-18 15:44:33 +02:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = GroupManagerPermissions.create(getServer(), "dynmap");
|
2019-03-20 06:54:52 +01:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = LuckPermsPermissions.create(getServer(), "dynmap");
|
2019-12-15 19:53:50 +01:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = LuckPerms5Permissions.create(getServer(), "dynmap");
|
2020-01-27 05:42:05 +01:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = VaultPermissions.create(this, "dynmap");
|
2012-01-15 23:58:19 +01:00
|
|
|
if (permissions == null)
|
2012-03-31 07:23:22 +02:00
|
|
|
permissions = BukkitPermissions.create("dynmap", perdefs);
|
2012-01-15 23:58:19 +01:00
|
|
|
if (permissions == null)
|
|
|
|
permissions = new OpPermissions(new String[] { "fullrender", "cancelrender", "radiusrender", "resetstats", "reload", "purgequeue", "pause", "ips-for-id", "ids-for-ip", "add-id-for-ip", "del-id-for-ip" });
|
|
|
|
/* Get and initialize data folder */
|
|
|
|
File dataDirectory = this.getDataFolder();
|
|
|
|
if(dataDirectory.exists() == false)
|
|
|
|
dataDirectory.mkdirs();
|
2014-08-23 06:15:57 +02:00
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Instantiate core */
|
|
|
|
if(core == null)
|
|
|
|
core = new DynmapCore();
|
|
|
|
/* Inject dependencies */
|
2013-05-09 07:55:07 +02:00
|
|
|
core.setPluginJarFile(this.getFile());
|
2013-01-29 18:49:22 +01:00
|
|
|
core.setPluginVersion(version, "CraftBukkit");
|
2012-01-15 23:58:19 +01:00
|
|
|
core.setMinecraftVersion(mcver);
|
|
|
|
core.setDataFolder(dataDirectory);
|
|
|
|
core.setServer(new BukkitServer());
|
2013-04-18 08:20:59 +02:00
|
|
|
core.setBiomeNames(helper.getBiomeNames());
|
2012-01-15 23:58:19 +01:00
|
|
|
|
2012-10-05 07:10:32 +02:00
|
|
|
/* Load configuration */
|
|
|
|
if(!core.initConfiguration(enabCoreCB)) {
|
|
|
|
this.setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2020-04-23 03:39:54 +02:00
|
|
|
|
|
|
|
/* Skins support via SkinsRestorer */
|
|
|
|
SkinsRestorerSkinUrlProvider skinUrlProvider = null;
|
|
|
|
|
2020-04-28 12:10:25 +02:00
|
|
|
if (core.configuration.getBoolean("skinsrestorer-integration", false)) {
|
2021-03-04 20:49:47 +01:00
|
|
|
try {
|
|
|
|
SkinsRestorer skinsRestorer = (SkinsRestorer) getServer().getPluginManager().getPlugin("SkinsRestorer");
|
2020-04-28 12:10:25 +02:00
|
|
|
|
2021-03-04 20:49:47 +01:00
|
|
|
if (skinsRestorer == null) {
|
|
|
|
Log.warning("SkinsRestorer integration can't be enabled because SkinsRestorer not installed");
|
|
|
|
} else {
|
2021-06-20 18:22:07 +02:00
|
|
|
skinUrlProvider = new SkinsRestorerSkinUrlProvider();
|
2021-03-04 20:49:47 +01:00
|
|
|
Log.info("SkinsRestorer API v14 integration enabled");
|
|
|
|
}
|
2021-06-20 18:22:07 +02:00
|
|
|
} catch(NoClassDefFoundError e) {
|
2021-03-04 20:49:47 +01:00
|
|
|
Log.warning("You are using unsupported version of SkinsRestorer. Use v14 or newer.");
|
|
|
|
Log.warning("Disabled SkinsRestorer integration for this session");
|
2020-04-28 12:10:25 +02:00
|
|
|
}
|
|
|
|
}
|
2020-04-23 03:39:54 +02:00
|
|
|
|
|
|
|
core.setSkinUrlProvider(skinUrlProvider);
|
|
|
|
|
2012-10-05 07:10:32 +02:00
|
|
|
/* See if we need to wait before enabling core */
|
|
|
|
if(!readyToEnable()) {
|
|
|
|
Listener pl = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-10-05 07:10:32 +02:00
|
|
|
public void onPluginEnabled(PluginEnableEvent evt) {
|
|
|
|
if (!readyToEnable()) {
|
|
|
|
if (readyToEnable()) { /* If we;re ready now, finish enable */
|
|
|
|
doEnable(); /* Finish enable */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(pl, this);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
doEnable();
|
|
|
|
}
|
2013-06-20 06:20:38 +02:00
|
|
|
// Start tps calculation
|
|
|
|
lasttick = System.nanoTime();
|
|
|
|
tps = 20.0;
|
|
|
|
perTickLimit = core.getMaxTickUseMS() * 1000000;
|
|
|
|
|
|
|
|
getServer().getScheduler().scheduleSyncRepeatingTask(this, new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
processTick();
|
|
|
|
}
|
|
|
|
}, 1, 1);
|
2012-10-05 07:10:32 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
private boolean readyToEnable() {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
private void doEnable() {
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Enable core */
|
2012-10-05 07:10:32 +02:00
|
|
|
if(!core.enableCore(enabCoreCB)) {
|
2012-01-15 23:58:19 +01:00
|
|
|
this.setEnabled(false);
|
|
|
|
return;
|
|
|
|
}
|
2012-01-22 17:48:43 +01:00
|
|
|
playerList = core.playerList;
|
2021-12-05 08:57:59 +01:00
|
|
|
if (helper.useGenericCache()) {
|
|
|
|
BukkitVersionHelper.gencache = new GenericChunkCache(core.getSnapShotCacheSize(), core.useSoftRefInSnapShotCache());
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
SnapshotCache.sscache = new SnapshotCache(core.getSnapShotCacheSize(), core.useSoftRefInSnapShotCache());
|
|
|
|
}
|
2012-01-18 06:58:11 +01:00
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Get map manager from core */
|
|
|
|
mapManager = core.getMapManager();
|
|
|
|
/* Initialized the currently loaded worlds */
|
|
|
|
for (World world : getServer().getWorlds()) {
|
2012-10-18 02:42:37 +02:00
|
|
|
BukkitWorld w = getWorld(world);
|
2012-01-15 23:58:19 +01:00
|
|
|
if(core.processWorldLoad(w)) /* Have core process load first - fire event listeners if good load after */
|
|
|
|
core.listenerManager.processWorldEvent(EventType.WORLD_LOAD, w);
|
2013-03-21 05:59:50 +01:00
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Register our update trigger events */
|
|
|
|
registerEvents();
|
2012-02-04 06:02:27 +01:00
|
|
|
|
2012-08-24 07:07:06 +02:00
|
|
|
/* Submit metrics to mcstats.org */
|
2012-08-25 05:37:48 +02:00
|
|
|
initMetrics();
|
2012-08-24 07:07:06 +02:00
|
|
|
|
2013-03-21 05:59:50 +01:00
|
|
|
/* Core is ready - notify API availability */
|
|
|
|
DynmapCommonAPIListener.apiInitialized(this);
|
|
|
|
|
2012-02-04 06:02:27 +01:00
|
|
|
Log.info("Enabled");
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onDisable() {
|
2013-03-21 05:59:50 +01:00
|
|
|
/* Core is being disabled - notify API disable */
|
|
|
|
DynmapCommonAPIListener.apiTerminated();
|
|
|
|
|
2012-08-24 07:07:06 +02:00
|
|
|
if (metrics != null) {
|
|
|
|
metrics = null;
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Disable core */
|
|
|
|
core.disableCore();
|
2012-01-18 06:58:11 +01:00
|
|
|
|
2018-08-08 08:39:51 +02:00
|
|
|
if(SnapshotCache.sscache != null) {
|
|
|
|
SnapshotCache.sscache.cleanup();
|
|
|
|
SnapshotCache.sscache = null;
|
2012-01-18 06:58:11 +01:00
|
|
|
}
|
2021-12-05 08:57:59 +01:00
|
|
|
if (BukkitVersionHelper.gencache != null) {
|
|
|
|
BukkitVersionHelper.gencache.cleanup();
|
|
|
|
BukkitVersionHelper.gencache = null;
|
|
|
|
}
|
2012-02-04 06:02:27 +01:00
|
|
|
Log.info("Disabled");
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2013-06-20 06:20:38 +02:00
|
|
|
|
|
|
|
private void processTick() {
|
|
|
|
long now = System.nanoTime();
|
|
|
|
long elapsed = now - lasttick;
|
|
|
|
lasttick = now;
|
|
|
|
avgticklen = ((avgticklen * 99) / 100) + (elapsed / 100);
|
|
|
|
tps = (double)1E9 / (double)avgticklen;
|
|
|
|
if (mapManager != null) {
|
|
|
|
chunks_in_cur_tick = mapManager.getMaxChunkLoadsPerTick();
|
|
|
|
}
|
|
|
|
cur_tick++;
|
|
|
|
|
|
|
|
// Tick core
|
|
|
|
if (core != null) {
|
|
|
|
core.serverTick(tps);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
@Override
|
|
|
|
public boolean onCommand(CommandSender sender, Command cmd, String commandLabel, String[] args) {
|
|
|
|
DynmapCommandSender dsender;
|
|
|
|
if(sender instanceof Player) {
|
|
|
|
dsender = new BukkitPlayer((Player)sender);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
dsender = new BukkitCommandSender(sender);
|
|
|
|
}
|
2019-05-26 07:07:01 +02:00
|
|
|
if (core != null)
|
|
|
|
return core.processCommand(dsender, cmd.getName(), commandLabel, args);
|
|
|
|
else
|
|
|
|
return false;
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final MarkerAPI getMarkerAPI() {
|
|
|
|
return core.getMarkerAPI();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean markerAPIInitialized() {
|
|
|
|
return core.markerAPIInitialized();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean sendBroadcastToWeb(String sender, String msg) {
|
|
|
|
return core.sendBroadcastToWeb(sender, msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final int triggerRenderOfVolume(String wid, int minx, int miny, int minz,
|
|
|
|
int maxx, int maxy, int maxz) {
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wid, minx, miny, minz, maxx, maxy, maxz);
|
2012-01-15 23:58:19 +01:00
|
|
|
return core.triggerRenderOfVolume(wid, minx, miny, minz, maxx, maxy, maxz);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final int triggerRenderOfBlock(String wid, int x, int y, int z) {
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wid, x, y, z);
|
2012-01-15 23:58:19 +01:00
|
|
|
return core.triggerRenderOfBlock(wid, x, y, z);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void setPauseFullRadiusRenders(boolean dopause) {
|
|
|
|
core.setPauseFullRadiusRenders(dopause);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean getPauseFullRadiusRenders() {
|
|
|
|
return core.getPauseFullRadiusRenders();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void setPauseUpdateRenders(boolean dopause) {
|
|
|
|
core.setPauseUpdateRenders(dopause);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean getPauseUpdateRenders() {
|
|
|
|
return core.getPauseUpdateRenders();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void setPlayerVisiblity(String player, boolean is_visible) {
|
|
|
|
core.setPlayerVisiblity(player, is_visible);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean getPlayerVisbility(String player) {
|
|
|
|
return core.getPlayerVisbility(player);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void postPlayerMessageToWeb(String playerid, String playerdisplay,
|
|
|
|
String message) {
|
|
|
|
core.postPlayerMessageToWeb(playerid, playerdisplay, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void postPlayerJoinQuitToWeb(String playerid, String playerdisplay,
|
|
|
|
boolean isjoin) {
|
|
|
|
core.postPlayerJoinQuitToWeb(playerid, playerdisplay, isjoin);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final String getDynmapCoreVersion() {
|
|
|
|
return core.getDynmapCoreVersion();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final int triggerRenderOfVolume(Location l0, Location l1) {
|
|
|
|
int x0 = l0.getBlockX(), y0 = l0.getBlockY(), z0 = l0.getBlockZ();
|
|
|
|
int x1 = l1.getBlockX(), y1 = l1.getBlockY(), z1 = l1.getBlockZ();
|
|
|
|
|
2012-10-18 02:42:37 +02:00
|
|
|
return core.triggerRenderOfVolume(getWorld(l0.getWorld()).getName(), Math.min(x0, x1), Math.min(y0, y1),
|
2012-01-15 23:58:19 +01:00
|
|
|
Math.min(z0, z1), Math.max(x0, x1), Math.max(y0, y1), Math.max(z0, z1));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void setPlayerVisiblity(Player player, boolean is_visible) {
|
|
|
|
core.setPlayerVisiblity(player.getName(), is_visible);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final boolean getPlayerVisbility(Player player) {
|
|
|
|
return core.getPlayerVisbility(player.getName());
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public final void postPlayerMessageToWeb(Player player, String message) {
|
|
|
|
core.postPlayerMessageToWeb(player.getName(), player.getDisplayName(), message);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void postPlayerJoinQuitToWeb(Player player, boolean isjoin) {
|
|
|
|
core.postPlayerJoinQuitToWeb(player.getName(), player.getDisplayName(), isjoin);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getDynmapVersion() {
|
|
|
|
return version;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static DynmapLocation toLoc(Location l) {
|
2012-03-10 22:07:13 +01:00
|
|
|
return new DynmapLocation(DynmapWorld.normalizeWorldName(l.getWorld().getName()), l.getBlockX(), l.getBlockY(), l.getBlockZ());
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
private void registerPlayerLoginListener() {
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener pl = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onPlayerJoin(PlayerJoinEvent evt) {
|
2013-07-05 17:57:19 +02:00
|
|
|
final DynmapPlayer dp = new BukkitPlayer(evt.getPlayer());
|
|
|
|
// Give other handlers a change to prep player (nicknames and such from Essentials)
|
|
|
|
getServer().getScheduler().scheduleSyncDelayedTask(DynmapPlugin.this, new Runnable() {
|
|
|
|
@Override
|
|
|
|
public void run() {
|
|
|
|
core.listenerManager.processPlayerEvent(EventType.PLAYER_JOIN, dp);
|
|
|
|
}
|
|
|
|
}, 2);
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onPlayerQuit(PlayerQuitEvent evt) {
|
|
|
|
DynmapPlayer dp = new BukkitPlayer(evt.getPlayer());
|
|
|
|
core.listenerManager.processPlayerEvent(EventType.PLAYER_QUIT, dp);
|
|
|
|
}
|
|
|
|
};
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(pl, this);
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
|
2012-02-23 04:00:13 +01:00
|
|
|
private class BlockCheckHandler implements Runnable {
|
|
|
|
public void run() {
|
|
|
|
BlockToCheck btt;
|
|
|
|
while(blocks_to_check.isEmpty() != true) {
|
|
|
|
btt = blocks_to_check.pop();
|
|
|
|
Location loc = btt.loc;
|
|
|
|
World w = loc.getWorld();
|
|
|
|
if(!w.isChunkLoaded(loc.getBlockX()>>4, loc.getBlockZ()>>4))
|
|
|
|
continue;
|
2021-07-18 03:19:56 +02:00
|
|
|
int bt = getBlockIdFromBlock(w.getBlockAt(loc));
|
2012-02-23 04:00:13 +01:00
|
|
|
/* Avoid stationary and moving water churn */
|
|
|
|
if(bt == 9) bt = 8;
|
|
|
|
if(btt.typeid == 9) btt.typeid = 8;
|
|
|
|
if((bt != btt.typeid) || (btt.data != w.getBlockAt(loc).getData())) {
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(w).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), btt.trigger);
|
2012-02-23 04:00:13 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
blocks_to_check = null;
|
|
|
|
/* Kick next run, if one is needed */
|
|
|
|
startIfNeeded();
|
|
|
|
}
|
|
|
|
public void startIfNeeded() {
|
|
|
|
if((blocks_to_check == null) && (blocks_to_check_accum.isEmpty() == false)) { /* More pending? */
|
|
|
|
blocks_to_check = blocks_to_check_accum;
|
|
|
|
blocks_to_check_accum = new LinkedList<BlockToCheck>();
|
|
|
|
getServer().getScheduler().scheduleSyncDelayedTask(DynmapPlugin.this, this, 10);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
private BlockCheckHandler btth = new BlockCheckHandler();
|
2012-02-22 15:07:13 +01:00
|
|
|
|
|
|
|
private void checkBlock(Block b, String trigger) {
|
|
|
|
BlockToCheck btt = new BlockToCheck();
|
|
|
|
btt.loc = b.getLocation();
|
2021-07-18 03:19:56 +02:00
|
|
|
btt.typeid = getBlockIdFromBlock(b);
|
2012-02-23 04:00:13 +01:00
|
|
|
btt.data = b.getData();
|
2012-02-22 15:07:13 +01:00
|
|
|
btt.trigger = trigger;
|
2012-02-23 04:00:13 +01:00
|
|
|
blocks_to_check_accum.add(btt); /* Add to accumulator */
|
|
|
|
btth.startIfNeeded();
|
2012-02-22 15:07:13 +01:00
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
private boolean onplace;
|
|
|
|
private boolean onbreak;
|
|
|
|
private boolean onblockform;
|
|
|
|
private boolean onblockfade;
|
|
|
|
private boolean onblockspread;
|
|
|
|
private boolean onblockfromto;
|
|
|
|
private boolean onblockphysics;
|
|
|
|
private boolean onleaves;
|
|
|
|
private boolean onburn;
|
|
|
|
private boolean onpiston;
|
|
|
|
private boolean onplayerjoin;
|
|
|
|
private boolean onplayermove;
|
|
|
|
private boolean ongeneratechunk;
|
|
|
|
private boolean onexplosion;
|
2012-02-14 03:06:37 +01:00
|
|
|
private boolean onstructuregrow;
|
2012-02-29 06:40:52 +01:00
|
|
|
private boolean onblockgrow;
|
2012-07-11 09:09:51 +02:00
|
|
|
private boolean onblockredstone;
|
2012-01-15 23:58:19 +01:00
|
|
|
|
2021-12-05 08:57:59 +01:00
|
|
|
private void invalidateSnapshot(String wn, int x, int y, int z) {
|
|
|
|
if (helper.useGenericCache()) {
|
|
|
|
BukkitVersionHelper.gencache.invalidateSnapshot(wn, x, y, z);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
SnapshotCache.sscache.invalidateSnapshot(wn, x, y, z);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
private void invalidateSnapshot(String wname, int minx, int miny, int minz, int maxx, int maxy, int maxz) {
|
|
|
|
if (helper.useGenericCache()) {
|
|
|
|
BukkitVersionHelper.gencache.invalidateSnapshot(wname, minx, miny, minz, maxx, maxy, maxz);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
SnapshotCache.sscache.invalidateSnapshot(wname, minx, miny, minz, maxx, maxy, maxz);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
private void registerEvents() {
|
2012-03-04 06:20:04 +01:00
|
|
|
|
|
|
|
// To trigger rendering.
|
|
|
|
onplace = core.isTrigger("blockplaced");
|
|
|
|
onbreak = core.isTrigger("blockbreak");
|
|
|
|
onleaves = core.isTrigger("leavesdecay");
|
|
|
|
onburn = core.isTrigger("blockburn");
|
|
|
|
onblockform = core.isTrigger("blockformed");
|
|
|
|
onblockfade = core.isTrigger("blockfaded");
|
|
|
|
onblockspread = core.isTrigger("blockspread");
|
|
|
|
onblockfromto = core.isTrigger("blockfromto");
|
|
|
|
onblockphysics = core.isTrigger("blockphysics");
|
|
|
|
onpiston = core.isTrigger("pistonmoved");
|
2012-07-11 09:09:51 +02:00
|
|
|
onblockredstone = core.isTrigger("blockredstone");
|
2012-03-04 06:20:04 +01:00
|
|
|
|
|
|
|
if(onplace) {
|
|
|
|
Listener placelistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockPlace(BlockPlaceEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-01-15 23:58:19 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockplace");
|
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(placelistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onbreak) {
|
|
|
|
Listener breaklistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockBreak(BlockBreakEvent event) {
|
2012-05-23 06:53:29 +02:00
|
|
|
Block b = event.getBlock();
|
|
|
|
if(b == null) return; /* Stupid mod workaround */
|
|
|
|
Location loc = b.getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-01-15 23:58:19 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockbreak");
|
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(breaklistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onleaves) {
|
|
|
|
Listener leaveslistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onLeavesDecay(LeavesDecayEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
if(onleaves) {
|
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "leavesdecay");
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(leaveslistener, this);
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
|
2012-03-04 06:20:04 +01:00
|
|
|
if(onburn) {
|
|
|
|
Listener burnlistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockBurn(BlockBurnEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
if(onburn) {
|
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockburn");
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(burnlistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onblockphysics) {
|
|
|
|
Listener physlistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockPhysics(BlockPhysicsEvent event) {
|
|
|
|
Block b = event.getBlock();
|
|
|
|
Material m = b.getType();
|
2012-04-10 01:03:32 +02:00
|
|
|
if(m == null) return;
|
2012-03-04 06:20:04 +01:00
|
|
|
switch(m) {
|
|
|
|
case STATIONARY_WATER:
|
|
|
|
case WATER:
|
|
|
|
case STATIONARY_LAVA:
|
|
|
|
case LAVA:
|
|
|
|
case GRAVEL:
|
|
|
|
case SAND:
|
2012-04-10 01:03:32 +02:00
|
|
|
checkBlock(b, "blockphysics");
|
2012-03-04 06:20:04 +01:00
|
|
|
break;
|
2012-07-21 07:35:41 +02:00
|
|
|
default:
|
|
|
|
break;
|
2012-03-04 06:20:04 +01:00
|
|
|
}
|
2012-02-23 04:00:13 +01:00
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(physlistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onblockfromto) {
|
|
|
|
Listener fromtolistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockFromTo(BlockFromToEvent event) {
|
2012-04-10 01:03:32 +02:00
|
|
|
Block b = event.getBlock();
|
|
|
|
Material m = b.getType();
|
2021-07-11 18:54:03 +02:00
|
|
|
String m_id = (m != null) ? m.toString() : "";
|
|
|
|
boolean not_pressure_plate = (m_id != "WOOD_PLATE") && (m_id != "STONE_PLATE") && (!m_id.contains("PRESSURE_PLATE")) && (m_id != "");
|
|
|
|
if (not_pressure_plate)
|
2012-04-10 01:03:32 +02:00
|
|
|
checkBlock(b, "blockfromto");
|
|
|
|
b = event.getToBlock();
|
|
|
|
m = b.getType();
|
2021-07-11 18:54:03 +02:00
|
|
|
if (not_pressure_plate)
|
2012-04-10 01:03:32 +02:00
|
|
|
checkBlock(b, "blockfromto");
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(fromtolistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onpiston) {
|
|
|
|
Listener pistonlistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockPistonRetract(BlockPistonRetractEvent event) {
|
|
|
|
Block b = event.getBlock();
|
|
|
|
Location loc = b.getLocation();
|
|
|
|
BlockFace dir;
|
|
|
|
try { /* Workaround Bukkit bug = http://leaky.bukkit.org/issues/1227 */
|
|
|
|
dir = event.getDirection();
|
|
|
|
} catch (ClassCastException ccx) {
|
|
|
|
dir = BlockFace.NORTH;
|
|
|
|
}
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2012-03-04 06:20:04 +01:00
|
|
|
int x = loc.getBlockX(), y = loc.getBlockY(), z = loc.getBlockZ();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, x, y, z);
|
2012-01-15 23:58:19 +01:00
|
|
|
if(onpiston)
|
|
|
|
mapManager.touch(wn, x, y, z, "pistonretract");
|
2012-03-04 06:20:04 +01:00
|
|
|
for(int i = 0; i < 2; i++) {
|
|
|
|
x += dir.getModX();
|
|
|
|
y += dir.getModY();
|
|
|
|
z += dir.getModZ();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, x, y, z);
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, x, y, z, "pistonretract");
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockPistonExtend(BlockPistonExtendEvent event) {
|
|
|
|
Block b = event.getBlock();
|
|
|
|
Location loc = b.getLocation();
|
|
|
|
BlockFace dir;
|
|
|
|
try { /* Workaround Bukkit bug = http://leaky.bukkit.org/issues/1227 */
|
|
|
|
dir = event.getDirection();
|
|
|
|
} catch (ClassCastException ccx) {
|
|
|
|
dir = BlockFace.NORTH;
|
|
|
|
}
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2012-03-04 06:20:04 +01:00
|
|
|
int x = loc.getBlockX(), y = loc.getBlockY(), z = loc.getBlockZ();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, x, y, z);
|
2012-01-15 23:58:19 +01:00
|
|
|
if(onpiston)
|
|
|
|
mapManager.touch(wn, x, y, z, "pistonretract");
|
2012-03-04 06:20:04 +01:00
|
|
|
for(int i = 0; i < 1+event.getLength(); i++) {
|
|
|
|
x += dir.getModX();
|
|
|
|
y += dir.getModY();
|
|
|
|
z += dir.getModZ();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, x, y, z);
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, x, y, z, "pistonretract");
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2012-03-04 06:20:04 +01:00
|
|
|
};
|
|
|
|
pm.registerEvents(pistonlistener, this);
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
|
2012-03-04 06:20:04 +01:00
|
|
|
if(onblockspread) {
|
|
|
|
Listener spreadlistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockSpread(BlockSpreadEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockspread");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(spreadlistener, this);
|
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
|
2012-03-04 06:20:04 +01:00
|
|
|
if(onblockform) {
|
|
|
|
Listener formlistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockForm(BlockFormEvent event) {
|
2012-02-29 06:40:52 +01:00
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockform");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(formlistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(onblockfade) {
|
|
|
|
Listener fadelistener = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-03-04 06:20:04 +01:00
|
|
|
public void onBlockFade(BlockFadeEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-03-04 06:20:04 +01:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockfade");
|
2012-02-29 06:40:52 +01:00
|
|
|
}
|
|
|
|
};
|
2012-03-04 06:20:04 +01:00
|
|
|
pm.registerEvents(fadelistener, this);
|
|
|
|
}
|
|
|
|
|
|
|
|
onblockgrow = core.isTrigger("blockgrow");
|
|
|
|
|
|
|
|
if(onblockgrow) {
|
2013-07-05 17:57:19 +02:00
|
|
|
Listener growTrigger = new Listener() {
|
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
|
|
|
public void onBlockGrow(BlockGrowEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2013-07-05 17:57:19 +02:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockgrow");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(growTrigger, this);
|
2012-02-29 06:40:52 +01:00
|
|
|
}
|
|
|
|
|
2012-07-11 09:09:51 +02:00
|
|
|
if(onblockredstone) {
|
|
|
|
Listener redstoneTrigger = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-07-11 09:09:51 +02:00
|
|
|
public void onBlockRedstone(BlockRedstoneEvent event) {
|
|
|
|
Location loc = event.getBlock().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wn = getWorld(loc.getWorld()).getName();
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ());
|
2012-07-11 09:09:51 +02:00
|
|
|
mapManager.touch(wn, loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "blockredstone");
|
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(redstoneTrigger, this);
|
|
|
|
}
|
|
|
|
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Register player event trigger handlers */
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener playerTrigger = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
|
|
|
if(onplayerjoin) {
|
|
|
|
Location loc = event.getPlayer().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
mapManager.touch(getWorld(loc.getWorld()).getName(), loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "playerjoin");
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
onplayerjoin = core.isTrigger("playerjoin");
|
|
|
|
onplayermove = core.isTrigger("playermove");
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(playerTrigger, this);
|
|
|
|
|
2012-02-07 17:21:56 +01:00
|
|
|
if(onplayermove) {
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener playermove = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-02-12 06:02:23 +01:00
|
|
|
public void onPlayerMove(PlayerMoveEvent event) {
|
|
|
|
Location loc = event.getPlayer().getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
mapManager.touch(getWorld(loc.getWorld()).getName(), loc.getBlockX(), loc.getBlockY(), loc.getBlockZ(), "playermove");
|
2012-02-12 06:02:23 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(playermove, this);
|
2012-02-07 17:21:56 +01:00
|
|
|
Log.warning("playermove trigger enabled - this trigger can cause excessive tile updating: use with caution");
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
/* Register entity event triggers */
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener entityTrigger = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onEntityExplode(EntityExplodeEvent event) {
|
|
|
|
Location loc = event.getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wname = getWorld(loc.getWorld()).getName();
|
2012-01-15 23:58:19 +01:00
|
|
|
int minx, maxx, miny, maxy, minz, maxz;
|
|
|
|
minx = maxx = loc.getBlockX();
|
|
|
|
miny = maxy = loc.getBlockY();
|
|
|
|
minz = maxz = loc.getBlockZ();
|
|
|
|
/* Calculate volume impacted by explosion */
|
|
|
|
List<Block> blocks = event.blockList();
|
|
|
|
for(Block b: blocks) {
|
|
|
|
Location l = b.getLocation();
|
|
|
|
int x = l.getBlockX();
|
|
|
|
if(x < minx) minx = x;
|
|
|
|
if(x > maxx) maxx = x;
|
|
|
|
int y = l.getBlockY();
|
|
|
|
if(y < miny) miny = y;
|
|
|
|
if(y > maxy) maxy = y;
|
|
|
|
int z = l.getBlockZ();
|
|
|
|
if(z < minz) minz = z;
|
|
|
|
if(z > maxz) maxz = z;
|
|
|
|
}
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wname, minx, miny, minz, maxx, maxy, maxz);
|
2012-01-15 23:58:19 +01:00
|
|
|
if(onexplosion) {
|
|
|
|
mapManager.touchVolume(wname, minx, miny, minz, maxx, maxy, maxz, "entityexplode");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
onexplosion = core.isTrigger("explosion");
|
2012-02-12 06:02:23 +01:00
|
|
|
pm.registerEvents(entityTrigger, this);
|
2012-01-15 23:58:19 +01:00
|
|
|
|
|
|
|
/* Register world event triggers */
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener worldTrigger = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onWorldLoad(WorldLoadEvent event) {
|
2012-10-18 02:42:37 +02:00
|
|
|
BukkitWorld w = getWorld(event.getWorld());
|
2012-01-15 23:58:19 +01:00
|
|
|
if(core.processWorldLoad(w)) /* Have core process load first - fire event listeners if good load after */
|
|
|
|
core.listenerManager.processWorldEvent(EventType.WORLD_LOAD, w);
|
|
|
|
}
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-01-15 23:58:19 +01:00
|
|
|
public void onWorldUnload(WorldUnloadEvent event) {
|
2012-11-11 06:47:40 +01:00
|
|
|
BukkitWorld w = getWorld(event.getWorld());
|
|
|
|
if(w != null) {
|
|
|
|
core.listenerManager.processWorldEvent(EventType.WORLD_UNLOAD, w);
|
|
|
|
w.setWorldUnloaded();
|
|
|
|
core.processWorldUnload(w);
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-02-14 03:06:37 +01:00
|
|
|
public void onStructureGrow(StructureGrowEvent event) {
|
|
|
|
Location loc = event.getLocation();
|
2012-10-18 02:42:37 +02:00
|
|
|
String wname = getWorld(loc.getWorld()).getName();
|
2012-02-14 03:06:37 +01:00
|
|
|
int minx, maxx, miny, maxy, minz, maxz;
|
|
|
|
minx = maxx = loc.getBlockX();
|
|
|
|
miny = maxy = loc.getBlockY();
|
|
|
|
minz = maxz = loc.getBlockZ();
|
|
|
|
/* Calculate volume impacted by explosion */
|
|
|
|
List<BlockState> blocks = event.getBlocks();
|
|
|
|
for(BlockState b: blocks) {
|
|
|
|
int x = b.getX();
|
|
|
|
if(x < minx) minx = x;
|
|
|
|
if(x > maxx) maxx = x;
|
|
|
|
int y = b.getY();
|
|
|
|
if(y < miny) miny = y;
|
|
|
|
if(y > maxy) maxy = y;
|
|
|
|
int z = b.getZ();
|
|
|
|
if(z < minz) minz = z;
|
|
|
|
if(z > maxz) maxz = z;
|
|
|
|
}
|
2021-12-05 08:57:59 +01:00
|
|
|
invalidateSnapshot(wname, minx, miny, minz, maxx, maxy, maxz);
|
2012-02-14 03:06:37 +01:00
|
|
|
if(onstructuregrow) {
|
|
|
|
mapManager.touchVolume(wname, minx, miny, minz, maxx, maxy, maxz, "structuregrow");
|
|
|
|
}
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
};
|
2012-02-14 03:06:37 +01:00
|
|
|
onstructuregrow = core.isTrigger("structuregrow");
|
2012-02-12 06:02:23 +01:00
|
|
|
// To link configuration to real loaded worlds.
|
|
|
|
pm.registerEvents(worldTrigger, this);
|
2012-01-15 23:58:19 +01:00
|
|
|
|
|
|
|
ongeneratechunk = core.isTrigger("chunkgenerated");
|
|
|
|
if(ongeneratechunk) {
|
2012-02-12 06:02:23 +01:00
|
|
|
Listener chunkTrigger = new Listener() {
|
2013-07-05 17:57:19 +02:00
|
|
|
@EventHandler(priority=EventPriority.MONITOR, ignoreCancelled=true)
|
2012-02-12 06:02:23 +01:00
|
|
|
public void onChunkPopulate(ChunkPopulateEvent event) {
|
|
|
|
Chunk c = event.getChunk();
|
2013-01-08 07:10:53 +01:00
|
|
|
ChunkSnapshot cs = c.getChunkSnapshot();
|
|
|
|
int ymax = 0;
|
|
|
|
for(int i = 0; i < c.getWorld().getMaxHeight() / 16; i++) {
|
|
|
|
if(!cs.isSectionEmpty(i)) {
|
|
|
|
ymax = (i+1)*16;
|
|
|
|
}
|
|
|
|
}
|
2012-02-12 06:02:23 +01:00
|
|
|
/* Touch extreme corners */
|
|
|
|
int x = c.getX() << 4;
|
|
|
|
int z = c.getZ() << 4;
|
2013-01-08 07:10:53 +01:00
|
|
|
mapManager.touchVolume(getWorld(event.getWorld()).getName(), x, 0, z, x+15, ymax, z+16, "chunkpopulate");
|
2012-02-12 06:02:23 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
pm.registerEvents(chunkTrigger, this);
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-02-08 08:05:53 +01:00
|
|
|
@Override
|
|
|
|
public void assertPlayerInvisibility(String player, boolean is_invisible,
|
|
|
|
String plugin_id) {
|
|
|
|
core.assertPlayerInvisibility(player, is_invisible, plugin_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void assertPlayerInvisibility(Player player, boolean is_invisible,
|
|
|
|
Plugin plugin) {
|
|
|
|
core.assertPlayerInvisibility(player.getName(), is_invisible, plugin.getDescription().getName());
|
|
|
|
}
|
2012-02-13 06:59:29 +01:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void assertPlayerVisibility(String player, boolean is_visible,
|
|
|
|
String plugin_id) {
|
|
|
|
core.assertPlayerVisibility(player, is_visible, plugin_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void assertPlayerVisibility(Player player, boolean is_visible,
|
|
|
|
Plugin plugin) {
|
|
|
|
core.assertPlayerVisibility(player.getName(), is_visible, plugin.getDescription().getName());
|
|
|
|
}
|
2012-02-23 06:10:13 +01:00
|
|
|
@Override
|
|
|
|
public boolean setDisableChatToWebProcessing(boolean disable) {
|
|
|
|
return core.setDisableChatToWebProcessing(disable);
|
|
|
|
}
|
2012-07-29 05:56:12 +02:00
|
|
|
@Override
|
|
|
|
public boolean testIfPlayerVisibleToPlayer(String player, String player_to_see) {
|
|
|
|
return core.testIfPlayerVisibleToPlayer(player, player_to_see);
|
|
|
|
}
|
2012-07-29 18:01:59 +02:00
|
|
|
@Override
|
|
|
|
public boolean testIfPlayerInfoProtected() {
|
|
|
|
return core.testIfPlayerInfoProtected();
|
|
|
|
}
|
2017-04-17 23:16:18 +02:00
|
|
|
|
2021-11-13 00:44:33 +01:00
|
|
|
private class FeatureChart extends CustomChart {
|
|
|
|
public FeatureChart() { super("features_used"); }
|
2017-04-17 23:16:18 +02:00
|
|
|
|
2021-11-13 00:44:33 +01:00
|
|
|
@Override
|
|
|
|
protected JsonObject getChartData() throws Exception {
|
|
|
|
JsonObjectBuilder obj = new JsonObjectBuilder();
|
|
|
|
obj = obj.appendField("internal_web_server", core.configuration.getBoolean("disable-webserver", false) ? 0 : 1);
|
|
|
|
obj = obj.appendField("login_security", core.configuration.getBoolean("login-enabled", false) ? 1 : 0);
|
|
|
|
obj = obj.appendField("player_info_protected", core.player_info_protected ? 1 : 0);
|
|
|
|
for (String mod : modsused)
|
|
|
|
obj = obj.appendField(mod + "_blocks", 1);
|
|
|
|
return obj.build();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
private class MapChart extends CustomChart {
|
|
|
|
public MapChart() { super("map_data"); }
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected JsonObject getChartData() throws Exception {
|
|
|
|
JsonObjectBuilder obj = new JsonObjectBuilder();
|
|
|
|
|
|
|
|
obj = obj.appendField("worlds", core.mapManager != null ? core.mapManager.getWorlds().size() : 0);
|
2019-12-01 03:38:05 +01:00
|
|
|
int maps = 0, hdmaps = 0;
|
2021-11-13 00:44:33 +01:00
|
|
|
if (core.mapManager != null) {
|
2019-12-01 03:38:05 +01:00
|
|
|
for (DynmapWorld w : core.mapManager.getWorlds()) {
|
|
|
|
for (MapType mt : w.maps)
|
|
|
|
if (mt instanceof HDMap)
|
|
|
|
++hdmaps;
|
|
|
|
maps += w.maps.size();
|
|
|
|
}
|
2021-11-13 00:44:33 +01:00
|
|
|
obj = obj.appendField("maps", maps);
|
|
|
|
obj = obj.appendField("hd_maps", hdmaps);
|
|
|
|
}
|
|
|
|
return obj.build();
|
|
|
|
}
|
2012-08-25 05:37:48 +02:00
|
|
|
}
|
2021-11-13 00:44:33 +01:00
|
|
|
|
|
|
|
private void initMetrics() {
|
|
|
|
metrics = new Metrics(this, 619);
|
|
|
|
|
|
|
|
metrics.addCustomChart(new FeatureChart());
|
|
|
|
|
|
|
|
metrics.addCustomChart(new MapChart());
|
|
|
|
}
|
|
|
|
|
2014-03-12 05:58:01 +01:00
|
|
|
@Override
|
2019-12-20 05:34:32 +01:00
|
|
|
public void processSignChange(String material, String world, int x, int y, int z,
|
2014-03-12 05:58:01 +01:00
|
|
|
String[] lines, String playerid) {
|
2019-12-20 05:34:32 +01:00
|
|
|
core.processSignChange(material, world, x, y, z, lines, playerid);
|
2014-03-12 05:58:01 +01:00
|
|
|
}
|
2015-02-15 19:40:30 +01:00
|
|
|
|
|
|
|
Polygon getWorldBorder(World w) {
|
|
|
|
return helper.getWorldBorder(w);
|
|
|
|
}
|
2019-06-09 16:59:08 +02:00
|
|
|
|
|
|
|
public static boolean migrateChunks() {
|
|
|
|
if ((plugin != null) && (plugin.core != null)) {
|
|
|
|
return plugin.core.migrateChunks();
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2012-01-15 23:58:19 +01:00
|
|
|
}
|