mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-03 21:08:25 +00:00 
			
		
		
		
	keep sure if assigneeIDs == nil -> do nothing
This commit is contained in:
		@@ -344,22 +344,24 @@ func CreateIssue(ctx *context.APIContext, form api.CreateIssueOption) {
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		// Check if the passed assignees is assignable
 | 
			
		||||
		for _, aID := range assigneeIDs {
 | 
			
		||||
			assignee, err := models.GetUserByID(aID)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				ctx.Error(500, "GetUserByID", err)
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
		if assigneeIDs != nil {
 | 
			
		||||
			for _, aID := range assigneeIDs {
 | 
			
		||||
				assignee, err := models.GetUserByID(aID)
 | 
			
		||||
				if err != nil {
 | 
			
		||||
					ctx.Error(500, "GetUserByID", err)
 | 
			
		||||
					return
 | 
			
		||||
				}
 | 
			
		||||
 | 
			
		||||
			valid, err := models.CanBeAssigned(assignee, ctx.Repo.Repository, false)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				ctx.Error(500, "canBeAssigned", err)
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
			if !valid {
 | 
			
		||||
				ctx.Error(422, "canBeAssigned", models.ErrUserDoesNotHaveAccessToRepo{UserID: aID, RepoName: ctx.Repo.Repository.Name})
 | 
			
		||||
				return
 | 
			
		||||
				// Check if the passed assignees is assignable
 | 
			
		||||
				valid, err := models.CanBeAssigned(assignee, ctx.Repo.Repository, false)
 | 
			
		||||
				if err != nil {
 | 
			
		||||
					ctx.Error(500, "canBeAssigned", err)
 | 
			
		||||
					return
 | 
			
		||||
				}
 | 
			
		||||
				if !valid {
 | 
			
		||||
					ctx.Error(422, "canBeAssigned", models.ErrUserDoesNotHaveAccessToRepo{UserID: aID, RepoName: ctx.Repo.Repository.Name})
 | 
			
		||||
					return
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	} else {
 | 
			
		||||
 
 | 
			
		||||
@@ -286,22 +286,25 @@ func CreatePullRequest(ctx *context.APIContext, form api.CreatePullRequestOption
 | 
			
		||||
		}
 | 
			
		||||
		return
 | 
			
		||||
	}
 | 
			
		||||
	// Check if the passed assignees is assignable
 | 
			
		||||
	for _, aID := range assigneeIDs {
 | 
			
		||||
		assignee, err := models.GetUserByID(aID)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			ctx.Error(500, "GetUserByID", err)
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		valid, err := models.CanBeAssigned(assignee, repo, true)
 | 
			
		||||
		if err != nil {
 | 
			
		||||
			ctx.Error(500, "canBeAssigned", err)
 | 
			
		||||
			return
 | 
			
		||||
		}
 | 
			
		||||
		if !valid {
 | 
			
		||||
			ctx.Error(422, "canBeAssigned", models.ErrUserDoesNotHaveAccessToRepo{UserID: aID, RepoName: repo.Name})
 | 
			
		||||
			return
 | 
			
		||||
	if assigneeIDs != nil {
 | 
			
		||||
		for _, aID := range assigneeIDs {
 | 
			
		||||
			assignee, err := models.GetUserByID(aID)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				ctx.Error(500, "GetUserByID", err)
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			// Check if the passed assignees is assignable
 | 
			
		||||
			valid, err := models.CanBeAssigned(assignee, repo, true)
 | 
			
		||||
			if err != nil {
 | 
			
		||||
				ctx.Error(500, "canBeAssigned", err)
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
			if !valid {
 | 
			
		||||
				ctx.Error(422, "canBeAssigned", models.ErrUserDoesNotHaveAccessToRepo{UserID: aID, RepoName: repo.Name})
 | 
			
		||||
				return
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user