All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opencb.opencga.client.rest.AbstractParentClient Maven / Gradle / Ivy

 /*
  * Copyright 2015-2020 OpenCB
  *
  * Licensed under the Apache License, Version 2.0 (the "License");
  * you may not use this file except in compliance with the License.
  * You may obtain a copy of the License at
  *
  *     http://www.apache.org/licenses/LICENSE-2.0
  *
  * Unless required by applicable law or agreed to in writing, software
  * distributed under the License is distributed on an "AS IS" BASIS,
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */

 package org.opencb.opencga.client.rest;

 import com.fasterxml.jackson.core.JsonParseException;
 import com.fasterxml.jackson.core.JsonProcessingException;
 import com.fasterxml.jackson.databind.DeserializationFeature;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.fasterxml.jackson.databind.ObjectReader;
 import org.apache.commons.collections4.CollectionUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.glassfish.jersey.client.ClientProperties;
 import org.glassfish.jersey.client.RequestEntityProcessing;
 import org.glassfish.jersey.media.multipart.FormDataMultiPart;
 import org.glassfish.jersey.media.multipart.MultiPartFeature;
 import org.glassfish.jersey.media.multipart.file.FileDataBodyPart;
 import org.opencb.commons.datastore.core.DataResult;
 import org.opencb.commons.datastore.core.Event;
 import org.opencb.commons.datastore.core.ObjectMap;
 import org.opencb.commons.datastore.core.QueryOptions;
 import org.opencb.opencga.client.config.ClientConfiguration;
 import org.opencb.opencga.client.exceptions.ClientException;
 import org.opencb.opencga.core.common.JacksonUtils;
 import org.opencb.opencga.core.response.OpenCGAResult;
 import org.opencb.opencga.core.response.QueryType;
 import org.opencb.opencga.core.response.RestResponse;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;

 import javax.net.ssl.*;
 import javax.ws.rs.client.*;
 import javax.ws.rs.core.Cookie;
 import javax.ws.rs.core.HttpHeaders;
 import javax.ws.rs.core.Response;
 import java.io.*;
 import java.net.*;
 import java.nio.channels.Channels;
 import java.nio.channels.ReadableByteChannel;
 import java.nio.charset.StandardCharsets;
 import java.nio.file.Files;
 import java.nio.file.Paths;
 import java.security.KeyManagementException;
 import java.security.NoSuchAlgorithmException;
 import java.security.SecureRandom;
 import java.security.cert.X509Certificate;
 import java.util.*;
 import java.util.stream.Collectors;

 /**
  * Created by imedina on 04/05/16.
  */
 public abstract class AbstractParentClient {

     protected static final String GET = "GET";
     protected static final String POST = "POST";
     protected static final String DELETE = "DELETE";
     protected static final int DEFAULT_BATCH_SIZE = 200;
     protected static final int DEFAULT_LIMIT = 2000;
     protected static final int DEFAULT_SKIP = 0;
     protected static final int DEFAULT_CONNECT_TIMEOUT = 1000;
     protected static final int DEFAULT_READ_TIMEOUT = 30000;
     protected static final int DEFAULT_UPLOAD_TIMEOUT = 5400000;
     protected static final String COOKIES = "cookies";

     protected final Client client;
     protected final ObjectMapper jsonObjectMapper;
     protected final ClientConfiguration clientConfiguration;
     protected final int batchSize;
     protected final int defaultLimit;
     private final Logger privateLogger;
     protected Logger logger;
     protected String token;
     private boolean throwExceptionOnError = false;

     protected AbstractParentClient(String token, ClientConfiguration clientConfiguration) {
         this.token = token;
         this.clientConfiguration = clientConfiguration;

         this.logger = LoggerFactory.getLogger(this.getClass());
         this.privateLogger = LoggerFactory.getLogger(AbstractParentClient.class);

         this.client = createRestClient();

         jsonObjectMapper = new ObjectMapper();
         jsonObjectMapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);

         if (this.clientConfiguration.getRest().getQuery() != null) {
             if (this.clientConfiguration.getRest().getQuery().getBatchSize() > 0) {
                 batchSize = this.clientConfiguration.getRest().getQuery().getBatchSize();
             } else {
                 batchSize = DEFAULT_BATCH_SIZE;
             }
             if (this.clientConfiguration.getRest().getQuery().getLimit() > 0) {
                 defaultLimit = this.clientConfiguration.getRest().getQuery().getLimit();
             } else {
                 defaultLimit = DEFAULT_LIMIT;
             }
         } else {
             batchSize = DEFAULT_BATCH_SIZE;
             defaultLimit = DEFAULT_LIMIT;
         }
     }

     private Client createRestClient() {
         ClientBuilder clientBuilder = ClientBuilder.newBuilder();
         clientBuilder.register(JacksonUtils.ObjectMapperProvider.class);
         if (clientConfiguration.getRest().isTlsAllowInvalidCertificates()) {
             privateLogger.debug("Using custom SSLContext to allow invalid certificates");
             try {
                 TrustManager[] trustAllCerts = new TrustManager[]{
                         new X509TrustManager() {
                             @Override
                             public X509Certificate[] getAcceptedIssuers() {
                                 return new X509Certificate[0];
                             }

                             @Override
                             public void checkClientTrusted(X509Certificate[] certs, String authType) {
                             }

                             @Override
                             public void checkServerTrusted(X509Certificate[] certs, String authType) {
                             }
                         },
                 };

                 SSLContext sc = SSLContext.getInstance("TLS");
                 sc.init(null, trustAllCerts, new SecureRandom());

                 HostnameVerifier verifier = new HostnameVerifier() {
                     private final String hostname = URI
                             .create(clientConfiguration.getRest().getHosts()
                                     .get(clientConfiguration.getRest().getDefaultHostIndex()).getUrl())
                             .getHost();

                     @Override
                     public boolean verify(String hostname, SSLSession sslSession) {
                         privateLogger.debug("Verify hostname = " + hostname);
                         return this.hostname.equals(hostname);
                     }
                 };
                 clientBuilder.sslContext(sc).hostnameVerifier(verifier);
             } catch (NoSuchAlgorithmException | KeyManagementException e) {
                 throw new RuntimeException(e);
             }
         }
         return clientBuilder.build();
     }

     public AbstractParentClient setThrowExceptionOnError(boolean throwExceptionOnError) {
         this.throwExceptionOnError = throwExceptionOnError;
         return this;
     }

     protected  RestResponse execute(String category, String action, Map params, String method, Class clazz)
             throws ClientException {
         return execute(category, null, action, params, method, clazz);
     }

     protected  RestResponse execute(String category, String id, String action, Map params, String method,
                                           Class clazz) throws ClientException {
         return execute(category, id, null, null, action, params, method, clazz);
     }

     protected  RestResponse execute(String category1, String id1, String category2, String id2, String action,
                                           Map paramsMap, String method, Class clazz) throws ClientException {
         List ids;
         if (StringUtils.isNotEmpty(id1)) {
             ids = Arrays.asList(id1.split(","));
         } else {
             ids = Collections.emptyList();
         }
         return execute(category1, ids, category2, id2, action, paramsMap, method, clazz);
     }

     private  RestResponse execute(String category1, List id1, String category2, String id2, String action,
                                         Map paramsMap, String method, Class clazz) throws ClientException {
         ObjectMap params;
         if (paramsMap == null) {
             params = new ObjectMap();
         } else {
             params = new ObjectMap(paramsMap);
         }
         params.put(QueryOptions.TIMEOUT, DEFAULT_READ_TIMEOUT);

         client.property(ClientProperties.CONNECT_TIMEOUT, DEFAULT_CONNECT_TIMEOUT);
         client.property(ClientProperties.READ_TIMEOUT, DEFAULT_READ_TIMEOUT);

         int skip;
         int limit;
         int batchSize;
         if (CollectionUtils.isEmpty(id1)) {
             skip = params.getInt(QueryOptions.SKIP, DEFAULT_SKIP);
             limit = params.getInt(QueryOptions.LIMIT, defaultLimit);
             batchSize = this.batchSize;

             if (limit < 0) {
                 limit = defaultLimit;
             }
         } else {
             // Ignore input SKIP and LIMIT from Params
             skip = 0;
             limit = id1.size();
             // Hardcoded OpenCGA IDs limit
             // See org.opencb.opencga.server.rest.OpenCGAWSServer.MAX_ID_SIZE
             batchSize = 100;

             params.remove(QueryOptions.SKIP);
             params.remove(QueryOptions.LIMIT);
         }

         RestResponse finalRestResponse = null;
         int finalNumResults = 0;
         int batchNumResults;
         // Call REST in batches
         do {
             // Update the batch limit
             int batchLimit = Math.min(batchSize, limit - finalNumResults);

             // Build URL
             WebTarget path = client
                     .target(clientConfiguration.getCurrentHost().getUrl())
                     .path("webservices")
                     .path("rest")
                     .path("v2")
                     .path(category1);
             // Select batch. Either by ID or with limit/skip
             if (CollectionUtils.isNotEmpty(id1)) {
                 // Select batch of IDs
                 String ids = String.join(",", id1.subList(skip, skip + batchLimit));
                 // Use templated variables to ensure correct URL encoding
                 path = path.path("{id1}").resolveTemplate("id1", ids);
                 // FIXME: This should not be needed!
                 params.put(QueryOptions.LIMIT, batchLimit);
             } else {
                 // Select batch with skip/limit
                 params.put(QueryOptions.SKIP, skip);
                 params.put(QueryOptions.LIMIT, batchLimit);
             }
             if (StringUtils.isNotEmpty(category2)) {
                 path = path.path(category2);
             }
             if (StringUtils.isNotEmpty(id2)) {
                 // Use templated variables to ensure correct URL encoding
                 path = path.path("{id2}").resolveTemplate("id2", id2);
             }
             path = path.path(action);
             //privateLogger.info("PATH ::: " + path);
             // Call REST
             RestResponse batchRestResponse = callRest(path, params, clazz, method, action);
             batchNumResults = batchRestResponse.allResultsSize();

             if (finalRestResponse == null) {
                 finalRestResponse = batchRestResponse;
                 if (finalRestResponse.getEvents() == null) {
                     finalRestResponse.setEvents(new ArrayList<>());
                 }
                 if (finalRestResponse.first() == null) {
                     finalRestResponse.setResponses(Collections.singletonList(new OpenCGAResult<>()));
                     finalRestResponse.first().setResults(new ArrayList<>());
                 }
                 if (finalRestResponse.first().getEvents() == null) {
                     finalRestResponse.first().setEvents(new ArrayList<>());
                 }
             } else {
                 // Merge results
                 if (batchNumResults > 0) {
                     finalRestResponse.first().getResults().addAll(batchRestResponse.getResponses().get(0).getResults());
                     finalRestResponse.first().setNumResults(finalRestResponse.first().getResults().size());
                 }
                 if (batchRestResponse.getEvents() != null) {
                     finalRestResponse.getEvents().addAll(batchRestResponse.getEvents());
                 }
                 if (batchRestResponse.first().getEvents() != null) {
                     finalRestResponse.first().getEvents().addAll(batchRestResponse.first().getEvents());
                 }
             }

             skip += batchNumResults;
             finalNumResults += batchNumResults;
         } while (batchNumResults >= batchSize && finalNumResults < limit);
         return finalRestResponse;
     }

     private  RestResponse callRest(WebTarget path, ObjectMap params, Class clazz, String method, String action)
             throws ClientException {
         RestResponse batchRestResponse;
         switch (action) {
             case "upload":
                /* if (isFileUploadServlet(params)) {
                     batchRestResponse = uploadFile(path, params, clazz);
                 } else {
                     batchRestResponse = callUploadRest(path, params, clazz);
                 }*/
                 batchRestResponse = callUploadRest(path, params, clazz);
                 break;
             case "download":
                 String destinyPath = params.getString("OPENCGA_DESTINY");
                 params.remove("OPENCGA_DESTINY");
                 callRestDownload(path, params, destinyPath);
                 batchRestResponse = new RestResponse<>();
                 break;
             default:
                 batchRestResponse = callRest(path, params, clazz, method);
                 break;
         }
         return batchRestResponse;
     }

     private boolean isFileUploadServlet(ObjectMap params) {
         return params != null
                 && params.containsKey("uploadServlet")
                 && Boolean.parseBoolean(String.valueOf(params.get("uploadServlet")));
     }

     private void addCookies(Invocation.Builder builder) {
         if (clientConfiguration.getAttributes() != null) {
             Object cookies = clientConfiguration.getAttributes().get(COOKIES);
             if (cookies instanceof Map) {
                 Map cookiesMap = (Map) cookies;
                 for (Map.Entry entry : cookiesMap.entrySet()) {
                     try {
                         builder.cookie(new Cookie(entry.getKey(), entry.getValue(), "", clientConfiguration.getCurrentHost().getUrl()));
                     } catch (ClientException e) {
                         throw new RuntimeException(e);
                     }
                 }
             }
         }
     }

     /**
      * Call to WS using get or post method.
      *
      * @param path   Path of the WS.
      * @param params Params to be passed to the WS.
      * @param clazz  Expected return class.
      * @param method Method by which the query will be done (GET or POST).
      * @return A queryResponse object containing the results of the query.
      * @param  Any entity
      * @throws ClientException if the path is wrong and cannot be converted to a proper url.
      */
     protected  RestResponse callRest(WebTarget path, ObjectMap params, Class clazz, String method) throws ClientException {
         Response response;
         Invocation.Builder builder;
         switch (method) {
             case DELETE:
             case GET:
                 // TODO we still have to check the limit of the query, and keep querying while there are more results
                 if (params != null) {
                     for (String key : params.keySet()) {
                         path = path.queryParam(key, params.getString(key));
                     }
                 }

                 privateLogger.debug("{} URL: {}", method, path.getUri());
                 builder = path.request().header(HttpHeaders.AUTHORIZATION, "Bearer " + this.token);
                 addCookies(builder);
                 if (method.equals(GET)) {
                     response = builder.get();
                 } else {
                     response = builder.delete();
                 }
                 break;
             case POST:
                 if (params != null) {
                     for (String key : params.keySet()) {
                         if (!key.equals("body")) {
                             path = path.queryParam(key, params.getString(key));
                         }
                     }
                 }

                 Object paramBody = (params != null && params.get("body") != null) ? params.get("body") : "";
                 privateLogger.debug("{} URL: {}, Body {}", method, path.getUri(), paramBody);
                 builder = path.request().header(HttpHeaders.AUTHORIZATION, "Bearer " + this.token);
                 addCookies(builder);
                 response = builder.post(Entity.json(paramBody));
                 break;
             default:
                 throw new IllegalArgumentException("Unsupported REST method " + method);
         }
         RestResponse restResponse = parseResult(response, clazz);
         checkErrors(restResponse, response.getStatusInfo(), method, path);
         return restResponse;
     }

     /**
      * Call to download WS.
      *
      * @param path           Path of the WS.
      * @param params         Params to be passed to the WS.
      * @param outputFilePath Path where the file will be written (downloaded).
      */
     protected void callRestDownload(WebTarget path, Map params, String outputFilePath) {
         if (Files.isDirectory(Paths.get(outputFilePath))) {
             outputFilePath += ("/" + new File(path.getUri().getPath().replace(":", "/")).getParentFile().getName());
         } else if (Files.notExists(Paths.get(outputFilePath).getParent())) {
             throw new RuntimeException("Output directory " + outputFilePath + " not found");
         }

         if (params != null) {
             for (String s : params.keySet()) {
                 path = path.queryParam(s, params.get(s));
             }
         }

         Invocation.Builder builder = path.request().header(HttpHeaders.AUTHORIZATION, "Bearer " + this.token);
         addCookies(builder);
         Response response = builder.get();

         if (response.getStatus() == Response.Status.OK.getStatusCode()) {
             ReadableByteChannel readableByteChannel = Channels.newChannel(response.readEntity(InputStream.class));
             try {
                 FileOutputStream fileOutputStream = new FileOutputStream(outputFilePath);
                 fileOutputStream.getChannel().transferFrom(readableByteChannel, 0, Long.MAX_VALUE);
             } catch (IOException e) {
                 throw new RuntimeException("Could not write file to " + outputFilePath, e);
             }
         } else {
             throw new RuntimeException("HTTP call failed. Response code is " + response.getStatus() + ". Error reported is "
                     + response.getStatusInfo());
         }
     }

     /**
      * Call to upload WS.
      *
      * @param path   Path of the WS.
      * @param params Params to be passed to the WS.
      * @param clazz  Expected return class.
      * @return A queryResponse object containing the results of the query.
      * @param  Any entity
      * @throws ClientException if the path is wrong and cannot be converted to a proper url.
      */
     protected  RestResponse callUploadRest(WebTarget path, Map params, Class clazz) throws ClientException {
         String filePath = ((String) params.get("file"));
         params.remove("file");
         params.remove("body");

         path.property(ClientProperties.READ_TIMEOUT, DEFAULT_UPLOAD_TIMEOUT);
         client.property(ClientProperties.READ_TIMEOUT, DEFAULT_UPLOAD_TIMEOUT);
         path.register(MultiPartFeature.class);
         path.property(ClientProperties.REQUEST_ENTITY_PROCESSING, RequestEntityProcessing.CHUNKED);

         final FileDataBodyPart filePart = new FileDataBodyPart("file", new File(filePath));
         FormDataMultiPart formDataMultiPart = new FormDataMultiPart();
         // Add the rest of the parameters to the form
         for (Map.Entry stringObjectEntry : params.entrySet()) {
             formDataMultiPart.field(stringObjectEntry.getKey(), stringObjectEntry.getValue().toString());
         }
         final FormDataMultiPart multipart = (FormDataMultiPart) formDataMultiPart.bodyPart(filePart);

         privateLogger.debug(POST + " URL: {}", path.getUri());
         Invocation.Builder builder = path.request().header(HttpHeaders.AUTHORIZATION, "Bearer " + this.token);
         addCookies(builder);
         Response response = builder.post(Entity.entity(multipart, multipart.getMediaType()));
         RestResponse restResponse = parseResult(response, clazz);

         try {
             formDataMultiPart.close();
             multipart.close();
         } catch (IOException e) {
             throw new ClientException(e.getMessage(), e);
         }

         checkErrors(restResponse, response.getStatusInfo(), POST, path);
         return restResponse;
     }


   /*  public  RestResponse upload(WebTarget path, Map params, Class clazz) throws ClientException {

         RestResponse restResponse = null;
         try {
             Client client = ClientBuilder.newBuilder().build();
             client.register(MultiPartFeature.class);
             client.property(ClientProperties.REQUEST_ENTITY_PROCESSING,
                     RequestEntityProcessing.CHUNKED);
             // WebTarget target = client.target("http://myexample.com").path("/upload");
             Invocation.Builder builder = path.request();
             String filePath = ((String) params.get("file"));
             File binaryFile = new File(filePath);
             InputStream targetStream = new FileInputStream(binaryFile);
             FormDataMultiPart form = new FormDataMultiPart();
             form.bodyPart(new StreamDataBodyPart("file", targetStream, binaryFile.getName()));
             Response response = builder.header(HttpHeaders.AUTHORIZATION, "Bearer " + this.token)
                     .post(Entity.entity(form, form.getMediaType()));
             restResponse = parseResult(response, clazz);
         } catch (Exception e) {
             throw new ClientException(e.getMessage(), e);
         }
         return restResponse;
     }
*/

     /**
      * Call to upload WS.
      *
      * @param path   Path of the WS.
      * @param params Params to be passed to the WS.
      * @param clazz  Expected return class.
      * @return A queryResponse object containing the results of the query.
      * @throws ClientException if the path is wrong and cannot be converted to a proper url.
      */
     private  RestResponse uploadFile(WebTarget path, Map params, Class clazz) throws ClientException {

         String charset = "UTF-8";
         String boundary = Long.toHexString(System.currentTimeMillis()); // Just generate some unique random value.
         String br = "\r\n"; // Line separator required by multipart/form-data.
         String filePath = ((String) params.get("file"));
         File binaryFile = new File(filePath);
         String message = "";
         int responseCode = -1;
         if (!Files.exists(binaryFile.toPath())) {
             message = "File not found";
         } else {
             try {
                 URL url = new URL(path.getUri().toURL().toString().replace("/rest/", "/UploadFileServlet/"));
                 URLConnection connection = url.openConnection();
                 connection.setDoOutput(true);
                 connection.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);
                 connection.setRequestProperty("Authorization", "Bearer " + token);
                 for (String key : params.keySet()) {
                     connection.setRequestProperty(key, String.valueOf(params.get(key)));
                 }
                 OutputStream output = connection.getOutputStream();
                 StringBuilder buffer = new StringBuilder();
                 BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(output, charset));
                 getParams(params);
                 // Send binary file.
                 buffer.append("--" + boundary).append(br);
                 buffer.append("Content-Disposition: form-data; name=\"binaryFile\"; filename=\"" + binaryFile.getName() + "\"").append(br);
                 buffer.append("Content-Type: " + URLConnection.guessContentTypeFromName(binaryFile.getName())).append(br);
                 buffer.append("Content-Transfer-Encoding: binary").append(br);
                 buffer.append(br);
                 writer.append(buffer.toString()).flush();

                 Files.copy(binaryFile.toPath(), output);
                 output.flush(); // Important before continuing with writer!
                 writer.append(br).flush(); // CRLF is important! It indicates end of boundary.
                 // End of multipart/form-data.
                 writer.append("--" + boundary + "--").append(br).flush();
                 // Request is lazily fired whenever you need to obtain information about response.
                 responseCode = ((HttpURLConnection) connection).getResponseCode();
                 InputStream inputStream = connection.getInputStream();
                 message = new BufferedReader(
                         new InputStreamReader(inputStream, StandardCharsets.UTF_8))
                         .lines()
                         .collect(Collectors.joining("\n"));
                 //  message = "File upload result: " + message;
             } catch (Exception e) {
                 message = "OpenCga Connecting error";
             }
         }
         RestResponse restResponse = new RestResponse<>();
         Event event = new Event();
         event.setMessage(message);
         if (responseCode == 200) {
             event.setType(Event.Type.INFO);
             restResponse.setType(QueryType.VOID);
         } else {
             event.setMessage("ERROR :: " + message);
             event.setType(Event.Type.ERROR);
         }
         restResponse.setEvents(new ArrayList<>());
         restResponse.getEvents().add(event);
         return restResponse;
     }

     private String getParams(Map params) throws UnsupportedEncodingException {
         StringBuilder result = new StringBuilder();
         boolean first = true;

         for (String key : params.keySet()) {
             if (!key.equals("file")) {
                 if (first) {
                     first = false;
                 } else {
                     result.append("&");
                 }
                 result.append(URLEncoder.encode(key, "UTF-8"));
                 result.append("=");
                 result.append(URLEncoder.encode(params.get(key).toString(), "UTF-8"));
             }
         }

         return result.toString();
     }

     protected  RestResponse parseResult(Response response, Class clazz) throws ClientException {
         String json = response.readEntity(String.class);
         if (StringUtils.isNotEmpty(json) && json.startsWith("<")) {
             return new RestResponse<>("", 0, Collections.singletonList(
                     new Event(Event.Type.ERROR,
                             response.getStatusInfo().getStatusCode(),
                             response.getStatusInfo().getFamily().toString(),
                             response.getStatusInfo().getReasonPhrase())), null, Collections.emptyList());
         } else if (StringUtils.isNotEmpty(json)) {
             ObjectReader reader = jsonObjectMapper
                     .readerFor(jsonObjectMapper.getTypeFactory().constructParametrizedType(RestResponse.class, DataResult.class, clazz));
             try {
                 return reader.readValue(json);
             } catch (JsonParseException e) {
                 throw new ClientException(e.getMessage(), e);
             } catch (JsonProcessingException e) {
                 throw new ClientException(e.getMessage(), e);
             }
         } else {
             return new RestResponse<>();
         }
     }

     protected  void checkErrors(RestResponse restResponse, Response.StatusType status, String method, WebTarget path)
             throws ClientException {
         if (restResponse != null && restResponse.getEvents() != null) {
             for (Event event : restResponse.getEvents()) {
                 if (Event.Type.ERROR.equals(event.getType())) {
                     if (throwExceptionOnError) {
                         logger.debug("Server error '{}' on {} {}", event.getMessage(), method, path.getUri());
                         throw new ClientException("Got server error '" + event.getMessage() + "'");
                     } else {
                         privateLogger.debug("Server error '{}' on {} {}", event.getMessage(), method, path.getUri());
                     }
                 }
             }
         }

         if (!Response.Status.Family.SUCCESSFUL.equals(status.getFamily())) {
             String message = "Unsuccessful HTTP status " + status.getFamily() + ":" + status.getStatusCode()
                     + " '" + status.getReasonPhrase() + "'";
             if (restResponse != null && CollectionUtils.isNotEmpty(restResponse.getResponses())) {
                 OpenCGAResult result = restResponse.getResponses().get(0);
                 if (CollectionUtils.isNotEmpty(result.getEvents())) {
                     List msgs = new ArrayList<>();
                     for (Event event : result.getEvents()) {
                         if (Event.Type.ERROR.equals(event.getType())) {
                             msgs.add(event.getMessage());
                         }
                     }
                     if (!msgs.isEmpty()) {
                         message += " [" + StringUtils.join(msgs, ",") + "]";
                     }
                 }
             }
             if (throwExceptionOnError) {
                 throw new ClientException(message);

             } else {
                 privateLogger.debug(message);
             }
         }
     }

     public AbstractParentClient setToken(String token) {
         this.token = token;
         return this;
     }

 }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy