mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Fix DeleteCollaboration transaction behaviour (#28886)
				
					
				
			The method can't be called with an outer transaction because if the user is not a collaborator the outer transaction will be rolled back even if the inner transaction uses the no-error path. `has == 0` leads to `return nil` which cancels the transaction. A standalone call of this method does nothing but if used with an outer transaction, that will be canceled.
This commit is contained in:
		| @@ -26,9 +26,12 @@ func DeleteCollaboration(ctx context.Context, repo *repo_model.Repository, uid i | ||||
| 	} | ||||
| 	defer committer.Close() | ||||
|  | ||||
| 	if has, err := db.GetEngine(ctx).Delete(collaboration); err != nil || has == 0 { | ||||
| 	if has, err := db.GetEngine(ctx).Delete(collaboration); err != nil { | ||||
| 		return err | ||||
| 	} else if err = access_model.RecalculateAccesses(ctx, repo); err != nil { | ||||
| 	} else if has == 0 { | ||||
| 		return committer.Commit() | ||||
| 	} | ||||
| 	if err = access_model.RecalculateAccesses(ctx, repo); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user