mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-25 19:42:38 +00:00 
			
		
		
		
	Since `modules/context` has to depend on `models` and many other packages, it should be moved from `modules/context` to `services/context` according to design principles. There is no logic code change on this PR, only move packages. - Move `code.gitea.io/gitea/modules/context` to `code.gitea.io/gitea/services/context` - Move `code.gitea.io/gitea/modules/contexttest` to `code.gitea.io/gitea/services/contexttest` because of depending on context - Move `code.gitea.io/gitea/modules/upload` to `code.gitea.io/gitea/services/context/upload` because of depending on context (cherry picked from commit 29f149bd9f517225a3c9f1ca3fb0a7b5325af696) Conflicts: routers/api/packages/alpine/alpine.go routers/api/v1/repo/issue_reaction.go routers/install/install.go routers/web/admin/config.go routers/web/passkey.go routers/web/repo/search.go routers/web/repo/setting/default_branch.go routers/web/user/home.go routers/web/user/profile.go tests/integration/editor_test.go tests/integration/integration_test.go tests/integration/mirror_push_test.go trivial context conflicts also modified all other occurrences in Forgejo specific files
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			1.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2022 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package feed
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"strings"
 | |
| 	"time"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/repo"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/util"
 | |
| 	"code.gitea.io/gitea/services/context"
 | |
| 
 | |
| 	"github.com/gorilla/feeds"
 | |
| )
 | |
| 
 | |
| // ShowFileFeed shows tags and/or releases on the repo as RSS / Atom feed
 | |
| func ShowFileFeed(ctx *context.Context, repo *repo.Repository, formatType string) {
 | |
| 	fileName := ctx.Repo.TreePath
 | |
| 	if len(fileName) == 0 {
 | |
| 		return
 | |
| 	}
 | |
| 	commits, err := ctx.Repo.GitRepo.CommitsByFileAndRange(
 | |
| 		git.CommitsByFileAndRangeOptions{
 | |
| 			Revision: ctx.Repo.RefName,
 | |
| 			File:     fileName,
 | |
| 			Page:     1,
 | |
| 		})
 | |
| 	if err != nil {
 | |
| 		ctx.ServerError("ShowBranchFeed", err)
 | |
| 		return
 | |
| 	}
 | |
| 
 | |
| 	title := fmt.Sprintf("Latest commits for file %s", ctx.Repo.TreePath)
 | |
| 
 | |
| 	link := &feeds.Link{Href: repo.HTMLURL() + "/" + ctx.Repo.BranchNameSubURL() + "/" + util.PathEscapeSegments(ctx.Repo.TreePath)}
 | |
| 
 | |
| 	feed := &feeds.Feed{
 | |
| 		Title:       title,
 | |
| 		Link:        link,
 | |
| 		Description: repo.Description,
 | |
| 		Created:     time.Now(),
 | |
| 	}
 | |
| 
 | |
| 	for _, commit := range commits {
 | |
| 		feed.Items = append(feed.Items, &feeds.Item{
 | |
| 			Id:    commit.ID.String(),
 | |
| 			Title: strings.TrimSpace(strings.Split(commit.Message(), "\n")[0]),
 | |
| 			Link:  &feeds.Link{Href: repo.HTMLURL() + "/commit/" + commit.ID.String()},
 | |
| 			Author: &feeds.Author{
 | |
| 				Name:  commit.Author.Name,
 | |
| 				Email: commit.Author.Email,
 | |
| 			},
 | |
| 			Description: commit.Message(),
 | |
| 			Content:     commit.Message(),
 | |
| 		})
 | |
| 	}
 | |
| 
 | |
| 	writeFeed(ctx, feed, formatType)
 | |
| }
 |