diff options
author | Jean-Baptiste Lievremont <jean-baptiste.lievremont@sonarsource.com> | 2015-06-01 12:13:46 +0200 |
---|---|---|
committer | Jean-Baptiste Lievremont <jean-baptiste.lievremont@sonarsource.com> | 2015-06-01 12:13:51 +0200 |
commit | ccb1bc6ac4dc9cfcb08ed1bb6625b1c2d3e4eebc (patch) | |
tree | f3fd0001674f315e89b3296d14233539c485120a /server | |
parent | 1822d25231ca4b7beb11a83ccd149143d7f54e26 (diff) | |
download | sonarqube-ccb1bc6ac4dc9cfcb08ed1bb6625b1c2d3e4eebc.tar.gz sonarqube-ccb1bc6ac4dc9cfcb08ed1bb6625b1c2d3e4eebc.zip |
SONAR-6465 Do not require admin permission, but display groups only when admin
Diffstat (limited to 'server')
3 files changed, 25 insertions, 29 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/user/ws/SearchAction.java b/server/sonar-server/src/main/java/org/sonar/server/user/ws/SearchAction.java index 311b31555e5..31de4ec6163 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/user/ws/SearchAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/user/ws/SearchAction.java @@ -67,7 +67,7 @@ public class SearchAction implements UsersWsAction { @Override public void define(WebService.NewController controller) { WebService.NewAction action = controller.createAction("search") - .setDescription("Get a list of active users. Requires Administer System permission.") + .setDescription("Get a list of active users. Administer System permission is required to show the 'groups' field.") .setSince("3.6") .setHandler(this) .setResponseExample(getClass().getResource("example-search.json")); @@ -81,8 +81,6 @@ public class SearchAction implements UsersWsAction { @Override public void handle(Request request, Response response) throws Exception { - userSession.checkLoggedIn().checkGlobalPermission(GlobalPermissions.SYSTEM_ADMIN); - SearchOptions options = new SearchOptions() .setPage(request.mandatoryParamAsInt(Param.PAGE), request.mandatoryParamAsInt(Param.PAGE_SIZE)); List<String> fields = request.paramAsStrings(Param.FIELDS); @@ -130,7 +128,7 @@ public class SearchAction implements UsersWsAction { } private void writeGroupsIfNeeded(JsonWriter json, Collection<String> groups, @Nullable List<String> fields) { - if (fieldIsWanted(FIELD_GROUPS, fields)) { + if (fieldIsWanted(FIELD_GROUPS, fields) && userSession.hasGlobalPermission(GlobalPermissions.SYSTEM_ADMIN)) { json.name(FIELD_GROUPS).beginArray(); for (String groupName : groups) { json.value(groupName); diff --git a/server/sonar-server/src/test/java/org/sonar/server/user/ws/SearchActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/user/ws/SearchActionTest.java index 85b5b575321..08f2bd4a802 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/user/ws/SearchActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/user/ws/SearchActionTest.java @@ -42,7 +42,6 @@ import org.sonar.core.user.UserDto; import org.sonar.core.user.UserGroupDto; import org.sonar.server.db.DbClient; import org.sonar.server.es.EsTester; -import org.sonar.server.exceptions.ForbiddenException; import org.sonar.server.tester.UserSessionRule; import org.sonar.server.user.db.GroupDao; import org.sonar.server.user.db.UserDao; @@ -101,7 +100,6 @@ public class SearchActionTest { @Test public void search_empty() throws Exception { - loginAsAdmin(); tester.newGetRequest("api/users", "search").execute().assertJson(getClass(), "empty.json"); } @@ -109,7 +107,6 @@ public class SearchActionTest { public void search_without_parameters() throws Exception { injectUsers(5); - loginAsAdmin(); tester.newGetRequest("api/users", "search").execute().assertJson(getClass(), "five_users.json"); } @@ -117,7 +114,6 @@ public class SearchActionTest { public void search_with_query() throws Exception { injectUsers(5); - loginAsAdmin(); tester.newGetRequest("api/users", "search").setParam("q", "user-1").execute().assertJson(getClass(), "user_one.json"); } @@ -125,7 +121,6 @@ public class SearchActionTest { public void search_with_paging() throws Exception { injectUsers(10); - loginAsAdmin(); tester.newGetRequest("api/users", "search").setParam(Param.PAGE_SIZE, "5").execute().assertJson(getClass(), "page_one.json"); tester.newGetRequest("api/users", "search").setParam(Param.PAGE_SIZE, "5").setParam(Param.PAGE, "2").execute().assertJson(getClass(), "page_two.json"); } @@ -134,21 +129,19 @@ public class SearchActionTest { public void search_with_fields() throws Exception { injectUsers(1); - loginAsAdmin(); - assertThat(tester.newGetRequest("api/users", "search").execute().outputAsString()) .contains("login") .contains("name") .contains("email") .contains("scmAccounts") - .contains("groups"); + .doesNotContain("groups"); assertThat(tester.newGetRequest("api/users", "search").setParam(Param.FIELDS, "").execute().outputAsString()) .contains("login") .contains("name") .contains("email") .contains("scmAccounts") - .contains("groups"); + .doesNotContain("groups"); assertThat(tester.newGetRequest("api/users", "search").setParam(Param.FIELDS, "login").execute().outputAsString()) .contains("login") @@ -169,6 +162,22 @@ public class SearchActionTest { .doesNotContain("name") .doesNotContain("email") .doesNotContain("scmAccounts") + .doesNotContain("groups"); + + loginAsAdmin(); + + assertThat(tester.newGetRequest("api/users", "search").execute().outputAsString()) + .contains("login") + .contains("name") + .contains("email") + .contains("scmAccounts") + .contains("groups"); + + assertThat(tester.newGetRequest("api/users", "search").setParam(Param.FIELDS, "groups").execute().outputAsString()) + .doesNotContain("login") + .doesNotContain("name") + .doesNotContain("email") + .doesNotContain("scmAccounts") .contains("groups"); } @@ -186,12 +195,6 @@ public class SearchActionTest { tester.newGetRequest("api/users", "search").execute().assertJson(getClass(), "user_with_groups.json"); } - @Test(expected = ForbiddenException.class) - public void fail_on_missing_permission() throws Exception { - userSession.login("not-admin"); - tester.newGetRequest("api/users", "search").execute(); - } - private List<UserDto> injectUsers(int numberOfUsers) throws Exception { List<UserDto> userDtos = Lists.newArrayList(); long createdAt = System.currentTimeMillis(); diff --git a/server/sonar-server/src/test/resources/org/sonar/server/user/ws/SearchActionTest/five_users.json b/server/sonar-server/src/test/resources/org/sonar/server/user/ws/SearchActionTest/five_users.json index 86b57c314ca..88a6fec9ecb 100644 --- a/server/sonar-server/src/test/resources/org/sonar/server/user/ws/SearchActionTest/five_users.json +++ b/server/sonar-server/src/test/resources/org/sonar/server/user/ws/SearchActionTest/five_users.json @@ -9,8 +9,7 @@ "email": "user-0@mail.com", "scmAccounts": [ "user-0" - ], - "groups": [] + ] }, { "login": "user-1", @@ -18,8 +17,7 @@ "email": "user-1@mail.com", "scmAccounts": [ "user-1" - ], - "groups": [] + ] }, { "login": "user-2", @@ -27,8 +25,7 @@ "email": "user-2@mail.com", "scmAccounts": [ "user-2" - ], - "groups": [] + ] }, { "login": "user-3", @@ -36,8 +33,7 @@ "email": "user-3@mail.com", "scmAccounts": [ "user-3" - ], - "groups": [] + ] }, { "login": "user-4", @@ -45,8 +41,7 @@ "email": "user-4@mail.com", "scmAccounts": [ "user-4" - ], - "groups": [] + ] } ] } |