diff options
author | Stas Vilchik <vilchiks@gmail.com> | 2017-02-20 10:56:59 +0100 |
---|---|---|
committer | Stas Vilchik <vilchiks@gmail.com> | 2017-02-20 10:56:59 +0100 |
commit | 297243e70a3ed48eb281a0a1e5ea00813f61eb40 (patch) | |
tree | 329b2c0563967d34950f3cb96b3fba965bb3f0b0 | |
parent | eb916d198dc3590c3d38647b3488edac4e1e27a7 (diff) | |
download | sonarqube-297243e70a3ed48eb281a0a1e5ea00813f61eb40.tar.gz sonarqube-297243e70a3ed48eb281a0a1e5ea00813f61eb40.zip |
return `isDefault` in /api/navigation/organization
-rw-r--r-- | server/sonar-server/src/main/java/org/sonar/server/ui/ws/OrganizationAction.java | 6 | ||||
-rw-r--r-- | server/sonar-server/src/test/java/org/sonar/server/ui/ws/OrganizationActionTest.java | 5 |
2 files changed, 9 insertions, 2 deletions
diff --git a/server/sonar-server/src/main/java/org/sonar/server/ui/ws/OrganizationAction.java b/server/sonar-server/src/main/java/org/sonar/server/ui/ws/OrganizationAction.java index 47cc9146e5c..2b66b7b9eb3 100644 --- a/server/sonar-server/src/main/java/org/sonar/server/ui/ws/OrganizationAction.java +++ b/server/sonar-server/src/main/java/org/sonar/server/ui/ws/OrganizationAction.java @@ -27,6 +27,7 @@ import org.sonar.core.permission.GlobalPermissions; import org.sonar.db.DbClient; import org.sonar.db.DbSession; import org.sonar.db.organization.OrganizationDto; +import org.sonar.server.organization.DefaultOrganizationProvider; import org.sonar.server.user.UserSession; import static org.sonar.core.permission.GlobalPermissions.SYSTEM_ADMIN; @@ -38,10 +39,12 @@ public class OrganizationAction implements NavigationWsAction { private static final String PARAM_ORGANIZATION = "organization"; private final DbClient dbClient; + private final DefaultOrganizationProvider defaultOrganizationProvider; private final UserSession userSession; - public OrganizationAction(DbClient dbClient, UserSession userSession) { + public OrganizationAction(DbClient dbClient, DefaultOrganizationProvider defaultOrganizationProvider, UserSession userSession) { this.dbClient = dbClient; + this.defaultOrganizationProvider = defaultOrganizationProvider; this.userSession = userSession; } @@ -83,6 +86,7 @@ public class OrganizationAction implements NavigationWsAction { .prop("canAdmin", userSession.hasOrganizationPermission(organizationUuid, SYSTEM_ADMIN)) .prop("canProvisionProjects", userSession.hasOrganizationPermission(organizationUuid, GlobalPermissions.PROVISIONING)) .prop("canDelete", organization.isGuarded() ? userSession.isSystemAdministrator() : userSession.hasOrganizationPermission(organizationUuid, SYSTEM_ADMIN)) + .prop("isDefault", organization.getKey().equals(defaultOrganizationProvider.get().getKey())) .endObject(); } } diff --git a/server/sonar-server/src/test/java/org/sonar/server/ui/ws/OrganizationActionTest.java b/server/sonar-server/src/test/java/org/sonar/server/ui/ws/OrganizationActionTest.java index 47193174de5..46174db1ace 100644 --- a/server/sonar-server/src/test/java/org/sonar/server/ui/ws/OrganizationActionTest.java +++ b/server/sonar-server/src/test/java/org/sonar/server/ui/ws/OrganizationActionTest.java @@ -28,6 +28,8 @@ import org.sonar.api.utils.System2; import org.sonar.db.DbClient; import org.sonar.db.DbTester; import org.sonar.db.organization.OrganizationDto; +import org.sonar.server.organization.DefaultOrganizationProvider; +import org.sonar.server.organization.TestDefaultOrganizationProvider; import org.sonar.server.tester.UserSessionRule; import org.sonar.server.ws.TestRequest; import org.sonar.server.ws.TestResponse; @@ -46,8 +48,9 @@ public class OrganizationActionTest { public ExpectedException expectedException = ExpectedException.none(); private DbClient dbClient = dbTester.getDbClient(); + private DefaultOrganizationProvider defaultOrganizationProvider = TestDefaultOrganizationProvider.from(dbTester); - private WsActionTester underTest = new WsActionTester(new OrganizationAction(dbClient, userSession)); + private WsActionTester underTest = new WsActionTester(new OrganizationAction(dbClient, defaultOrganizationProvider, userSession)); @Test public void verify_definition() { |