From a3935607ecae26f8ede68d587fc4eec95c84a9c9 Mon Sep 17 00:00:00 2001 From: Julien Lancelot Date: Tue, 21 Feb 2017 16:01:54 +0100 Subject: SONAR-8790 Add last analysis date on api/components/search_projects WS --- .../org/sonarqube/ws/client/component/ComponentsService.java | 5 ++++- .../sonarqube/ws/client/component/SearchProjectsRequest.java | 12 ++++++++++++ 2 files changed, 16 insertions(+), 1 deletion(-) (limited to 'sonar-ws/src/main') diff --git a/sonar-ws/src/main/java/org/sonarqube/ws/client/component/ComponentsService.java b/sonar-ws/src/main/java/org/sonarqube/ws/client/component/ComponentsService.java index fd382d321a6..5a4817ddc1d 100644 --- a/sonar-ws/src/main/java/org/sonarqube/ws/client/component/ComponentsService.java +++ b/sonar-ws/src/main/java/org/sonarqube/ws/client/component/ComponentsService.java @@ -20,6 +20,7 @@ package org.sonarqube.ws.client.component; import com.google.common.base.Joiner; +import java.util.List; import org.sonarqube.ws.WsComponents.BulkUpdateKeyWsResponse; import org.sonarqube.ws.WsComponents.SearchProjectsWsResponse; import org.sonarqube.ws.WsComponents.SearchWsResponse; @@ -106,6 +107,7 @@ public class ComponentsService extends BaseService { } public SearchProjectsWsResponse searchProjects(SearchProjectsRequest request) { + List additionalFields = request.getAdditionalFields(); GetRequest get = new GetRequest(path(ACTION_SEARCH_PROJECTS)) .setParam(PARAM_ORGANIZATION, request.getOrganization()) .setParam(PARAM_FILTER, request.getFilter()) @@ -113,7 +115,8 @@ public class ComponentsService extends BaseService { .setParam(Param.SORT, request.getSort()) .setParam(Param.ASCENDING, request.getAsc()) .setParam(Param.PAGE, request.getPage()) - .setParam(Param.PAGE_SIZE, request.getPageSize()); + .setParam(Param.PAGE_SIZE, request.getPageSize()) + .setParam(Param.FIELDS, !additionalFields.isEmpty() ? inlineMultipleParamValue(additionalFields) : null); return call(get, SearchProjectsWsResponse.parser()); } } diff --git a/sonar-ws/src/main/java/org/sonarqube/ws/client/component/SearchProjectsRequest.java b/sonar-ws/src/main/java/org/sonarqube/ws/client/component/SearchProjectsRequest.java index f6d9e359645..a2e249a866b 100644 --- a/sonar-ws/src/main/java/org/sonarqube/ws/client/component/SearchProjectsRequest.java +++ b/sonar-ws/src/main/java/org/sonarqube/ws/client/component/SearchProjectsRequest.java @@ -39,6 +39,7 @@ public class SearchProjectsRequest { private final List facets; private final String sort; private final Boolean asc; + private final List additionalFields; private SearchProjectsRequest(Builder builder) { this.page = builder.page; @@ -48,6 +49,7 @@ public class SearchProjectsRequest { this.facets = builder.facets; this.sort = builder.sort; this.asc = builder.asc; + this.additionalFields = builder.additionalFields; } @CheckForNull @@ -82,6 +84,10 @@ public class SearchProjectsRequest { return asc; } + public List getAdditionalFields() { + return additionalFields; + } + public static Builder builder() { return new Builder(); } @@ -94,6 +100,7 @@ public class SearchProjectsRequest { private List facets = new ArrayList<>(); private String sort; private Boolean asc; + private List additionalFields = new ArrayList<>(); private Builder() { // enforce static factory method @@ -134,6 +141,11 @@ public class SearchProjectsRequest { return this; } + public Builder setAdditionalFields(List additionalFields) { + this.additionalFields = requireNonNull(additionalFields, "additional fields cannot be null"); + return this; + } + public SearchProjectsRequest build() { if (page == null) { page = 1; -- cgit v1.2.3