summaryrefslogtreecommitdiff
path: root/master/src/main/java/com/orbekk/PingServer.java
diff options
context:
space:
mode:
Diffstat (limited to 'master/src/main/java/com/orbekk/PingServer.java')
-rw-r--r--master/src/main/java/com/orbekk/PingServer.java50
1 files changed, 50 insertions, 0 deletions
diff --git a/master/src/main/java/com/orbekk/PingServer.java b/master/src/main/java/com/orbekk/PingServer.java
new file mode 100644
index 0000000..b1126d4
--- /dev/null
+++ b/master/src/main/java/com/orbekk/PingServer.java
@@ -0,0 +1,50 @@
+package com.orbekk;
+
+import org.apache.log4j.Logger;
+import org.eclipse.jetty.server.Server;
+
+import com.googlecode.jsonrpc4j.JsonRpcServer;
+import com.orbekk.rpc.PingService;
+import com.orbekk.rpc.PingServiceImpl;
+import com.orbekk.rpc.RpcHandler;
+
+public class PingServer {
+ Server server;
+ Logger logger = Logger.getLogger(getClass());
+
+ public PingServer(Server server) {
+ this.server = server;
+ }
+
+ public static PingServer createPingServer(int port) {
+ PingService service = new PingServiceImpl();
+ JsonRpcServer jsonServer = new JsonRpcServer(service, PingService.class);
+
+ Server server = new Server(port);
+ RpcHandler rpcHandler = new RpcHandler(jsonServer);
+ server.setHandler(rpcHandler);
+
+ return new PingServer(server);
+ }
+
+ public void start() throws Exception {
+ logger.info("Starting server.");
+ server.start();
+ }
+
+ public void join() {
+ try {
+ server.join();
+ } catch (InterruptedException e) {
+ logger.info("Received InterruptException while waiting for server.", e.fillInStackTrace());
+ }
+ }
+
+ public void stop() {
+ try {
+ server.stop();
+ } catch (Exception e) {
+ logger.warn("Exception when stopping server.", e.fillInStackTrace());
+ }
+ }
+}