TotalFreedomMod/src/me/StevenLawson/TotalFreedomMod/HTTPD/TFM_HTTPD_Manager.java

193 lines
5.3 KiB
Java
Raw Normal View History

2013-08-27 01:48:04 +00:00
package me.StevenLawson.TotalFreedomMod.HTTPD;
import java.io.IOException;
import java.net.Socket;
2013-08-27 01:48:04 +00:00
import java.util.Map;
2013-08-27 13:01:12 +00:00
import java.util.concurrent.Callable;
import java.util.concurrent.Future;
import static me.StevenLawson.TotalFreedomMod.HTTPD.NanoHTTPD.MIME_PLAINTEXT;
import me.StevenLawson.TotalFreedomMod.TFM_ConfigEntry;
2013-08-27 01:48:04 +00:00
import me.StevenLawson.TotalFreedomMod.TFM_Log;
2013-08-27 13:01:12 +00:00
import me.StevenLawson.TotalFreedomMod.TotalFreedomMod;
2013-08-27 01:48:04 +00:00
import org.apache.commons.lang.StringUtils;
2013-08-27 13:01:12 +00:00
import org.bukkit.Bukkit;
2013-08-27 01:48:04 +00:00
public class TFM_HTTPD_Manager
{
public static final int PORT = TFM_ConfigEntry.HTTPD_PORT.getInteger();
2013-08-27 01:48:04 +00:00
//
private final TFM_HTTPD httpd = new TFM_HTTPD(PORT);
private TFM_HTTPD_Manager()
{
}
public void start()
{
if (!TFM_ConfigEntry.HTTPD_ENABLED.getBoolean())
{
return;
}
2013-08-27 01:48:04 +00:00
try
{
httpd.start();
2013-08-27 16:39:28 +00:00
if (httpd.isAlive())
{
TFM_Log.info("TFM HTTPd started. Listening on port: " + httpd.getListeningPort());
}
else
{
TFM_Log.info("Error starting TFM HTTPd.");
}
2013-08-27 01:48:04 +00:00
}
catch (IOException ex)
{
TFM_Log.severe(ex);
}
}
public void stop()
{
if (!TFM_ConfigEntry.HTTPD_ENABLED.getBoolean())
{
return;
}
2013-08-27 01:48:04 +00:00
httpd.stop();
2013-08-27 16:39:28 +00:00
TFM_Log.info("TFM HTTPd stopped.");
2013-08-27 01:48:04 +00:00
}
private static enum ModuleType
{
DUMP(false, "dump"),
HELP(true, "help"),
LIST(true, "list"),
FILE(false, "file"),
SCHEMATIC(false, "schematic");
private final boolean runOnBukkitThread;
private final String name;
private ModuleType(boolean runOnBukkitThread, String name)
{
this.runOnBukkitThread = runOnBukkitThread;
this.name = name;
}
public boolean isRunOnBukkitThread()
{
return runOnBukkitThread;
}
public String getName()
{
return name;
}
private static ModuleType getByName(String needle)
{
for (ModuleType type : values())
{
if (type.getName().equalsIgnoreCase(needle))
{
return type;
}
}
return FILE;
}
}
2013-08-27 01:48:04 +00:00
private static class TFM_HTTPD extends NanoHTTPD
{
public TFM_HTTPD(int port)
{
super(port);
}
public TFM_HTTPD(String hostname, int port)
{
super(hostname, port);
}
@Override
public Response serve(
final String uri,
final Method method,
final Map<String, String> headers,
final Map<String, String> params,
final Map<String, String> files,
final Socket socket)
2013-08-27 01:48:04 +00:00
{
Response response = null;
final String[] args = StringUtils.split(uri, "/");
final ModuleType moduleType = args.length >= 1 ? ModuleType.getByName(args[0]) : ModuleType.FILE;
if (moduleType.isRunOnBukkitThread())
2013-08-27 01:48:04 +00:00
{
2013-08-27 13:01:12 +00:00
Future<Response> responseCall = Bukkit.getScheduler().callSyncMethod(TotalFreedomMod.plugin, new Callable<Response>()
2013-08-27 01:48:04 +00:00
{
2013-08-27 13:01:12 +00:00
@Override
public Response call() throws Exception
{
switch (moduleType)
2013-08-27 13:01:12 +00:00
{
case HELP:
return new Module_help(uri, method, headers, params, files, socket).getResponse();
case LIST:
return new Module_list(uri, method, headers, params, files, socket).getResponse();
default:
return null;
2013-08-27 13:01:12 +00:00
}
}
});
try
2013-08-27 01:48:04 +00:00
{
2013-08-27 13:01:12 +00:00
response = responseCall.get();
2013-08-27 01:48:04 +00:00
}
2013-08-27 13:01:12 +00:00
catch (Exception ex)
2013-08-27 01:48:04 +00:00
{
2013-08-27 13:01:12 +00:00
TFM_Log.severe(ex);
2013-08-27 01:48:04 +00:00
}
}
else
{
switch (moduleType)
{
case DUMP:
response = new Module_dump(uri, method, headers, params, files, socket).getResponse();
break;
case SCHEMATIC:
response = new Module_schematic(uri, method, headers, params, files, socket).getResponse();
break;
default:
response = new Module_file(uri, method, headers, params, files, socket).getResponse();
}
}
2013-08-27 01:48:04 +00:00
if (response == null)
{
return new Response(Response.Status.NOT_FOUND, MIME_PLAINTEXT, "Error 404: Not Found - The requested resource was not found on this server.");
}
else
{
return response;
}
}
}
public static TFM_HTTPD_Manager getInstance()
{
return TFM_HTTPDManagerHolder.INSTANCE;
}
private static class TFM_HTTPDManagerHolder
{
private static final TFM_HTTPD_Manager INSTANCE = new TFM_HTTPD_Manager();
}
}