diff options
author | Duarte Meneses <duarte.meneses@sonarsource.com> | 2020-10-14 16:43:30 -0500 |
---|---|---|
committer | sonartech <sonartech@sonarsource.com> | 2020-11-28 20:06:15 +0000 |
commit | 37587a03da2ea2289e2c2c6b0ca213e8274fe5c7 (patch) | |
tree | 3968c8afe017835b1f5853a1ba3b63882f056713 /server/sonar-db-dao/src/main/java/org/sonar | |
parent | e24f1b14536dc7268d03495f6ef281698ff09184 (diff) | |
download | sonarqube-37587a03da2ea2289e2c2c6b0ca213e8274fe5c7.tar.gz sonarqube-37587a03da2ea2289e2c2c6b0ca213e8274fe5c7.zip |
SONAR-14033 Refactor storage of applications
Diffstat (limited to 'server/sonar-db-dao/src/main/java/org/sonar')
15 files changed, 270 insertions, 8 deletions
diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/DaoModule.java b/server/sonar-db-dao/src/main/java/org/sonar/db/DaoModule.java index 205d02d18e2..a76ef07ffc6 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/DaoModule.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/DaoModule.java @@ -35,6 +35,7 @@ import org.sonar.db.ce.CeTaskCharacteristicDao; import org.sonar.db.ce.CeTaskInputDao; import org.sonar.db.ce.CeTaskMessageDao; import org.sonar.db.component.AnalysisPropertiesDao; +import org.sonar.db.component.ApplicationProjectsDao; import org.sonar.db.component.BranchDao; import org.sonar.db.component.ComponentDao; import org.sonar.db.component.ComponentKeyUpdaterDao; @@ -101,6 +102,7 @@ public class DaoModule extends Module { ActiveRuleDao.class, AnalysisPropertiesDao.class, AuthorizationDao.class, + ApplicationProjectsDao.class, BranchDao.class, CeActivityDao.class, CeQueueDao.class, diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/DbClient.java b/server/sonar-db-dao/src/main/java/org/sonar/db/DbClient.java index 78d717373ed..bd6c3c878d6 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/DbClient.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/DbClient.java @@ -33,6 +33,7 @@ import org.sonar.db.ce.CeTaskCharacteristicDao; import org.sonar.db.ce.CeTaskInputDao; import org.sonar.db.ce.CeTaskMessageDao; import org.sonar.db.component.AnalysisPropertiesDao; +import org.sonar.db.component.ApplicationProjectsDao; import org.sonar.db.component.BranchDao; import org.sonar.db.component.ComponentDao; import org.sonar.db.component.ComponentKeyUpdaterDao; @@ -166,6 +167,7 @@ public class DbClient { private final SessionTokensDao sessionTokensDao; private final SamlMessageIdDao samlMessageIdDao; private final UserDismissedMessagesDao userDismissedMessagesDao; + private final ApplicationProjectsDao applicationProjectsDao; public DbClient(Database database, MyBatis myBatis, DBSessions dbSessions, Dao... daos) { this.database = database; @@ -245,6 +247,7 @@ public class DbClient { sessionTokensDao = getDao(map, SessionTokensDao.class); samlMessageIdDao = getDao(map, SamlMessageIdDao.class); userDismissedMessagesDao = getDao(map, UserDismissedMessagesDao.class); + applicationProjectsDao = getDao(map, ApplicationProjectsDao.class); } public DbSession openSession(boolean batch) { @@ -267,6 +270,10 @@ public class DbClient { return almPatDao; } + public ApplicationProjectsDao applicationProjectsDao() { + return applicationProjectsDao; + } + public ProjectAlmSettingDao projectAlmSettingDao() { return projectAlmSettingDao; } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java b/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java index 8c1f4a3b487..77205277bb5 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/MyBatis.java @@ -47,6 +47,7 @@ import org.sonar.db.ce.CeTaskCharacteristicMapper; import org.sonar.db.ce.CeTaskInputMapper; import org.sonar.db.ce.CeTaskMessageMapper; import org.sonar.db.component.AnalysisPropertiesMapper; +import org.sonar.db.component.ApplicationProjectsMapper; import org.sonar.db.component.BranchMapper; import org.sonar.db.component.ComponentDto; import org.sonar.db.component.ComponentDtoWithSnapshotId; @@ -231,6 +232,7 @@ public class MyBatis implements Startable { AlmPatMapper.class, AlmSettingMapper.class, AnalysisPropertiesMapper.class, + ApplicationProjectsMapper.class, AuthorizationMapper.class, BranchMapper.class, CeActivityMapper.class, diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsDao.java new file mode 100644 index 00000000000..713d67dd5dd --- /dev/null +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsDao.java @@ -0,0 +1,108 @@ +/* + * SonarQube + * Copyright (C) 2009-2020 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.db.component; + +import java.util.Collection; +import java.util.Set; +import org.sonar.api.utils.System2; +import org.sonar.core.util.UuidFactory; +import org.sonar.db.Dao; +import org.sonar.db.DbSession; +import org.sonar.db.project.ProjectDto; + +public class ApplicationProjectsDao implements Dao { + private final System2 system2; + private final UuidFactory uuidFactory; + + public ApplicationProjectsDao(System2 system2, UuidFactory uuidFactory) { + this.system2 = system2; + this.uuidFactory = uuidFactory; + } + + public void addProject(DbSession dbSession, String applicationUuid, String projectUuid) { + getMapper(dbSession).addProject(uuidFactory.create(), applicationUuid, projectUuid, system2.now()); + } + + public void removeApplicationProjectsByApplicationAndProject(DbSession dbSession, String applicationUuid, String projectUuid) { + getMapper(dbSession).removeApplicationBranchProjectBranchesByApplicationAndProject(applicationUuid, projectUuid); + getMapper(dbSession).removeApplicationProjectsByApplicationAndProject(applicationUuid, projectUuid); + } + + public int countApplicationProjects(DbSession dbSession, String applicationUuid) { + return getMapper(dbSession).countApplicationProjects(applicationUuid); + } + + public Set<ProjectDto> selectProjects(DbSession dbSession, String applicationUuid) { + return getMapper(dbSession).selectProjects(applicationUuid); + } + + public void remove(DbSession dbSession, String applicationUuid) { + getMapper(dbSession).removeApplicationBranchProjectBranchesByApplication(applicationUuid); + getMapper(dbSession).removeApplicationProjectsByApplication(applicationUuid); + } + + public void addProjectBranchToAppBranch(DbSession dbSession, BranchDto applicationBranch, BranchDto projectBranch) { + getMapper(dbSession).addProjectBranchToAppBranch( + uuidFactory.create(), + applicationBranch.getProjectUuid(), + applicationBranch.getUuid(), + projectBranch.getProjectUuid(), + projectBranch.getUuid(), + system2.now()); + } + + public void addProjectBranchToAppBranch(DbSession dbSession, String applicationUuid, String applicationBranchUuid, String projectUuid, String projectBranchUuid) { + getMapper(dbSession).addProjectBranchToAppBranch( + uuidFactory.create(), + applicationUuid, + applicationBranchUuid, + projectUuid, + projectBranchUuid, + system2.now()); + } + + public void removeProjectBranchFromAppBranch(DbSession dbSession, String applicationBranchUuid, String projectBranchUuid) { + getMapper(dbSession).removeProjectBranchFromAppBranch(applicationBranchUuid, projectBranchUuid); + } + + public Set<BranchDto> selectProjectBranchesFromAppBranch(DbSession dbSession, String applicationBranchUuid) { + return getMapper(dbSession).selectProjectBranchesFromAppBranch(applicationBranchUuid); + } + + public Set<ProjectDto> selectApplicationsFromProjectBranch(DbSession dbSession, String projectUuid, String branchKey) { + return getMapper(dbSession).selectApplicationsFromProjectBranch(projectUuid, branchKey); + } + + public Set<ProjectDto> selectApplicationsFromProjects(DbSession dbSession, Collection<String> projectUuids) { + return getMapper(dbSession).selectApplicationsFromProjects(projectUuids); + } + + private static ApplicationProjectsMapper getMapper(DbSession session) { + return session.getMapper(ApplicationProjectsMapper.class); + } + + public void updateApplicationBranchName(DbSession dbSession, String applicationBranchUuid, String newName) { + getMapper(dbSession).updateApplicationBranchName(applicationBranchUuid, newName); + } + + public void removeAllProjectBranchesOfAppBranch(DbSession dbSession, String applicationBranchUuid) { + getMapper(dbSession).removeAllProjectBranchesOfAppBranch(applicationBranchUuid); + } +} diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsMapper.java new file mode 100644 index 00000000000..a45cb6529bc --- /dev/null +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/ApplicationProjectsMapper.java @@ -0,0 +1,69 @@ +/* + * SonarQube + * Copyright (C) 2009-2020 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.db.component; + +import java.util.Collection; +import java.util.Set; +import org.apache.ibatis.annotations.Param; +import org.sonar.db.project.ProjectDto; + +public interface ApplicationProjectsMapper { + void addProject( + @Param("uuid") String uuid, + @Param("applicationUuid") String applicationUuid, + @Param("projectUuid") String projectUuid, + @Param("now") long now); + + void removeApplicationBranchProjectBranchesByApplicationAndProject( + @Param("applicationUuid") String applicationUuid, + @Param("projectUuid") String projectUuid); + + void removeApplicationProjectsByApplicationAndProject( + @Param("applicationUuid") String applicationUuid, + @Param("projectUuid") String projectUuid); + + Set<ProjectDto> selectProjects(@Param("applicationUuid") String applicationUuid); + + void removeApplicationProjectsByApplication(String applicationUuid); + + void removeApplicationBranchProjectBranchesByApplication(String applicationUuid); + + void addProjectBranchToAppBranch( + @Param("uuid") String uuid, + @Param("applicationUuid") String applicationUuid, + @Param("applicationBranchUuid") String applicationBranchUuid, + @Param("projectUuid") String projectUuid, + @Param("projectBranchUuid") String projectBranchUuid, + @Param("now") long now); + + void removeProjectBranchFromAppBranch(@Param("applicationBranchUuid") String applicationBranchUuid, @Param("projectBranchUuid") String projectBranchUuid); + + Set<BranchDto> selectProjectBranchesFromAppBranch(@Param("applicationBranchUuid") String applicationBranchUuid); + + int countApplicationProjects(@Param("applicationUuid") String applicationUuid); + + void updateApplicationBranchName(@Param("uuid") String uuid, @Param("newName") String newName); + + Set<ProjectDto> selectApplicationsFromProjectBranch(@Param("projectUuid") String projectUuid, @Param("branchKey") String branchKey); + + Set<ProjectDto> selectApplicationsFromProjects(@Param("projectUuids") Collection<String> projectUuids); + + void removeAllProjectBranchesOfAppBranch(@Param("applicationBranchUuid") String applicationBranchUuid); +} diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchDao.java index eea97147e49..3abeac13c01 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchDao.java @@ -20,7 +20,6 @@ package org.sonar.db.component; import java.util.Collection; -import java.util.Collections; import java.util.LinkedList; import java.util.List; import java.util.Map; @@ -30,6 +29,7 @@ import org.sonar.db.Dao; import org.sonar.db.DbSession; import org.sonar.db.project.ProjectDto; +import static java.util.Collections.emptyList; import static org.sonar.db.DatabaseUtils.executeLargeInputs; public class BranchDao implements Dao { @@ -68,7 +68,7 @@ public class BranchDao implements Dao { public List<BranchDto> selectByBranchKeys(DbSession dbSession, Map<String, String> branchKeyByProjectUuid) { if (branchKeyByProjectUuid.isEmpty()) { - return Collections.emptyList(); + return emptyList(); } return mapper(dbSession).selectByBranchKeys(branchKeyByProjectUuid); } @@ -94,6 +94,9 @@ public class BranchDao implements Dao { } public List<BranchDto> selectByUuids(DbSession session, Collection<String> uuids) { + if (uuids.isEmpty()) { + return emptyList(); + } return executeLargeInputs(uuids, mapper(session)::selectByUuids); } @@ -103,7 +106,7 @@ public class BranchDao implements Dao { public List<String> selectProjectUuidsWithIssuesNeedSync(DbSession session, Collection<String> uuids) { if (uuids.isEmpty()) { - return Collections.emptyList(); + return emptyList(); } return executeLargeInputs(uuids, mapper(session)::selectProjectUuidsWithIssuesNeedSync); @@ -146,6 +149,10 @@ public class BranchDao implements Dao { return mapper(dbSession).updateNeedIssueSync(branchUuid, needIssueSync, now); } + public void deleteBranch(DbSession dbSession, String projectUuid, String branchKey) { + mapper(dbSession).deleteBranch(projectUuid, branchKey); + } + public boolean doAnyOfComponentsNeedIssueSync(DbSession session, List<String> components) { if (!components.isEmpty()) { List<Boolean> result = new LinkedList<>(); diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchMapper.java index c44507015fd..db9667426f7 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchMapper.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/BranchMapper.java @@ -68,4 +68,5 @@ public interface BranchMapper { short doAnyOfComponentsNeedIssueSync(@Param("componentKeys") List<String> components); + void deleteBranch(@Param("projectUuid") String projectUuid, @Param("branchKey") String branchKey); } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/SelectionMode.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/SelectionMode.java new file mode 100644 index 00000000000..6a636de8542 --- /dev/null +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/SelectionMode.java @@ -0,0 +1,27 @@ +/* + * SonarQube + * Copyright (C) 2009-2020 SonarSource SA + * mailto:info AT sonarsource DOT com + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 3 of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ +package org.sonar.db.component; + +public enum SelectionMode { + MANUAL_MEASURE, + REGEXP, + TAGS, + REMAINING_PROJECTS +} diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/component/SnapshotDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/component/SnapshotDao.java index f70760d6541..0f62ef98e7d 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/component/SnapshotDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/component/SnapshotDao.java @@ -34,7 +34,6 @@ import org.sonar.db.Dao; import org.sonar.db.DbSession; import static com.google.common.base.Preconditions.checkArgument; -import static com.google.common.collect.FluentIterable.from; import static java.util.Objects.requireNonNull; import static org.sonar.db.DatabaseUtils.executeLargeInputs; @@ -125,9 +124,7 @@ public class SnapshotDao implements Dao { */ @CheckForNull public ViewsSnapshotDto selectSnapshotBefore(String componentUuid, long date, DbSession dbSession) { - return from(mapper(dbSession).selectSnapshotBefore(componentUuid, date)) - .first() - .orNull(); + return mapper(dbSession).selectSnapshotBefore(componentUuid, date).stream().findFirst().orElse(null); } private static SnapshotMapper mapper(DbSession session) { diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDao.java index 46dd8218e9a..8d2509cf449 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDao.java @@ -50,6 +50,10 @@ public class ProjectDao implements Dao { return Optional.ofNullable(mapper(session).selectProjectOrAppByKey(key)); } + public List<ProjectDto> selectAllApplications(DbSession session){ + return mapper(session).selectAllApplications(); + } + public List<ProjectDto> selectProjectsByKeys(DbSession session, Set<String> keys) { if (keys.isEmpty()) { return Collections.emptyList(); @@ -57,6 +61,13 @@ public class ProjectDao implements Dao { return mapper(session).selectProjectsByKeys(keys); } + public List<ProjectDto> selectApplicationsByKeys(DbSession session, Set<String> keys) { + if (keys.isEmpty()) { + return Collections.emptyList(); + } + return mapper(session).selectApplicationsByKeys(keys); + } + public List<ProjectDto> selectProjects(DbSession session) { return mapper(session).selectProjects(); } @@ -99,4 +110,5 @@ public class ProjectDao implements Dao { private static ProjectMapper mapper(DbSession session) { return session.getMapper(ProjectMapper.class); } + } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDto.java b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDto.java index e01902c2eb5..656fe8e67ae 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDto.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectDto.java @@ -181,4 +181,5 @@ public class ProjectDto { public int hashCode() { return uuid != null ? uuid.hashCode() : 0; } + } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectMapper.java index 01ff1c11e97..c2fafe6a8f3 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectMapper.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/project/ProjectMapper.java @@ -57,4 +57,8 @@ public interface ProjectMapper { List<ProjectDto> selectProjectsByOrganizationUuid(String organizationUuid); void updateVisibility(@Param("uuid") String uuid, @Param("isPrivate") boolean isPrivate, @Param("updatedAt") long updatedAt); + + List<ProjectDto> selectAllApplications(); + + List<ProjectDto> selectApplicationsByKeys(@Param("kees") Collection<String> kees); } diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeCommands.java b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeCommands.java index b11c7febd7f..6ab82d82e1b 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeCommands.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeCommands.java @@ -49,7 +49,6 @@ class PurgeCommands { this.system2 = system2; } - @VisibleForTesting PurgeCommands(DbSession session, PurgeProfiler profiler, System2 system2) { this(session, session.getMapper(PurgeMapper.class), profiler, system2); } @@ -406,6 +405,21 @@ class PurgeCommands { profiler.stop(); } + void deleteApplicationProjects(String applicationUuid) { + profiler.start("deleteApplicationProjects (app_projects)"); + purgeMapper.deleteApplicationBranchProjectBranchesByApplicationUuid(applicationUuid); + purgeMapper.deleteApplicationProjectsByApplicationUuid(applicationUuid); + session.commit(); + profiler.stop(); + } + + void deleteApplicationBranchProjects(String applicationBranchUuid) { + profiler.start("deleteApplicationBranchProjects (app_branch_project_branch)"); + purgeMapper.deleteApplicationBranchProjects(applicationBranchUuid); + session.commit(); + profiler.stop(); + } + public void deleteProjectAlmSettings(String rootUuid) { profiler.start("deleteProjectAlmSettings (project_alm_settings)"); purgeMapper.deleteProjectAlmSettingsByProjectUuid(rootUuid); @@ -415,6 +429,7 @@ class PurgeCommands { void deleteBranch(String rootUuid) { profiler.start("deleteBranch (project_branches)"); + purgeMapper.deleteApplicationBranchProjectBranchesByProjectBranchUuid(rootUuid); purgeMapper.deleteBranchByUuid(rootUuid); session.commit(); profiler.stop(); diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeDao.java b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeDao.java index bb39d91a389..3498ad1f49d 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeDao.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeDao.java @@ -221,6 +221,8 @@ public class PurgeDao implements Dao { commands.deletePermissions(rootUuid); commands.deleteNewCodePeriods(rootUuid); commands.deleteBranch(rootUuid); + commands.deleteApplicationBranchProjects(rootUuid); + commands.deleteApplicationProjects(rootUuid); commands.deleteComponents(rootUuid); commands.deleteComponentsByMainBranchProjectUuid(rootUuid); commands.deleteProject(rootUuid); diff --git a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeMapper.java b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeMapper.java index 840533516f9..57ca6f26a3e 100644 --- a/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeMapper.java +++ b/server/sonar-db-dao/src/main/java/org/sonar/db/purge/PurgeMapper.java @@ -141,6 +141,14 @@ public interface PurgeMapper { void deleteProjectMappingsByProjectUuid(@Param("projectUuid") String projectUuid); + void deleteApplicationProjectsByApplicationUuid(@Param("applicationUuid") String applicationUuid); + + void deleteApplicationBranchProjectBranchesByApplicationUuid(@Param("applicationUuid") String applicationUuid); + + void deleteApplicationBranchProjects(@Param("branchUuid") String applicationBranchUuid); + + void deleteApplicationBranchProjectBranchesByProjectBranchUuid(@Param("projectBranchUuid") String projectBranchUuid); + void deleteBranchByUuid(@Param("uuid") String uuid); void deleteLiveMeasuresByProjectUuid(@Param("projectUuid") String projectUuid); |