summaryrefslogtreecommitdiffstats
path: root/services
diff options
context:
space:
mode:
authorzeripath <art27@cantab.net>2022-03-21 08:09:42 +0000
committerGitHub <noreply@github.com>2022-03-21 09:09:42 +0100
commitb05b40180f41b440d18a6d6abafd2d6187979bfe (patch)
treebbc90af80de79472111f255d8e174370169ff634 /services
parentc604c9ae66696539174b04a33f9f3bb73b7a09c2 (diff)
downloadgitea-b05b40180f41b440d18a6d6abafd2d6187979bfe.tar.gz
gitea-b05b40180f41b440d18a6d6abafd2d6187979bfe.zip
Use IterateBufferSize whilst querying repositories during adoption check (#19140)
The adoption page checks directories to see if they are repositories by querying the db on a per user basis. This can lead to problems if a user has a large number of repositories or putative repositories. This PR changes the buffering to check the db in IterataeBufferSize batches instead. Fix #19137 Signed-off-by: Andrew Thornton <art27@cantab.net>
Diffstat (limited to 'services')
-rw-r--r--services/repository/adopt.go7
1 files changed, 7 insertions, 0 deletions
diff --git a/services/repository/adopt.go b/services/repository/adopt.go
index 72fe284ad3..2af01e973a 100644
--- a/services/repository/adopt.go
+++ b/services/repository/adopt.go
@@ -339,6 +339,13 @@ func ListUnadoptedRepositories(query string, opts *db.ListOptions) ([]string, in
}
repoNamesToCheck = append(repoNamesToCheck, name)
+ if len(repoNamesToCheck) > setting.Database.IterateBufferSize {
+ if err = checkUnadoptedRepositories(userName, repoNamesToCheck, unadopted); err != nil {
+ return err
+ }
+ repoNamesToCheck = repoNamesToCheck[:0]
+
+ }
return filepath.SkipDir
}); err != nil {
return nil, 0, err