Nelze vybrat více než 25 témat Téma musí začínat písmenem nebo číslem, může obsahovat pomlčky („-“) a může být dlouhé až 35 znaků.

UsersAction.java 6.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2023 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.server.usergroups.ws;
  21. import java.util.List;
  22. import java.util.Map;
  23. import java.util.Set;
  24. import org.sonar.api.server.ws.Change;
  25. import org.sonar.api.server.ws.Request;
  26. import org.sonar.api.server.ws.Response;
  27. import org.sonar.api.server.ws.WebService.NewAction;
  28. import org.sonar.api.server.ws.WebService.NewController;
  29. import org.sonar.api.server.ws.WebService.Param;
  30. import org.sonar.api.server.ws.WebService.SelectionMode;
  31. import org.sonar.api.utils.Paging;
  32. import org.sonar.api.utils.text.JsonWriter;
  33. import org.sonar.db.DbClient;
  34. import org.sonar.db.DbSession;
  35. import org.sonar.db.permission.GlobalPermission;
  36. import org.sonar.db.user.UserMembershipDto;
  37. import org.sonar.db.user.UserMembershipQuery;
  38. import org.sonar.server.management.ManagedInstanceService;
  39. import org.sonar.server.permission.GroupUuid;
  40. import org.sonar.server.user.UserSession;
  41. import static java.lang.Boolean.TRUE;
  42. import static java.util.stream.Collectors.toSet;
  43. import static org.sonar.api.utils.Paging.forPageIndex;
  44. import static org.sonar.server.usergroups.ws.GroupWsSupport.defineGroupWsParameters;
  45. public class UsersAction implements UserGroupsWsAction {
  46. private static final String FIELD_SELECTED = "selected";
  47. private static final String FIELD_NAME = "name";
  48. private static final String FIELD_LOGIN = "login";
  49. private static final String FIELD_MANAGED = "managed";
  50. private final DbClient dbClient;
  51. private final UserSession userSession;
  52. private final ManagedInstanceService managedInstanceService;
  53. private final GroupWsSupport support;
  54. public UsersAction(DbClient dbClient, UserSession userSession, ManagedInstanceService managedInstanceService, GroupWsSupport support) {
  55. this.dbClient = dbClient;
  56. this.userSession = userSession;
  57. this.managedInstanceService = managedInstanceService;
  58. this.support = support;
  59. }
  60. @Override
  61. public void define(NewController context) {
  62. NewAction action = context.createAction("users")
  63. .setDescription("Search for users with membership information with respect to a group.<br>" +
  64. "Requires the following permission: 'Administer System'.")
  65. .setHandler(this)
  66. .setSince("5.2")
  67. .setResponseExample(getClass().getResource("users-example.json"))
  68. .addSelectionModeParam()
  69. .addSearchQuery("freddy", "names", "logins")
  70. .addPagingParams(25)
  71. .setChangelog(
  72. new Change("10.0", "Field 'managed' added to the payload."),
  73. new Change("10.0", "Parameter 'id' is removed. Use 'name' instead."),
  74. new Change("9.8", "response fields 'total', 's', 'ps' have been deprecated, please use 'paging' object instead."),
  75. new Change("9.8", "The field 'paging' has been added to the response."),
  76. new Change("8.4", "Parameter 'id' is deprecated. Format changes from integer to string. Use 'name' instead."));
  77. defineGroupWsParameters(action);
  78. }
  79. @Override
  80. public void handle(Request request, Response response) throws Exception {
  81. int pageSize = request.mandatoryParamAsInt(Param.PAGE_SIZE);
  82. int page = request.mandatoryParamAsInt(Param.PAGE);
  83. String queryString = request.param(Param.TEXT_QUERY);
  84. String selected = request.mandatoryParam(Param.SELECTED);
  85. try (DbSession dbSession = dbClient.openSession(false)) {
  86. GroupUuid group = support.findGroup(dbSession, request);
  87. userSession.checkPermission(GlobalPermission.ADMINISTER);
  88. UserMembershipQuery query = UserMembershipQuery.builder()
  89. .groupUuid(group.getUuid())
  90. .memberSearch(queryString)
  91. .membership(getMembership(selected))
  92. .pageIndex(page)
  93. .pageSize(pageSize)
  94. .build();
  95. int total = dbClient.groupMembershipDao().countMembers(dbSession, query);
  96. Paging paging = forPageIndex(page).withPageSize(pageSize).andTotal(total);
  97. List<UserMembershipDto> users = dbClient.groupMembershipDao().selectMembers(dbSession, query, paging.offset(), paging.pageSize());
  98. Map<String, Boolean> userUuidToIsManaged = managedInstanceService.getUserUuidToManaged(dbSession, getUserUuids(users));
  99. try (JsonWriter json = response.newJsonWriter()) {
  100. json.beginObject();
  101. writeMembers(json, users, userUuidToIsManaged);
  102. writePaging(json, paging);
  103. json.name("paging").beginObject()
  104. .prop("pageIndex", page)
  105. .prop("pageSize", pageSize)
  106. .prop("total", total)
  107. .endObject();
  108. json.endObject();
  109. }
  110. }
  111. }
  112. private static Set<String> getUserUuids(List<UserMembershipDto> users) {
  113. return users.stream().map(UserMembershipDto::getUuid).collect(toSet());
  114. }
  115. private static void writeMembers(JsonWriter json, List<UserMembershipDto> users, Map<String, Boolean> userUuidToIsManaged) {
  116. json.name("users").beginArray();
  117. for (UserMembershipDto user : users) {
  118. json.beginObject()
  119. .prop(FIELD_LOGIN, user.getLogin())
  120. .prop(FIELD_NAME, user.getName())
  121. .prop(FIELD_SELECTED, user.getGroupUuid() != null)
  122. .prop(FIELD_MANAGED, TRUE.equals(userUuidToIsManaged.get(user.getUuid())))
  123. .endObject();
  124. }
  125. json.endArray();
  126. }
  127. /**
  128. * @deprecated since 9.8 - replaced by 'paging' object structure.
  129. */
  130. @Deprecated(since = "9.8")
  131. private static void writePaging(JsonWriter json, Paging paging) {
  132. json.prop(Param.PAGE, paging.pageIndex())
  133. .prop(Param.PAGE_SIZE, paging.pageSize())
  134. .prop("total", paging.total());
  135. }
  136. private static String getMembership(String selected) {
  137. SelectionMode selectionMode = SelectionMode.fromParam(selected);
  138. String membership = UserMembershipQuery.ANY;
  139. if (SelectionMode.SELECTED == selectionMode) {
  140. membership = UserMembershipQuery.IN;
  141. } else if (SelectionMode.DESELECTED == selectionMode) {
  142. membership = UserMembershipQuery.OUT;
  143. }
  144. return membership;
  145. }
  146. }