]> source.dussan.org Git - gitea.git/commitdiff
Delete protected branch if repository gets removed (#15658)
authorKN4CK3R <KN4CK3R@users.noreply.github.com>
Thu, 29 Apr 2021 22:48:52 +0000 (00:48 +0200)
committerGitHub <noreply@github.com>
Thu, 29 Apr 2021 22:48:52 +0000 (00:48 +0200)
* Added missing error parameters.

* Delete protected branch if repository gets removed.

* Added doctor fix.

models/repo.go
modules/doctor/dbconsistency.go

index cea874769d1287fc594e11eb97e906c5c5511827..0a0f725f09d91231b15cb6da5b8ea1d632507d25 100644 (file)
@@ -1472,6 +1472,7 @@ func DeleteRepository(doer *User, uid, repoID int64) error {
                &LanguageStat{RepoID: repoID},
                &Comment{RefRepoID: repoID},
                &Task{RepoID: repoID},
+               &ProtectedBranch{RepoID: repoID},
        ); err != nil {
                return fmt.Errorf("deleteBeans: %v", err)
        }
index 8c960cb4a8bdee3dab00d9fcbb3da60ce8fe634a..417a7d4b6b45c0639d31daddc8b91d8e13a8f980 100644 (file)
@@ -29,7 +29,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
        if count > 0 {
                if autofix {
                        if err = models.DeleteOrphanedLabels(); err != nil {
-                               logger.Critical("Error: %v whilst deleting orphaned labels")
+                               logger.Critical("Error: %v whilst deleting orphaned labels", err)
                                return err
                        }
                        logger.Info("%d labels without existing repository/organisation deleted", count)
@@ -47,7 +47,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
        if count > 0 {
                if autofix {
                        if err = models.DeleteOrphanedIssueLabels(); err != nil {
-                               logger.Critical("Error: %v whilst deleting orphaned issue_labels")
+                               logger.Critical("Error: %v whilst deleting orphaned issue_labels", err)
                                return err
                        }
                        logger.Info("%d issue_labels without existing label deleted", count)
@@ -65,7 +65,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
        if count > 0 {
                if autofix {
                        if err = models.DeleteOrphanedIssues(); err != nil {
-                               logger.Critical("Error: %v whilst deleting orphaned issues")
+                               logger.Critical("Error: %v whilst deleting orphaned issues", err)
                                return err
                        }
                        logger.Info("%d issues without existing repository deleted", count)
@@ -83,7 +83,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
        if count > 0 {
                if autofix {
                        if err = models.DeleteOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id"); err != nil {
-                               logger.Critical("Error: %v whilst deleting orphaned objects")
+                               logger.Critical("Error: %v whilst deleting orphaned objects", err)
                                return err
                        }
                        logger.Info("%d pull requests without existing issue deleted", count)
@@ -101,7 +101,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
        if count > 0 {
                if autofix {
                        if err = models.DeleteOrphanedObjects("tracked_time", "issue", "tracked_time.issue_id=issue.id"); err != nil {
-                               logger.Critical("Error: %v whilst deleting orphaned objects")
+                               logger.Critical("Error: %v whilst deleting orphaned objects", err)
                                return err
                        }
                        logger.Info("%d tracked times without existing issue deleted", count)
@@ -120,7 +120,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
                if autofix {
                        updatedCount, err := models.FixNullArchivedRepository()
                        if err != nil {
-                               logger.Critical("Error: %v whilst fixing null archived repositories")
+                               logger.Critical("Error: %v whilst fixing null archived repositories", err)
                                return err
                        }
                        logger.Info("%d repositories with null is_archived updated", updatedCount)
@@ -139,7 +139,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
                if autofix {
                        updatedCount, err := models.FixCommentTypeLabelWithEmptyLabel()
                        if err != nil {
-                               logger.Critical("Error: %v whilst removing label comments with empty labels")
+                               logger.Critical("Error: %v whilst removing label comments with empty labels", err)
                                return err
                        }
                        logger.Info("%d label comments with empty labels removed", updatedCount)
@@ -197,7 +197,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
                        if autofix {
                                err := models.FixBadSequences()
                                if err != nil {
-                                       logger.Critical("Error: %v whilst attempting to fix sequences")
+                                       logger.Critical("Error: %v whilst attempting to fix sequences", err)
                                        return err
                                }
                                logger.Info("%d sequences updated", count)
@@ -207,6 +207,24 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
                }
        }
 
+       // find protected branches without existing repository
+       count, err = models.CountOrphanedObjects("protected_branch", "repository", "protected_branch.repo_id=repository.id")
+       if err != nil {
+               logger.Critical("Error: %v whilst counting orphaned objects")
+               return err
+       }
+       if count > 0 {
+               if autofix {
+                       if err = models.DeleteOrphanedObjects("protected_branch", "repository", "protected_branch.repo_id=repository.id"); err != nil {
+                               logger.Critical("Error: %v whilst deleting orphaned objects", err)
+                               return err
+                       }
+                       logger.Info("%d protected branches without existing repository deleted", count)
+               } else {
+                       logger.Warn("%d protected branches without existing repository", count)
+               }
+       }
+
        return nil
 }