65248945c9
Clarify when "string" should be used (and be escaped), and when "template.HTML" should be used (no need to escape) And help PRs like #29059 , to render the error messages correctly. (cherry picked from commit f3eb835886031df7a562abc123c3f6011c81eca8) Conflicts: modules/web/middleware/binding.go routers/web/feed/convert.go tests/integration/branches_test.go tests/integration/repo_branch_test.go trivial context conflicts
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
// Copyright 2022 The Gitea Authors. All rights reserved.
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package feed
|
|
|
|
import (
|
|
"time"
|
|
|
|
"code.gitea.io/gitea/models/db"
|
|
repo_model "code.gitea.io/gitea/models/repo"
|
|
"code.gitea.io/gitea/modules/context"
|
|
|
|
"github.com/gorilla/feeds"
|
|
)
|
|
|
|
// shows tags and/or releases on the repo as RSS / Atom feed
|
|
func ShowReleaseFeed(ctx *context.Context, repo *repo_model.Repository, isReleasesOnly bool, formatType string) {
|
|
releases, err := db.Find[repo_model.Release](ctx, repo_model.FindReleasesOptions{
|
|
IncludeTags: !isReleasesOnly,
|
|
RepoID: ctx.Repo.Repository.ID,
|
|
})
|
|
if err != nil {
|
|
ctx.ServerError("GetReleasesByRepoID", err)
|
|
return
|
|
}
|
|
|
|
var title string
|
|
var link *feeds.Link
|
|
|
|
if isReleasesOnly {
|
|
title = ctx.Locale.TrString("repo.release.releases_for", repo.FullName())
|
|
link = &feeds.Link{Href: repo.HTMLURL() + "/release"}
|
|
} else {
|
|
title = ctx.Locale.TrString("repo.release.tags_for", repo.FullName())
|
|
link = &feeds.Link{Href: repo.HTMLURL() + "/tags"}
|
|
}
|
|
|
|
feed := &feeds.Feed{
|
|
Title: title,
|
|
Link: link,
|
|
Description: repo.Description,
|
|
Created: time.Now(),
|
|
}
|
|
|
|
feed.Items, err = releasesToFeedItems(ctx, releases, isReleasesOnly)
|
|
if err != nil {
|
|
ctx.ServerError("releasesToFeedItems", err)
|
|
return
|
|
}
|
|
|
|
writeFeed(ctx, feed, formatType)
|
|
}
|