mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 11:33:11 +00:00 
			
		
		
		
	* Change graceful to use a singleton obtained through GetManager instead of a global. * Graceful: Make TestPullRequests shutdownable * Graceful: Make the cron tasks graceful * Graceful: AddTestPullRequest run in graceful ctx * Graceful: SyncMirrors shutdown * Graceful: SetDefaultContext for Xorm to be HammerContext * Avoid starting graceful for migrate commands and checkout * Graceful: DeliverHooks now can be shutdown * Fix multiple syncing errors in modules/sync/UniqueQueue & Make UniqueQueue closable * Begin the process of making the repo indexer shutdown gracefully
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // Use of this source code is governed by a MIT-style
 | |
| // license that can be found in the LICENSE file.
 | |
| 
 | |
| package migrations
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models"
 | |
| 	"code.gitea.io/gitea/modules/log"
 | |
| 	"code.gitea.io/gitea/modules/structs"
 | |
| )
 | |
| 
 | |
| // UpdateMigrationPosterID updates all migrated repositories' issues and comments posterID
 | |
| func UpdateMigrationPosterID(ctx context.Context) {
 | |
| 	for _, gitService := range structs.SupportedFullGitService {
 | |
| 		select {
 | |
| 		case <-ctx.Done():
 | |
| 			log.Warn("UpdateMigrationPosterID aborted due to shutdown before %s", gitService.Name())
 | |
| 		default:
 | |
| 		}
 | |
| 		if err := updateMigrationPosterIDByGitService(ctx, gitService); err != nil {
 | |
| 			log.Error("updateMigrationPosterIDByGitService failed: %v", err)
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func updateMigrationPosterIDByGitService(ctx context.Context, tp structs.GitServiceType) error {
 | |
| 	provider := tp.Name()
 | |
| 	if len(provider) == 0 {
 | |
| 		return nil
 | |
| 	}
 | |
| 
 | |
| 	const batchSize = 100
 | |
| 	var start int
 | |
| 	for {
 | |
| 		select {
 | |
| 		case <-ctx.Done():
 | |
| 			log.Warn("UpdateMigrationPosterIDByGitService(%s) aborted due to shutdown", tp.Name())
 | |
| 			return nil
 | |
| 		default:
 | |
| 		}
 | |
| 
 | |
| 		users, err := models.FindExternalUsersByProvider(models.FindExternalUserOptions{
 | |
| 			Provider: provider,
 | |
| 			Start:    start,
 | |
| 			Limit:    batchSize,
 | |
| 		})
 | |
| 		if err != nil {
 | |
| 			return err
 | |
| 		}
 | |
| 
 | |
| 		for _, user := range users {
 | |
| 			select {
 | |
| 			case <-ctx.Done():
 | |
| 				log.Warn("UpdateMigrationPosterIDByGitService(%s) aborted due to shutdown", tp.Name())
 | |
| 				return nil
 | |
| 			default:
 | |
| 			}
 | |
| 			externalUserID := user.ExternalID
 | |
| 			if err := models.UpdateMigrationsByType(tp, externalUserID, user.UserID); err != nil {
 | |
| 				log.Error("UpdateMigrationsByType type %s external user id %v to local user id %v failed: %v", tp.Name(), user.ExternalID, user.UserID, err)
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if len(users) < batchSize {
 | |
| 			break
 | |
| 		}
 | |
| 		start += len(users)
 | |
| 	}
 | |
| 	return nil
 | |
| }
 |