|
|
|
@ -1224,6 +1224,14 @@ func NewIssuePost(ctx *context.Context) { |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if projectID > 0 { |
|
|
|
|
if !ctx.Repo.CanRead(unit.TypeProjects) { |
|
|
|
|
// User must also be able to see the project.
|
|
|
|
|
ctx.Error(http.StatusBadRequest, "user hasn't permissions to read projects") |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if setting.Attachment.Enabled { |
|
|
|
|
attachments = form.Files |
|
|
|
|
} |
|
|
|
@ -1256,7 +1264,7 @@ func NewIssuePost(ctx *context.Context) { |
|
|
|
|
Ref: form.Ref, |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if err := issue_service.NewIssue(ctx, repo, issue, labelIDs, attachments, assigneeIDs); err != nil { |
|
|
|
|
if err := issue_service.NewIssue(ctx, repo, issue, labelIDs, attachments, assigneeIDs, projectID); err != nil { |
|
|
|
|
if repo_model.IsErrUserDoesNotHaveAccessToRepo(err) { |
|
|
|
|
ctx.Error(http.StatusBadRequest, "UserDoesNotHaveAccessToRepo", err.Error()) |
|
|
|
|
} else if errors.Is(err, user_model.ErrBlockedUser) { |
|
|
|
@ -1267,18 +1275,6 @@ func NewIssuePost(ctx *context.Context) { |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if projectID > 0 { |
|
|
|
|
if !ctx.Repo.CanRead(unit.TypeProjects) { |
|
|
|
|
// User must also be able to see the project.
|
|
|
|
|
ctx.Error(http.StatusBadRequest, "user hasn't permissions to read projects") |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
if err := issues_model.ChangeProjectAssign(ctx, issue, ctx.Doer, projectID); err != nil { |
|
|
|
|
ctx.ServerError("ChangeProjectAssign", err) |
|
|
|
|
return |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
log.Trace("Issue created: %d/%d", repo.ID, issue.ID) |
|
|
|
|
if ctx.FormString("redirect_after_creation") == "project" && projectID > 0 { |
|
|
|
|
ctx.JSONRedirect(ctx.Repo.RepoLink + "/projects/" + strconv.FormatInt(projectID, 10)) |
|
|
|
|