1 package jalview.fts.service.threedbeacons;
4 import java.util.ArrayList;
5 import java.util.Collection;
6 import java.util.Iterator;
9 import java.util.Objects;
11 import javax.ws.rs.core.MediaType;
13 import org.json.simple.parser.ParseException;
15 import com.sun.jersey.api.client.Client;
16 import com.sun.jersey.api.client.ClientResponse;
17 import com.sun.jersey.api.client.WebResource;
18 import com.sun.jersey.api.client.config.DefaultClientConfig;
20 import jalview.datamodel.SequenceI;
21 import jalview.fts.api.FTSData;
22 import jalview.fts.api.FTSDataColumnI;
23 import jalview.fts.api.FTSRestClientI;
24 import jalview.fts.core.FTSRestClient;
25 import jalview.fts.core.FTSRestRequest;
26 import jalview.fts.core.FTSRestResponse;
27 import jalview.fts.service.pdb.PDBFTSRestClient;
28 import jalview.util.JSONUtils;
29 import jalview.util.MessageManager;
30 import jalview.util.Platform;
32 public class TDBeaconsFTSRestClient extends FTSRestClient
34 private static final String DEFAULT_THREEDBEACONS_DOMAIN =
35 "https://wwwdev.ebi.ac.uk/pdbe/pdbe-kb/3dbeacons-hub-api/uniprot/";
37 private static FTSRestClientI instance = null;
39 protected TDBeaconsFTSRestClient()
43 @SuppressWarnings("unchecked")
45 public FTSRestResponse executeRequest(FTSRestRequest tdbRestRequest)
50 String query = tdbRestRequest.getFieldToSearchBy()
51 + tdbRestRequest.getSearchTerm();
53 Class<ClientResponse> clientResponseClass;
57 client = (Client) (Object) new jalview.javascript.web.Client();
58 clientResponseClass = (Class<ClientResponse>) (Object) jalview.javascript.web.ClientResponse.class;
66 client = Client.create(new DefaultClientConfig());
67 clientResponseClass = ClientResponse.class;
69 WebResource webResource;
70 webResource = client.resource(DEFAULT_THREEDBEACONS_DOMAIN)
72 URI uri = webResource.getURI();
73 System.out.println(uri.toString());
75 // Execute the REST request
76 ClientResponse clientResponse = webResource
77 .accept(MediaType.APPLICATION_JSON).get(clientResponseClass);
79 // Get the JSON string from the response object or directly from the
80 // client (JavaScript)
81 Map<String, Object> jsonObj = null;
82 String responseString = null;
84 // Check the response status and report exception if one occurs
85 int responseStatus = clientResponse.getStatus();
86 switch (responseStatus)
92 jsonObj = clientResponse.getEntity(Map.class);
96 responseString = clientResponse.getEntity(String.class);
100 throw new Exception(parseJsonExceptionString(responseString));
103 getMessageByHTTPStatusCode(responseStatus, "3DBeacons"));
105 // Process the response and return the result to the caller.
106 return parseTDBeaconsJsonResponse(responseString, jsonObj, tdbRestRequest);
107 } catch (Exception e)
109 String exceptionMsg = e.getMessage();
110 if (exceptionMsg.contains("SocketException"))
112 // No internet connection
113 throw new Exception(MessageManager.getString(
114 "exception.unable_to_detect_internet_connection"));
116 else if (exceptionMsg.contains("UnknownHostException"))
118 // The server is unreachable
119 throw new Exception(MessageManager.formatMessage(
120 "exception.fts_server_unreachable", "3DB Hub"));
130 public String setSearchTerm(String term) {
134 public static FTSRestResponse parseTDBeaconsJsonResponse(
135 String tdbJsonResponseString, FTSRestRequest tdbRestRequest)
137 return parseTDBeaconsJsonResponse(tdbJsonResponseString,
138 (Map<String, Object>) null, tdbRestRequest);
141 @SuppressWarnings("unchecked")
142 public static FTSRestResponse parseTDBeaconsJsonResponse(String tdbJsonResponseString,
143 Map<String, Object> jsonObj, FTSRestRequest tdbRestRequest)
145 FTSRestResponse searchResult = new FTSRestResponse();
146 List<FTSData> result = null;
152 jsonObj = (Map<String, Object>) JSONUtils.parse(tdbJsonResponseString);
154 //System.out.println(jsonObj);
156 Object uniprot_entry = jsonObj.get("uniprot_entry");
157 System.out.println(uniprot_entry);
159 Long seqLength = (Long) ((Map<String, Object>) jsonObj.get("uniprot_entry")).get("sequence_length");
160 System.out.println("seqLenght :" + seqLength);
162 result = new ArrayList<>();
163 List<Object> structures = (List<Object>) jsonObj.get("structures");
164 //Map<String, Object> tdbResponse = (Map<String, Object>) jsonObj.get("structures");
167 for (Iterator<Object> strucIter = structures.iterator(); strucIter
170 Map<String, Object> structure = (Map<String, Object>) strucIter.next();
171 result.add(getFTSData(structure, tdbRestRequest));
173 //System.out.println(structure);
176 System.out.println("1 : " + structures.get(1));
177 searchResult.setNumberOfItemsFound(numFound);
178 searchResult.setSearchSummary(result);
179 searchResult.setSequenceLength(seqLength);
181 } catch (ParseException e)
188 private static FTSData getFTSData(Map<String, Object> tdbJsonStructure,
189 FTSRestRequest tdbRequest)
191 // TODO Auto-generated method stub
192 String primaryKey = null;
193 Object[] summaryRowData;
194 Collection<FTSDataColumnI> displayFields = tdbRequest.getWantedFields();
196 summaryRowData = new Object[displayFields.size()];
197 for (FTSDataColumnI field : displayFields) {
198 String fieldData = (tdbJsonStructure.get(field.getCode()) == null) ? " "
199 : tdbJsonStructure.get(field.getCode()).toString();
200 if (field.isPrimaryKeyColumn())
202 primaryKey = fieldData;
203 summaryRowData[colCounter++] = primaryKey;
205 else if (fieldData == null || fieldData.isEmpty())
207 summaryRowData[colCounter++] = null;
213 summaryRowData[colCounter++] = (field.getDataType()
214 .getDataTypeClass() == Integer.class)
215 ? Integer.valueOf(fieldData)
216 : (field.getDataType()
217 .getDataTypeClass() == Double.class)
218 ? Double.valueOf(fieldData)
220 } catch (Exception e)
223 System.out.println("offending value:" + fieldData);
227 final String primaryKey1 = primaryKey;
228 final Object[] summaryRowData1 = summaryRowData;
234 public Object[] getSummaryData()
236 return summaryRowData1;
240 public Object getPrimaryKey()
246 * Returns a string representation of this object;
249 public String toString()
251 StringBuilder summaryFieldValues = new StringBuilder();
252 for (Object summaryField : summaryRowData1)
254 summaryFieldValues.append(
255 summaryField == null ? " " : summaryField.toString())
258 return summaryFieldValues.toString();
262 * Returns hash code value for this object
265 public int hashCode()
267 return Objects.hash(primaryKey1, this.toString());
271 public boolean equals(Object that)
273 return this.toString().equals(that.toString());
278 // private static FTSData getFTSData(Map<String, Object> doc,
279 // FTSRestRequest tdbRestRequest)
281 // String primaryKey = null;
283 // Object[] summaryRowData;
285 // Collection<FTSDataColumnI> displayFields = tdbRestRequest.getWantedFields();
286 // int colCounter = 0;
287 // summaryRowData = new Object[displayFields.size() + 1];
292 private String parseJsonExceptionString(String jsonErrorString)
294 // TODO Auto-generated method stub
299 public String getColumnDataConfigFileName()
301 return "/fts/tdbeacons_data_columns.txt";
304 public static FTSRestClientI getInstance()
306 if (instance == null)
308 instance = new TDBeaconsFTSRestClient();
313 private Collection<FTSDataColumnI> allDefaultDisplayedStructureDataColumns;
315 public Collection<FTSDataColumnI> getAllDefaultDisplayedStructureDataColumns()
317 if (allDefaultDisplayedStructureDataColumns == null
318 || allDefaultDisplayedStructureDataColumns.isEmpty())
320 allDefaultDisplayedStructureDataColumns = new ArrayList<>();
321 allDefaultDisplayedStructureDataColumns
322 .addAll(super.getAllDefaultDisplayedFTSDataColumns());
324 return allDefaultDisplayedStructureDataColumns;