aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKN4CK3R <KN4CK3R@users.noreply.github.com>2021-04-30 21:10:39 +0200
committerGitHub <noreply@github.com>2021-04-30 21:10:39 +0200
commitee3fb92419338e12a531168b486d3c8f5c2164c0 (patch)
treee830b3747cd05f35796d0859f6e6f9b2ddbe526c
parentf5eb33c354fc8e61cc1be221f3b7256fd7b66615 (diff)
downloadgitea-ee3fb92419338e12a531168b486d3c8f5c2164c0.tar.gz
gitea-ee3fb92419338e12a531168b486d3c8f5c2164c0.zip
Delete references if repository gets deleted (#15681)
* Remove DeletedBranch and LFSLocks. * Sort beans. Co-authored-by: zeripath <art27@cantab.net>
-rw-r--r--models/repo.go32
-rw-r--r--modules/doctor/dbconsistency.go55
2 files changed, 61 insertions, 26 deletions
diff --git a/models/repo.go b/models/repo.go
index 0a0f725f09..daa94c0d50 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -1455,24 +1455,26 @@ func DeleteRepository(doer *User, uid, repoID int64) error {
if err := deleteBeans(sess,
&Access{RepoID: repo.ID},
&Action{RepoID: repo.ID},
- &Watch{RepoID: repoID},
- &Star{RepoID: repoID},
- &Mirror{RepoID: repoID},
- &Milestone{RepoID: repoID},
- &Release{RepoID: repoID},
&Collaboration{RepoID: repoID},
- &PullRequest{BaseRepoID: repoID},
- &RepoUnit{RepoID: repoID},
- &RepoRedirect{RedirectRepoID: repoID},
- &Webhook{RepoID: repoID},
+ &Comment{RefRepoID: repoID},
+ &CommitStatus{RepoID: repoID},
+ &DeletedBranch{RepoID: repoID},
&HookTask{RepoID: repoID},
+ &LFSLock{RepoID: repoID},
+ &LanguageStat{RepoID: repoID},
+ &Milestone{RepoID: repoID},
+ &Mirror{RepoID: repoID},
&Notification{RepoID: repoID},
- &CommitStatus{RepoID: repoID},
+ &ProtectedBranch{RepoID: repoID},
+ &PullRequest{BaseRepoID: repoID},
+ &Release{RepoID: repoID},
&RepoIndexerStatus{RepoID: repoID},
- &LanguageStat{RepoID: repoID},
- &Comment{RefRepoID: repoID},
+ &RepoRedirect{RedirectRepoID: repoID},
+ &RepoUnit{RepoID: repoID},
+ &Star{RepoID: repoID},
&Task{RepoID: repoID},
- &ProtectedBranch{RepoID: repoID},
+ &Watch{RepoID: repoID},
+ &Webhook{RepoID: repoID},
); err != nil {
return fmt.Errorf("deleteBeans: %v", err)
}
@@ -1488,10 +1490,6 @@ func DeleteRepository(doer *User, uid, repoID int64) error {
return err
}
- if _, err := sess.Where("repo_id = ?", repoID).Delete(new(RepoUnit)); err != nil {
- return err
- }
-
if repo.IsFork {
if _, err := sess.Exec("UPDATE `repository` SET num_forks=num_forks-1 WHERE id=?", repo.ForkID); err != nil {
return fmt.Errorf("decrease fork count: %v", err)
diff --git a/modules/doctor/dbconsistency.go b/modules/doctor/dbconsistency.go
index 417a7d4b6b..23e8331e77 100644
--- a/modules/doctor/dbconsistency.go
+++ b/modules/doctor/dbconsistency.go
@@ -23,7 +23,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find labels without existing repo or org
count, err := models.CountOrphanedLabels()
if err != nil {
- logger.Critical("Error: %v whilst counting orphaned labels")
+ logger.Critical("Error: %v whilst counting orphaned labels", err)
return err
}
if count > 0 {
@@ -41,7 +41,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find IssueLabels without existing label
count, err = models.CountOrphanedIssueLabels()
if err != nil {
- logger.Critical("Error: %v whilst counting orphaned issue_labels")
+ logger.Critical("Error: %v whilst counting orphaned issue_labels", err)
return err
}
if count > 0 {
@@ -59,7 +59,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find issues without existing repository
count, err = models.CountOrphanedIssues()
if err != nil {
- logger.Critical("Error: %v whilst counting orphaned issues")
+ logger.Critical("Error: %v whilst counting orphaned issues", err)
return err
}
if count > 0 {
@@ -77,7 +77,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find pulls without existing issues
count, err = models.CountOrphanedObjects("pull_request", "issue", "pull_request.issue_id=issue.id")
if err != nil {
- logger.Critical("Error: %v whilst counting orphaned objects")
+ logger.Critical("Error: %v whilst counting orphaned objects", err)
return err
}
if count > 0 {
@@ -95,7 +95,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find tracked times without existing issues/pulls
count, err = models.CountOrphanedObjects("tracked_time", "issue", "tracked_time.issue_id=issue.id")
if err != nil {
- logger.Critical("Error: %v whilst counting orphaned objects")
+ logger.Critical("Error: %v whilst counting orphaned objects", err)
return err
}
if count > 0 {
@@ -113,7 +113,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find null archived repositories
count, err = models.CountNullArchivedRepository()
if err != nil {
- logger.Critical("Error: %v whilst counting null archived repositories")
+ logger.Critical("Error: %v whilst counting null archived repositories", err)
return err
}
if count > 0 {
@@ -132,7 +132,7 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
// find label comments with empty labels
count, err = models.CountCommentTypeLabelWithEmptyLabel()
if err != nil {
- logger.Critical("Error: %v whilst counting label comments with empty labels")
+ logger.Critical("Error: %v whilst counting label comments with empty labels", err)
return err
}
if count > 0 {
@@ -191,7 +191,8 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
if setting.Database.UsePostgreSQL {
count, err = models.CountBadSequences()
if err != nil {
- logger.Critical("Error: %v whilst checking sequence values")
+ logger.Critical("Error: %v whilst checking sequence values", err)
+ return err
}
if count > 0 {
if autofix {
@@ -210,7 +211,7 @@ 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")
+ logger.Critical("Error: %v whilst counting orphaned objects", err)
return err
}
if count > 0 {
@@ -225,6 +226,42 @@ func checkDBConsistency(logger log.Logger, autofix bool) error {
}
}
+ // find deleted branches without existing repository
+ count, err = models.CountOrphanedObjects("deleted_branch", "repository", "deleted_branch.repo_id=repository.id")
+ if err != nil {
+ logger.Critical("Error: %v whilst counting orphaned objects", err)
+ return err
+ }
+ if count > 0 {
+ if autofix {
+ if err = models.DeleteOrphanedObjects("deleted_branch", "repository", "deleted_branch.repo_id=repository.id"); err != nil {
+ logger.Critical("Error: %v whilst deleting orphaned objects", err)
+ return err
+ }
+ logger.Info("%d deleted branches without existing repository deleted", count)
+ } else {
+ logger.Warn("%d deleted branches without existing repository", count)
+ }
+ }
+
+ // find LFS locks without existing repository
+ count, err = models.CountOrphanedObjects("lfs_lock", "repository", "lfs_lock.repo_id=repository.id")
+ if err != nil {
+ logger.Critical("Error: %v whilst counting orphaned objects", err)
+ return err
+ }
+ if count > 0 {
+ if autofix {
+ if err = models.DeleteOrphanedObjects("lfs_lock", "repository", "lfs_lock.repo_id=repository.id"); err != nil {
+ logger.Critical("Error: %v whilst deleting orphaned objects", err)
+ return err
+ }
+ logger.Info("%d LFS locks without existing repository deleted", count)
+ } else {
+ logger.Warn("%d LFS locks without existing repository", count)
+ }
+ }
+
return nil
}