You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

RequestValidator.java 4.1KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2019 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.permission.ws;
  21. import com.google.common.base.Joiner;
  22. import java.util.Set;
  23. import java.util.regex.Pattern;
  24. import java.util.regex.PatternSyntaxException;
  25. import java.util.stream.Collectors;
  26. import javax.annotation.Nullable;
  27. import org.sonar.api.resources.ResourceType;
  28. import org.sonar.api.resources.ResourceTypes;
  29. import org.sonar.core.permission.GlobalPermissions;
  30. import org.sonar.server.exceptions.BadRequestException;
  31. import org.sonar.server.permission.PermissionService;
  32. import org.sonar.server.usergroups.ws.GroupIdOrAnyone;
  33. import org.sonar.server.ws.WsUtils;
  34. import static com.google.common.base.Strings.isNullOrEmpty;
  35. import static java.lang.String.format;
  36. import static org.sonar.server.ws.WsUtils.checkRequest;
  37. import static org.sonarqube.ws.client.permission.PermissionsWsParameters.PARAM_PERMISSION;
  38. import static org.sonarqube.ws.client.permission.PermissionsWsParameters.PARAM_PROJECT_KEY_PATTERN;
  39. import static org.sonarqube.ws.client.permission.PermissionsWsParameters.PARAM_QUALIFIER;
  40. public class RequestValidator {
  41. public static final String MSG_TEMPLATE_WITH_SAME_NAME = "A template with the name '%s' already exists (case insensitive).";
  42. private final PermissionService permissionService;
  43. private final String allProjectsPermissionsOnOneLine;
  44. public RequestValidator(PermissionService permissionService) {
  45. this.permissionService = permissionService;
  46. allProjectsPermissionsOnOneLine = Joiner.on(", ").join(permissionService.getAllProjectPermissions());
  47. }
  48. public String validateProjectPermission(String permission) {
  49. WsUtils.checkRequest(permissionService.getAllProjectPermissions().contains(permission),
  50. String.format("The '%s' parameter for project permissions must be one of %s. '%s' was passed.", PARAM_PERMISSION,
  51. allProjectsPermissionsOnOneLine, permission));
  52. return permission;
  53. }
  54. public static void validateGlobalPermission(String permission) {
  55. checkRequest(GlobalPermissions.ALL.contains(permission),
  56. format("The '%s' parameter for global permissions must be one of %s. '%s' was passed.", PARAM_PERMISSION, GlobalPermissions.ALL_ON_ONE_LINE, permission));
  57. }
  58. public static void validateNotAnyoneAndAdminPermission(String permission, GroupIdOrAnyone group) {
  59. checkRequest(!GlobalPermissions.SYSTEM_ADMIN.equals(permission) || !group.isAnyone(),
  60. format("It is not possible to add the '%s' permission to group 'Anyone'.", permission));
  61. }
  62. public static void validateQualifier(@Nullable String qualifier, ResourceTypes resourceTypes) {
  63. if (qualifier == null) {
  64. return;
  65. }
  66. Set<String> rootQualifiers = resourceTypes.getRoots().stream()
  67. .map(ResourceType::getQualifier)
  68. .collect(Collectors.toSet());
  69. checkRequest(rootQualifiers.contains(qualifier),
  70. format("The '%s' parameter must be one of %s. '%s' was passed.", PARAM_QUALIFIER, rootQualifiers, qualifier));
  71. }
  72. public static void validateProjectPattern(@Nullable String projectPattern) {
  73. if (isNullOrEmpty(projectPattern)) {
  74. return;
  75. }
  76. try {
  77. Pattern.compile(projectPattern);
  78. } catch (PatternSyntaxException e) {
  79. throw BadRequestException.create(format("The '%s' parameter must be a valid Java regular expression. '%s' was passed", PARAM_PROJECT_KEY_PATTERN, projectPattern));
  80. }
  81. }
  82. }