]> source.dussan.org Git - gitea.git/commitdiff
Redirect from `{repo}/issues/new` to `{repo}/issues/new/choose` when blank issues...
authorJakobDev <jakobdev@gmx.de>
Thu, 31 Aug 2023 15:36:25 +0000 (17:36 +0200)
committerGitHub <noreply@github.com>
Thu, 31 Aug 2023 15:36:25 +0000 (15:36 +0000)
You can currently visit `{repo}/issues/new` and create a blank issue,
even if it's disabled. This PR fixes this,

Fixes https://codeberg.org/forgejo/forgejo/issues/1356

Co-authored-by: Giteabot <teabot@gitea.io>
routers/web/repo/issue.go

index b8b5a2dff26d59e343082b7cdf5ad59f4d004c7e..f5e8f80ddfe2e8c9970047af4a828aca8f2dbf4e 100644 (file)
@@ -902,9 +902,17 @@ func setTemplateIfExists(ctx *context.Context, ctxDataKey string, possibleFiles
 
 // NewIssue render creating issue page
 func NewIssue(ctx *context.Context) {
+       issueConfig, _ := issue_service.GetTemplateConfigFromDefaultBranch(ctx.Repo.Repository, ctx.Repo.GitRepo)
+       hasTemplates := issue_service.HasTemplatesOrContactLinks(ctx.Repo.Repository, ctx.Repo.GitRepo)
+       if !issueConfig.BlankIssuesEnabled && hasTemplates {
+               // The "issues/new" and "issues/new/choose" share the same query parameters "project" and "milestone", if blank issues are disabled, just redirect to the "issues/choose" page with these parameters.
+               ctx.Redirect(fmt.Sprintf("%s/issues/new/choose?%s", ctx.Repo.Repository.Link(), ctx.Req.URL.RawQuery), http.StatusSeeOther)
+               return
+       }
+
        ctx.Data["Title"] = ctx.Tr("repo.issues.new")
        ctx.Data["PageIsIssueList"] = true
-       ctx.Data["NewIssueChooseTemplate"] = issue_service.HasTemplatesOrContactLinks(ctx.Repo.Repository, ctx.Repo.GitRepo)
+       ctx.Data["NewIssueChooseTemplate"] = hasTemplates
        ctx.Data["PullRequestWorkInProgressPrefixes"] = setting.Repository.PullRequest.WorkInProgressPrefixes
        title := ctx.FormString("title")
        ctx.Data["TitleQuery"] = title