X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Flibrary%2FRemoteLibraryServer.java;h=f92c37e8e2ecaf6a1b7604d6b0c914a56b03131a;hb=95c926ea1d5b7c75d5bbc81c50d80f5509d28a4d;hp=d2d9a6e6fa870fd007d0617b18b540e49124bab8;hpb=f569d249d96479f9da73e0b37d3f543fa41eeadc;p=fanfix.git
diff --git a/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java b/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java
deleted file mode 100644
index d2d9a6e..0000000
--- a/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java
+++ /dev/null
@@ -1,112 +0,0 @@
-package be.nikiroo.fanfix.library;
-
-import java.io.IOException;
-import java.security.InvalidParameterException;
-import java.util.List;
-
-import be.nikiroo.fanfix.Instance;
-import be.nikiroo.fanfix.data.MetaData;
-import be.nikiroo.fanfix.data.Story;
-import be.nikiroo.utils.Version;
-import be.nikiroo.utils.serial.ConnectActionServer;
-import be.nikiroo.utils.serial.Server;
-
-/**
- * Create a new remote server that will listen for order on the given port.
- *
- * The available commands are given as String arrays (first item is the key,
- * second is the command, the rest are the arguments):
- *
- * - KEY GET_METADATA *: will return the metadata of all the stories in the
- * library
- * - KEY GET_STORY [luid]: will return the given story if it exists (or NULL
- * if not)
- * - KEY SAVE_STORY [story] [luid]: save the story with the given LUID
- * - KEY DELETE_STORY [luid]: delete the story of LUID luid
- * - KEY GET_COVER [luid]: return the cover of the story
- * - KEY GET_SOURCE_COVER [source]: return the cover for this source
- * - KEY SET_SOURCE_COVER [source], [luid]: set the default cover for the
- * given source to the cover of the story denoted by luid
- * - KEY EXIT: stop the server
- *
- *
- * @author niki
- */
-public class RemoteLibraryServer extends Server {
- private final String key;
-
- /**
- * Create a new remote server (will not be active until
- * {@link RemoteLibraryServer#start()} is called).
- *
- * @param key
- * the key that will restrict access to this server
- * @param port
- * the port to listen on
- *
- * @throws IOException
- * in case of I/O error
- */
- public RemoteLibraryServer(String key, int port) throws IOException {
- super(port, true);
- this.key = key;
- }
-
- @Override
- protected Object onRequest(ConnectActionServer action,
- Version clientVersion, Object data) throws Exception {
- String key = "";
- String command = "";
- Object[] args = new Object[0];
- if (data instanceof Object[]) {
- Object[] dataArray = (Object[]) data;
- if (dataArray.length >= 2) {
- args = new Object[dataArray.length - 2];
- for (int i = 2; i < dataArray.length; i++) {
- args[i - 2] = dataArray[i];
- }
-
- key = "" + dataArray[0];
- command = "" + dataArray[1];
- }
- }
-
- System.out.print("[" + command + "] ");
- for (Object arg : args) {
- System.out.print(arg + " ");
- }
- System.out.println("");
-
- if (!key.equals(this.key)) {
- System.out.println("Key rejected.");
- throw new SecurityException("Invalid key");
- }
-
- // TODO: progress (+send name + %age info back to client)
-
- if ("GET_METADATA".equals(command)) {
- if (args[0].equals("*")) {
- List metas = Instance.getLibrary().getMetas(null);
- return metas.toArray(new MetaData[] {});
- }
- throw new InvalidParameterException(
- "only * is valid here, but you passed: " + args[0]);
- } else if ("GET_STORY".equals(command)) {
- return Instance.getLibrary().getStory("" + args[0], null);
- } else if ("SAVE_STORY".equals(command)) {
- Instance.getLibrary().save((Story) args[0], "" + args[1], null);
- } else if ("DELETE_STORY".equals(command)) {
- Instance.getLibrary().delete("" + args[0]);
- } else if ("GET_COVER".equals(command)) {
- return Instance.getLibrary().getCover("" + args[0]);
- } else if ("GET_SOURCE_COVER".equals(command)) {
- return Instance.getLibrary().getSourceCover("" + args[0]);
- } else if ("SET_SOURCE_COVER".equals(command)) {
- Instance.getLibrary().setSourceCover("" + args[0], "" + args[1]);
- } else if ("EXIT".equals(command)) {
- stop(0, false);
- }
-
- return null;
- }
-}