X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Fws%2Frest%2FRestClient.java;h=ac1188d08aed6e92af2af5bd5500083796e0a64a;hb=797df64fa2a0a30773d0f48f5494d4155e5a8be3;hp=ac4f44ec2795245762e5783e3ccc179444778e78;hpb=f149a335b5467a4802eded5da0ca2fc732d7caf7;p=jalview.git
diff --git a/src/jalview/ws/rest/RestClient.java b/src/jalview/ws/rest/RestClient.java
index ac4f44e..ac1188d 100644
--- a/src/jalview/ws/rest/RestClient.java
+++ b/src/jalview/ws/rest/RestClient.java
@@ -1,3 +1,20 @@
+/*******************************************************************************
+ * Jalview - A Sequence Alignment Editor and Viewer (Version 2.7)
+ * Copyright (C) 2011 J Procter, AM Waterhouse, J Engelhardt, LM Lui, G Barton, M Clamp, S Searle
+ *
+ * This file is part of Jalview.
+ *
+ * Jalview is free software: you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
+ *
+ * Jalview is distributed in the hope that it will be useful, but
+ * WITHOUT ANY WARRANTY; without even the implied warranty
+ * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ * PURPOSE. See the GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along with Jalview. If not, see .
+ *******************************************************************************/
/**
*
*/
@@ -7,6 +24,7 @@ import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.Collection;
import java.util.Hashtable;
+import java.util.Vector;
import javax.swing.JMenu;
import javax.swing.JMenuItem;
@@ -14,6 +32,7 @@ import javax.swing.JOptionPane;
import javax.swing.event.MenuEvent;
import javax.swing.event.MenuListener;
+import jalview.bin.Cache;
import jalview.datamodel.AlignmentView;
import jalview.gui.AlignFrame;
import jalview.gui.AlignViewport;
@@ -285,23 +304,24 @@ public class RestClient extends WSClient implements WSClientI,
public static RestClient makeShmmrRestClient()
{
- String action = "Analysis", description = "Sequence Harmony and Multi-Relief (UNSTABLE!)", name = "Sequence Harmony";
+ String action = "Analysis", description = "Sequence Harmony and Multi-Relief (Brandt et al. 2010)", name = "Multi-Harmony";
Hashtable iparams = new Hashtable();
jalview.ws.rest.params.JobConstant toolp;
//toolp = new jalview.ws.rest.JobConstant("tool","jalview");
//iparams.put(toolp.token, toolp);
- toolp = new jalview.ws.rest.params.JobConstant("mbjob[method]","shmr");
- iparams.put(toolp.token, toolp);
- toolp = new jalview.ws.rest.params.JobConstant("mbjob[description]","step 1");
- iparams.put(toolp.token, toolp);
- toolp = new jalview.ws.rest.params.JobConstant("start_search","1");
- iparams.put(toolp.token, toolp);
- toolp = new jalview.ws.rest.params.JobConstant("blast","0");
- iparams.put(toolp.token, toolp);
+ //toolp = new jalview.ws.rest.params.JobConstant("mbjob[method]","shmr");
+ //iparams.put(toolp.token, toolp);
+ //toolp = new jalview.ws.rest.params.JobConstant("mbjob[description]","step 1");
+ //iparams.put(toolp.token, toolp);
+ //toolp = new jalview.ws.rest.params.JobConstant("start_search","1");
+ //iparams.put(toolp.token, toolp);
+ //toolp = new jalview.ws.rest.params.JobConstant("blast","0");
+ //iparams.put(toolp.token, toolp);
jalview.ws.rest.params.Alignment aliinput = new jalview.ws.rest.params.Alignment();
- aliinput.token = "ali";//_file";
- aliinput.writeAsFile=false;//true;
+ // SHMR server has a 65K limit for content pasted into the 'ali' parameter, so we always upload our files.
+ aliinput.token = "ali_file";//_file";
+ aliinput.writeAsFile=true;//true;
//aliinput.token = "ali_file";
//aliinput.writeAsFile=true;
iparams.put(aliinput.token, aliinput);
@@ -315,7 +335,7 @@ public class RestClient extends WSClient implements WSClientI,
action,
description,
name,
- "http://www.ibi.vu.nl/programs/shmrwww/index.php?tool=jalview",// ?tool=jalview&mbjob[method]=shmr&mbjob[description]=step1",
+ "http://zeus.few.vu.nl/programs/shmrwww/index.php?tool=jalview",// ?tool=jalview&mbjob[method]=shmr&mbjob[description]=step1",
"?tool=jalview", iparams, true, false, '-');
// a priori knowledge of the data returned from the service
shmrService.addResultDatatype(JvDataType.ANNOTATION);
@@ -341,14 +361,92 @@ public class RestClient extends WSClient implements WSClientI,
return true;
}
+ protected static Vector services=null;
+ public static final String RSBS_SERVICES="RSBS_SERVICES";
public static RestClient[] getRestClients()
{
- return new RestClient[] { makeShmmrRestClient() };
+ if (services==null)
+ {
+ services = new Vector();
+ try {
+ for (RestServiceDescription descr: RestServiceDescription.parseDescriptions(jalview.bin.Cache.getDefault(RSBS_SERVICES,makeShmmrRestClient().service.toString())))
+ {
+ services.add(descr.toString());
+ }
+ }
+ catch (Exception ex) {
+ System.err.println("Serious - RSBS descriptions in user preferences are corrupt!");
+ ex.printStackTrace();
+ }
+
+ }
+ RestClient[] lst = new RestClient[services.size()];
+ int i=0;
+ for (String svc:services) {
+ lst[i++] = new RestClient(new RestServiceDescription(svc));
+ }
+ return lst;
+ }
+ public static void main(String args[])
+ {
+ try {
+ RestClient[] clients = getRestClients();
+ System.out.println("Got "+clients.length+" clients.");
+ int i=0;
+ Vector urls=new Vector();
+ for (RestClient cl:clients) {
+ System.out.println(""+(++i)+": "+cl.service.toString());
+ urls.add(cl.service.toString());
+ }
+ setRsbsServices(urls);
+ if (clients.length!=getRestClients().length)
+ {
+ System.err.println("Failed. Differing numbers of clients when stringified and parsed again.");
+ }
+
+ } catch (Throwable x)
+ {
+ System.err.println("Failed. Unexpected exception.");
+ x.printStackTrace();
+ }
}
-
public String getAction()
{
return service.details.Action;
}
+ public RestServiceDescription getRestDescription()
+ {
+ return service;
+ }
+
+ public static Vector getRsbsDescriptions()
+ {
+ Vector rsbsDescrs = new Vector();
+ for (RestClient rsbs:getRestClients())
+ {
+ rsbsDescrs.add(rsbs.getRestDescription().toString());
+ }
+ return rsbsDescrs;
+ }
+
+ public static void setRsbsServices(Vector rsbsUrls)
+ {
+ if (rsbsUrls!=null)
+ {
+ // TODO: consider validating services ?
+ services = new Vector(rsbsUrls);
+ StringBuffer sprop = new StringBuffer();
+ for (String s:services)
+ {
+ sprop.append(s);
+ }
+ Cache.setProperty(RSBS_SERVICES, sprop.toString());
+ }
+ else
+ {
+ Cache.removeProperty(RSBS_SERVICES);
+ }
+ }
+
}