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>
This commit is contained in:
		
							parent
							
								
									c604c9ae66
								
							
						
					
					
						commit
						b05b40180f
					
				|  | @ -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 | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue