mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-31 08:18:02 -04:00 
			
		
		
		
	* Backport: Repo Transfer permission checks (#14792) * update tests
This commit is contained in:
		| @@ -445,7 +445,7 @@ func TestAPIRepoTransfer(t *testing.T) { | ||||
| 		expectedStatus int | ||||
| 	}{ | ||||
| 		{ctxUserID: 1, newOwner: "user2", teams: nil, expectedStatus: http.StatusAccepted}, | ||||
| 		{ctxUserID: 2, newOwner: "user1", teams: nil, expectedStatus: http.StatusAccepted}, | ||||
| 		{ctxUserID: 2, newOwner: "user1", teams: nil, expectedStatus: http.StatusForbidden}, | ||||
| 		{ctxUserID: 2, newOwner: "user6", teams: nil, expectedStatus: http.StatusForbidden}, | ||||
| 		{ctxUserID: 1, newOwner: "user2", teams: &[]int64{2}, expectedStatus: http.StatusUnprocessableEntity}, | ||||
| 		{ctxUserID: 1, newOwner: "user3", teams: &[]int64{5}, expectedStatus: http.StatusForbidden}, | ||||
|   | ||||
| @@ -93,7 +93,12 @@ func Transfer(ctx *context.APIContext, opts api.TransferRepoOption) { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if err = repo_service.TransferOwnership(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.IsErrCancelled(err) { | ||||
| 			ctx.Error(http.StatusForbidden, "transfer", "user has no right to create repo for new owner") | ||||
| 			return | ||||
| 		} | ||||
|  | ||||
| 		ctx.InternalServerError(err) | ||||
| 		return | ||||
| 	} | ||||
|   | ||||
| @@ -475,9 +475,12 @@ func SettingsPost(ctx *context.Context, form auth.RepoSettingForm) { | ||||
| 			ctx.Repo.GitRepo.Close() | ||||
| 			ctx.Repo.GitRepo = nil | ||||
| 		} | ||||
| 		if err = repo_service.TransferOwnership(ctx.User, newOwner, repo, nil); err != nil { | ||||
| 		if err = repo_service.StartRepositoryTransfer(ctx.User, newOwner, repo, nil); err != nil { | ||||
| 			if models.IsErrRepoAlreadyExist(err) { | ||||
| 				ctx.RenderWithErr(ctx.Tr("repo.settings.new_owner_has_same_repo"), tplSettingsOptions, nil) | ||||
| 			} else if models.IsErrCancelled(err) { | ||||
| 				// this err msg is not translated, since it was introduced in a backport | ||||
| 				ctx.RenderWithErr("user has no right to create repo for new owner", tplSettingsOptions, nil) | ||||
| 			} else { | ||||
| 				ctx.ServerError("TransferOwnership", err) | ||||
| 			} | ||||
|   | ||||
| @@ -72,3 +72,31 @@ func ChangeRepositoryName(doer *models.User, repo *models.Repository, newRepoNam | ||||
|  | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
| // StartRepositoryTransfer transfer a repo from one owner to a new one. | ||||
| // it make repository into pending transfer state, if doer can not create repo for new owner. | ||||
| func StartRepositoryTransfer(doer, newOwner *models.User, repo *models.Repository, teams []*models.Team) error { | ||||
| 	if repo.Status != models.RepositoryReady { | ||||
| 		return fmt.Errorf("repository is not ready for transfer") | ||||
| 	} | ||||
|  | ||||
| 	// Admin is always allowed to transfer | ||||
| 	if doer.IsAdmin { | ||||
| 		return TransferOwnership(doer, newOwner, repo, teams) | ||||
| 	} | ||||
|  | ||||
| 	// If new owner is an org and user can create repos he can transfer directly too | ||||
| 	if newOwner.IsOrganization() { | ||||
| 		allowed, err := models.CanCreateOrgRepo(newOwner.ID, doer.ID) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		if allowed { | ||||
| 			return TransferOwnership(doer, newOwner, repo, teams) | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	// Block Transfer, new feature will come in v1.14.0 | ||||
| 	// https://github.com/go-gitea/gitea/pull/14792 | ||||
| 	return models.ErrCancelled{} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user