mirror of
https://github.com/webbukkit/dynmap.git
synced 2025-01-16 20:51:53 +01:00
Add support for WorldGuard on built-in server, fix getNodes() on new
ConfigurationNode class
This commit is contained in:
parent
a7ba34065b
commit
26f4f7d994
@ -132,10 +132,11 @@ public class ConfigurationNode implements Map<String, Object> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public List<ConfigurationNode> getNodes(String path) {
|
public List<ConfigurationNode> getNodes(String path) {
|
||||||
Object o = getObject(path);
|
List<Object> o = getList(path);
|
||||||
if (!(o instanceof List<?>)) {
|
|
||||||
|
if(o == null)
|
||||||
return new ArrayList<ConfigurationNode>();
|
return new ArrayList<ConfigurationNode>();
|
||||||
}
|
|
||||||
ArrayList<ConfigurationNode> nodes = new ArrayList<ConfigurationNode>();
|
ArrayList<ConfigurationNode> nodes = new ArrayList<ConfigurationNode>();
|
||||||
for(Object i : (List<?>)o) {
|
for(Object i : (List<?>)o) {
|
||||||
if (i instanceof Map<?, ?>) {
|
if (i instanceof Map<?, ?>) {
|
||||||
|
@ -46,6 +46,7 @@ import org.dynmap.web.handlers.ClientConfigurationHandler;
|
|||||||
import org.dynmap.web.handlers.ClientUpdateHandler;
|
import org.dynmap.web.handlers.ClientUpdateHandler;
|
||||||
import org.dynmap.web.handlers.FilesystemHandler;
|
import org.dynmap.web.handlers.FilesystemHandler;
|
||||||
import org.dynmap.web.handlers.SendMessageHandler;
|
import org.dynmap.web.handlers.SendMessageHandler;
|
||||||
|
import org.dynmap.web.handlers.RegionHandler;
|
||||||
|
|
||||||
public class DynmapPlugin extends JavaPlugin {
|
public class DynmapPlugin extends JavaPlugin {
|
||||||
public HttpServer webServer = null;
|
public HttpServer webServer = null;
|
||||||
@ -141,6 +142,14 @@ public class DynmapPlugin extends JavaPlugin {
|
|||||||
webServer.handlers.put("/tiles/", new FilesystemHandler(tilesDirectory));
|
webServer.handlers.put("/tiles/", new FilesystemHandler(tilesDirectory));
|
||||||
webServer.handlers.put("/up/", new ClientUpdateHandler(mapManager, playerList, getServer(), configuration.getBoolean("health-in-json", false)));
|
webServer.handlers.put("/up/", new ClientUpdateHandler(mapManager, playerList, getServer(), configuration.getBoolean("health-in-json", false)));
|
||||||
webServer.handlers.put("/up/configuration", new ClientConfigurationHandler(configuration.getNode("web")));
|
webServer.handlers.put("/up/configuration", new ClientConfigurationHandler(configuration.getNode("web")));
|
||||||
|
/* See if regions configuration branch is present */
|
||||||
|
for(ConfigurationNode type : configuration.getNode("web").getNodes("components")) {
|
||||||
|
if(type.getString("type").equalsIgnoreCase("regions")) {
|
||||||
|
String fname = type.getString("filename", "regions.yml");
|
||||||
|
fname = "/standalone/" + fname.substring(0, fname.lastIndexOf('.')) + "_"; /* Find our path base */
|
||||||
|
webServer.handlers.put(fname + "*", new RegionHandler(type));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (configuration.getNode("web").getBoolean("allowwebchat", false)) {
|
if (configuration.getNode("web").getBoolean("allowwebchat", false)) {
|
||||||
SendMessageHandler messageHandler = new SendMessageHandler() {{
|
SendMessageHandler messageHandler = new SendMessageHandler() {{
|
||||||
|
@ -33,7 +33,7 @@ class JsonTimerTask extends TimerTask {
|
|||||||
this.server = this.plugin.getServer();
|
this.server = this.plugin.getServer();
|
||||||
this.mapManager = this.plugin.getMapManager();
|
this.mapManager = this.plugin.getMapManager();
|
||||||
this.configuration = config;
|
this.configuration = config;
|
||||||
for(ConfigurationNode type : configuration.getNodes("web/components"))
|
for(ConfigurationNode type : configuration.getNode("web").getNodes("components"))
|
||||||
if(type.getString("type").equalsIgnoreCase("regions")) {
|
if(type.getString("type").equalsIgnoreCase("regions")) {
|
||||||
this.regions = type;
|
this.regions = type;
|
||||||
break;
|
break;
|
||||||
|
@ -161,6 +161,13 @@ public class HttpServerConnection extends Thread {
|
|||||||
handler = entry.getValue();
|
handler = entry.getValue();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
/* Wildcard handler for non-directory matches */
|
||||||
|
else if(key.endsWith("*") && request.path.startsWith(key.substring(0, key.length()-1))) { relativePath = request.path.substring(entry.getKey().length());
|
||||||
|
relativePath = request.path.substring(entry.getKey().length()-1);
|
||||||
|
relativePath = URLDecoder.decode(relativePath,"utf-8");
|
||||||
|
handler = entry.getValue();
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (handler == null) {
|
if (handler == null) {
|
||||||
|
73
src/main/java/org/dynmap/web/handlers/RegionHandler.java
Normal file
73
src/main/java/org/dynmap/web/handlers/RegionHandler.java
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
package org.dynmap.web.handlers;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.logging.Level;
|
||||||
|
import org.bukkit.util.config.Configuration;
|
||||||
|
import org.dynmap.ConfigurationNode;
|
||||||
|
import org.dynmap.web.HttpRequest;
|
||||||
|
import org.dynmap.web.HttpResponse;
|
||||||
|
import org.dynmap.web.Json;
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.ByteArrayInputStream;
|
||||||
|
|
||||||
|
public class RegionHandler extends FileHandler {
|
||||||
|
private ConfigurationNode regions;
|
||||||
|
public RegionHandler(ConfigurationNode regions) {
|
||||||
|
this.regions = regions;
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
protected InputStream getFileInput(String path, HttpRequest request, HttpResponse response) {
|
||||||
|
if(regions == null)
|
||||||
|
return null;
|
||||||
|
/* Right path? */
|
||||||
|
if(path.endsWith(".json") == false)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
String worldname = path.substring(0, path.lastIndexOf(".json"));
|
||||||
|
Configuration regionConfig = null;
|
||||||
|
File infile;
|
||||||
|
String regionFile;
|
||||||
|
|
||||||
|
/* If using worldpath, format is either plugins/<plugin>/<worldname>/<filename> OR
|
||||||
|
* plugins/<plugin>/worlds/<worldname>/<filename>
|
||||||
|
*/
|
||||||
|
File basepath = new File("plugins", regions.getString("name", "WorldGuard"));
|
||||||
|
if(basepath.exists() == false)
|
||||||
|
return null;
|
||||||
|
if(regions.getBoolean("useworldpath", false)) {
|
||||||
|
regionFile = worldname + "/" + regions.getString("filename", "regions.yml");
|
||||||
|
infile = new File(basepath, regionFile);
|
||||||
|
if(!infile.exists()) {
|
||||||
|
infile = new File(basepath, "worlds/" + regionFile);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { /* Else, its plugins/<plugin>/<filename> */
|
||||||
|
regionFile = regions.getString("filename", "regions.yml");
|
||||||
|
infile = new File(basepath, regionFile);
|
||||||
|
}
|
||||||
|
if(infile.exists()) {
|
||||||
|
regionConfig = new Configuration(infile);
|
||||||
|
}
|
||||||
|
//File didn't exist
|
||||||
|
if(regionConfig == null)
|
||||||
|
return null;
|
||||||
|
regionConfig.load();
|
||||||
|
/* Parse region data and store in MemoryInputStream */
|
||||||
|
Map<?, ?> regionData = (Map<?, ?>) regionConfig.getProperty(regions.getString("basenode", "regions"));
|
||||||
|
try {
|
||||||
|
ByteArrayOutputStream fos = new ByteArrayOutputStream();
|
||||||
|
fos.write(Json.stringifyJson(regionData).getBytes());
|
||||||
|
fos.close();
|
||||||
|
return new ByteArrayInputStream(fos.toByteArray());
|
||||||
|
} catch (FileNotFoundException ex) {
|
||||||
|
log.log(Level.SEVERE, "Exception while writing JSON-file.", ex);
|
||||||
|
} catch (IOException ioe) {
|
||||||
|
log.log(Level.SEVERE, "Exception while writing JSON-file.", ioe);
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user