mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-26 05:04:27 +08:00 
			
		
		
		
	Ensure that git repository is closed before transfer (#18049)
Repository Transfer requires that the repository directory is renamed - which is not possible on Windows if the git repository is open. Fix #17885 Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		| @ -98,6 +98,11 @@ func Transfer(ctx *context.APIContext) { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	if ctx.Repo.GitRepo != nil { | ||||||
|  | 		ctx.Repo.GitRepo.Close() | ||||||
|  | 		ctx.Repo.GitRepo = nil | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if err := repo_service.StartRepositoryTransfer(ctx.User, newOwner, ctx.Repo.Repository, teams); err != nil { | 	if err := repo_service.StartRepositoryTransfer(ctx.User, newOwner, ctx.Repo.Repository, teams); err != nil { | ||||||
| 		if models.IsErrRepoTransferInProgress(err) { | 		if models.IsErrRepoTransferInProgress(err) { | ||||||
| 			ctx.Error(http.StatusConflict, "CreatePendingRepositoryTransfer", err) | 			ctx.Error(http.StatusConflict, "CreatePendingRepositoryTransfer", err) | ||||||
|  | |||||||
| @ -323,6 +323,11 @@ func acceptOrRejectRepoTransfer(ctx *context.Context, accept bool) error { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if accept { | 	if accept { | ||||||
|  | 		if ctx.Repo.GitRepo != nil { | ||||||
|  | 			ctx.Repo.GitRepo.Close() | ||||||
|  | 			ctx.Repo.GitRepo = nil | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if err := repo_service.TransferOwnership(repoTransfer.Doer, repoTransfer.Recipient, ctx.Repo.Repository, repoTransfer.Teams); err != nil { | 		if err := repo_service.TransferOwnership(repoTransfer.Doer, repoTransfer.Recipient, ctx.Repo.Repository, repoTransfer.Teams); err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 zeripath
					zeripath