Fix issue dependencies (#27736)
Fix #27722 Fix #27357 Fix #25837 1. Fix the typo `BlockingByDependenciesNotPermitted`, which causes the `not permitted message` not to show. The correct one is `Blocking` or `BlockedBy` 2. Rewrite the perm check. The perm check uses a very tricky way to avoid duplicate checks for a slice of issues, which is confusing. In fact, it's also the reason causing the bug. It uses `lastRepoID` and `lastPerm` to avoid duplicate checks, but forgets to assign the `lastPerm` at the end of the code block. So I rewrote this to avoid this trick.  3. It also reuses the `blocks` slice, which is even more confusing. So I rewrote this too. 
This commit is contained in:
		
							parent
							
								
									4f8f5f6e25
								
							
						
					
					
						commit
						9b59af37e7
					
				| @ -102,23 +102,24 @@ func GetIssueDependencies(ctx *context.APIContext) { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var lastRepoID int64 | ||||
| 	var lastPerm access_model.Permission | ||||
| 	repoPerms := make(map[int64]access_model.Permission) | ||||
| 	repoPerms[ctx.Repo.Repository.ID] = ctx.Repo.Permission | ||||
| 	for _, blocker := range blockersInfo { | ||||
| 		// Get the permissions for this repository | ||||
| 		perm := lastPerm | ||||
| 		if lastRepoID != blocker.Repository.ID { | ||||
| 			if blocker.Repository.ID == ctx.Repo.Repository.ID { | ||||
| 				perm = ctx.Repo.Permission | ||||
| 			} else { | ||||
| 				var err error | ||||
| 				perm, err = access_model.GetUserRepoPermission(ctx, &blocker.Repository, ctx.Doer) | ||||
| 				if err != nil { | ||||
| 					ctx.ServerError("GetUserRepoPermission", err) | ||||
| 					return | ||||
| 				} | ||||
| 		// If the repo ID exists in the map, return the exist permissions | ||||
| 		// else get the permission and add it to the map | ||||
| 		var perm access_model.Permission | ||||
| 		existPerm, ok := repoPerms[blocker.RepoID] | ||||
| 		if ok { | ||||
| 			perm = existPerm | ||||
| 		} else { | ||||
| 			var err error | ||||
| 			perm, err = access_model.GetUserRepoPermission(ctx, &blocker.Repository, ctx.Doer) | ||||
| 			if err != nil { | ||||
| 				ctx.ServerError("GetUserRepoPermission", err) | ||||
| 				return | ||||
| 			} | ||||
| 			lastRepoID = blocker.Repository.ID | ||||
| 			repoPerms[blocker.RepoID] = perm | ||||
| 		} | ||||
| 
 | ||||
| 		// check permission | ||||
| @ -345,29 +346,31 @@ func GetIssueBlocks(ctx *context.APIContext) { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	var lastRepoID int64 | ||||
| 	var lastPerm access_model.Permission | ||||
| 
 | ||||
| 	var issues []*issues_model.Issue | ||||
| 
 | ||||
| 	repoPerms := make(map[int64]access_model.Permission) | ||||
| 	repoPerms[ctx.Repo.Repository.ID] = ctx.Repo.Permission | ||||
| 
 | ||||
| 	for i, depMeta := range deps { | ||||
| 		if i < skip || i >= max { | ||||
| 			continue | ||||
| 		} | ||||
| 
 | ||||
| 		// Get the permissions for this repository | ||||
| 		perm := lastPerm | ||||
| 		if lastRepoID != depMeta.Repository.ID { | ||||
| 			if depMeta.Repository.ID == ctx.Repo.Repository.ID { | ||||
| 				perm = ctx.Repo.Permission | ||||
| 			} else { | ||||
| 				var err error | ||||
| 				perm, err = access_model.GetUserRepoPermission(ctx, &depMeta.Repository, ctx.Doer) | ||||
| 				if err != nil { | ||||
| 					ctx.ServerError("GetUserRepoPermission", err) | ||||
| 					return | ||||
| 				} | ||||
| 		// If the repo ID exists in the map, return the exist permissions | ||||
| 		// else get the permission and add it to the map | ||||
| 		var perm access_model.Permission | ||||
| 		existPerm, ok := repoPerms[depMeta.RepoID] | ||||
| 		if ok { | ||||
| 			perm = existPerm | ||||
| 		} else { | ||||
| 			var err error | ||||
| 			perm, err = access_model.GetUserRepoPermission(ctx, &depMeta.Repository, ctx.Doer) | ||||
| 			if err != nil { | ||||
| 				ctx.ServerError("GetUserRepoPermission", err) | ||||
| 				return | ||||
| 			} | ||||
| 			lastRepoID = depMeta.Repository.ID | ||||
| 			repoPerms[depMeta.RepoID] = perm | ||||
| 		} | ||||
| 
 | ||||
| 		if !perm.CanReadIssuesOrPulls(depMeta.Issue.IsPull) { | ||||
|  | ||||
| @ -1962,7 +1962,7 @@ func ViewIssue(ctx *context.Context) { | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	ctx.Data["BlockingDependencies"], ctx.Data["BlockingByDependenciesNotPermitted"] = checkBlockedByIssues(ctx, blocking) | ||||
| 	ctx.Data["BlockingDependencies"], ctx.Data["BlockingDependenciesNotPermitted"] = checkBlockedByIssues(ctx, blocking) | ||||
| 	if ctx.Written() { | ||||
| 		return | ||||
| 	} | ||||
| @ -2023,38 +2023,34 @@ func ViewIssue(ctx *context.Context) { | ||||
| 
 | ||||
| // checkBlockedByIssues return canRead and notPermitted | ||||
| func checkBlockedByIssues(ctx *context.Context, blockers []*issues_model.DependencyInfo) (canRead, notPermitted []*issues_model.DependencyInfo) { | ||||
| 	var ( | ||||
| 		lastRepoID int64 | ||||
| 		lastPerm   access_model.Permission | ||||
| 	) | ||||
| 	for i, blocker := range blockers { | ||||
| 	repoPerms := make(map[int64]access_model.Permission) | ||||
| 	repoPerms[ctx.Repo.Repository.ID] = ctx.Repo.Permission | ||||
| 	for _, blocker := range blockers { | ||||
| 		// Get the permissions for this repository | ||||
| 		perm := lastPerm | ||||
| 		if lastRepoID != blocker.Repository.ID { | ||||
| 			if blocker.Repository.ID == ctx.Repo.Repository.ID { | ||||
| 				perm = ctx.Repo.Permission | ||||
| 			} else { | ||||
| 				var err error | ||||
| 				perm, err = access_model.GetUserRepoPermission(ctx, &blocker.Repository, ctx.Doer) | ||||
| 				if err != nil { | ||||
| 					ctx.ServerError("GetUserRepoPermission", err) | ||||
| 					return nil, nil | ||||
| 				} | ||||
| 		// If the repo ID exists in the map, return the exist permissions | ||||
| 		// else get the permission and add it to the map | ||||
| 		var perm access_model.Permission | ||||
| 		existPerm, ok := repoPerms[blocker.RepoID] | ||||
| 		if ok { | ||||
| 			perm = existPerm | ||||
| 		} else { | ||||
| 			var err error | ||||
| 			perm, err = access_model.GetUserRepoPermission(ctx, &blocker.Repository, ctx.Doer) | ||||
| 			if err != nil { | ||||
| 				ctx.ServerError("GetUserRepoPermission", err) | ||||
| 				return nil, nil | ||||
| 			} | ||||
| 			lastRepoID = blocker.Repository.ID | ||||
| 			repoPerms[blocker.RepoID] = perm | ||||
| 		} | ||||
| 
 | ||||
| 		// check permission | ||||
| 		if !perm.CanReadIssuesOrPulls(blocker.Issue.IsPull) { | ||||
| 			blockers[len(notPermitted)], blockers[i] = blocker, blockers[len(notPermitted)] | ||||
| 			notPermitted = blockers[:len(notPermitted)+1] | ||||
| 		if perm.CanReadIssuesOrPulls(blocker.Issue.IsPull) { | ||||
| 			canRead = append(canRead, blocker) | ||||
| 		} else { | ||||
| 			notPermitted = append(notPermitted, blocker) | ||||
| 		} | ||||
| 	} | ||||
| 	blockers = blockers[len(notPermitted):] | ||||
| 	sortDependencyInfo(blockers) | ||||
| 	sortDependencyInfo(canRead) | ||||
| 	sortDependencyInfo(notPermitted) | ||||
| 
 | ||||
| 	return blockers, notPermitted | ||||
| 	return canRead, notPermitted | ||||
| } | ||||
| 
 | ||||
| func sortDependencyInfo(blockers []*issues_model.DependencyInfo) { | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user