X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;ds=inline;f=src%2Fbe%2Fnikiroo%2Ffanfix%2Flibrary%2FRemoteLibraryServer.java;h=138246ae47044a33399b132ac6c619ca320083df;hb=aac7079dc723e0c03a6c6f58a81d4ef756811fa2;hp=245e6fd9b3fc7184c9178e557bb5efe4ba638b89;hpb=7efece854302b553804f764780db3f47bc3b250e;p=nikiroo-utils.git diff --git a/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java b/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java index 245e6fd..138246a 100644 --- a/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java +++ b/src/be/nikiroo/fanfix/library/RemoteLibraryServer.java @@ -1,7 +1,7 @@ package be.nikiroo.fanfix.library; import java.io.IOException; -import java.security.InvalidParameterException; +import java.net.URL; import java.util.ArrayList; import java.util.List; @@ -28,16 +28,23 @@ import be.nikiroo.utils.serial.server.ServerObject; * * @@ -74,13 +81,13 @@ public class RemoteLibraryServer extends ServerObject { if (data instanceof Object[]) { Object[] dataArray = (Object[]) data; if (dataArray.length >= 2) { + md5 = "" + dataArray[0]; + command = "" + dataArray[1]; + args = new Object[dataArray.length - 2]; for (int i = 2; i < dataArray.length; i++) { args[i - 2] = dataArray[i]; } - - md5 = "" + dataArray[0]; - command = "" + dataArray[1]; } } @@ -103,8 +110,9 @@ public class RemoteLibraryServer extends ServerObject { createPgForwarder(action)); return metas.toArray(new MetaData[] {}); } - throw new InvalidParameterException( - "only * is valid here, but you passed: " + args[0]); + + return new MetaData[] { Instance.getLibrary().getInfo( + (String) args[0]) }; } else if ("GET_STORY".equals(command)) { MetaData meta = Instance.getLibrary().getInfo((String) args[0]); meta = meta.clone(); @@ -132,6 +140,11 @@ public class RemoteLibraryServer extends ServerObject { Story story = rebuildStory(list); Instance.getLibrary().save(story, (String) args[0], null); + return story.getMeta().getLuid(); + } else if ("IMPORT".equals(command)) { + Story story = Instance.getLibrary().imprt( + new URL((String) args[0]), createPgForwarder(action)); + return story.getMeta().getLuid(); } else if ("DELETE_STORY".equals(command)) { Instance.getLibrary().delete((String) args[0]); } else if ("GET_COVER".equals(command)) { @@ -141,6 +154,9 @@ public class RemoteLibraryServer extends ServerObject { } else if ("SET_SOURCE_COVER".equals(command)) { Instance.getLibrary().setSourceCover((String) args[0], (String) args[1]); + } else if ("CHANGE_SOURCE".equals(command)) { + Instance.getLibrary().changeSource((String) args[0], + (String) args[1], createPgForwarder(action)); } else if ("EXIT".equals(command)) { stop(0, false); } @@ -162,6 +178,8 @@ public class RemoteLibraryServer extends ServerObject { * @return the list of {@link Object}s */ static List breakStory(Story story) { + System.out.println("Story to break: "+story); + List list = new ArrayList(); story = story.clone(); @@ -202,6 +220,7 @@ public class RemoteLibraryServer extends ServerObject { } } + System.out.println("rebuilt story: "+story); return story; }