mirror of
				https://codeberg.org/forgejo/forgejo.git
				synced 2025-10-31 14:31:02 +00:00 
			
		
		
		
	user, topic, project, label, milestone, repository, pull_request, release, asset, comment, reaction, review providers Signed-off-by: Earl Warren <contact@earl-warren.org> Preserve file size when creating attachments Introduced inc6f5029708repoList.LoadAttributes has a ctx argument now Rename `repo.GetOwner` to `repo.LoadOwner`bd66fa586aupgrade to the latest gof3 (cherry picked from commitc770713656) [F3] ID remapping logic is in place, remove workaround (cherry picked from commitd0fee30167) [F3] it is experimental, do not enable by default (cherry picked from commitde325b21d0) (cherry picked from commit547e7b3c40)
		
			
				
	
	
		
			196 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			196 lines
		
	
	
	
		
			4.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package driver
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 
 | |
| 	"code.gitea.io/gitea/models/db"
 | |
| 	issues_model "code.gitea.io/gitea/models/issues"
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/timeutil"
 | |
| 	issue_service "code.gitea.io/gitea/services/issue"
 | |
| 
 | |
| 	"lab.forgefriends.org/friendlyforgeformat/gof3/format"
 | |
| 	"lab.forgefriends.org/friendlyforgeformat/gof3/util"
 | |
| )
 | |
| 
 | |
| type Issue struct {
 | |
| 	issues_model.Issue
 | |
| }
 | |
| 
 | |
| func IssueConverter(f *issues_model.Issue) *Issue {
 | |
| 	return &Issue{
 | |
| 		Issue: *f,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (o Issue) GetID() int64 {
 | |
| 	return o.Index
 | |
| }
 | |
| 
 | |
| func (o *Issue) SetID(id int64) {
 | |
| 	o.Index = id
 | |
| }
 | |
| 
 | |
| func (o *Issue) IsNil() bool {
 | |
| 	return o.Index == 0
 | |
| }
 | |
| 
 | |
| func (o *Issue) Equals(other *Issue) bool {
 | |
| 	return o.Index == other.Index
 | |
| }
 | |
| 
 | |
| func (o *Issue) ToFormat() *format.Issue {
 | |
| 	var milestone string
 | |
| 	if o.Milestone != nil {
 | |
| 		milestone = o.Milestone.Name
 | |
| 	}
 | |
| 
 | |
| 	labels := make([]string, 0, len(o.Labels))
 | |
| 	for _, label := range o.Labels {
 | |
| 		labels = append(labels, label.Name)
 | |
| 	}
 | |
| 
 | |
| 	var assignees []string
 | |
| 	for i := range o.Assignees {
 | |
| 		assignees = append(assignees, o.Assignees[i].Name)
 | |
| 	}
 | |
| 
 | |
| 	return &format.Issue{
 | |
| 		Common:    format.NewCommon(o.Index),
 | |
| 		Title:     o.Title,
 | |
| 		PosterID:  format.NewUserReference(o.Poster.ID),
 | |
| 		Content:   o.Content,
 | |
| 		Milestone: milestone,
 | |
| 		State:     string(o.State()),
 | |
| 		Created:   o.CreatedUnix.AsTime(),
 | |
| 		Updated:   o.UpdatedUnix.AsTime(),
 | |
| 		Closed:    o.ClosedUnix.AsTimePtr(),
 | |
| 		IsLocked:  o.IsLocked,
 | |
| 		Labels:    labels,
 | |
| 		Assignees: assignees,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (o *Issue) FromFormat(issue *format.Issue) {
 | |
| 	labels := make([]*issues_model.Label, 0, len(issue.Labels))
 | |
| 	for _, label := range issue.Labels {
 | |
| 		labels = append(labels, &issues_model.Label{Name: label})
 | |
| 	}
 | |
| 
 | |
| 	assignees := make([]*user_model.User, 0, len(issue.Assignees))
 | |
| 	for _, a := range issue.Assignees {
 | |
| 		assignees = append(assignees, &user_model.User{
 | |
| 			Name: a,
 | |
| 		})
 | |
| 	}
 | |
| 
 | |
| 	*o = Issue{
 | |
| 		Issue: issues_model.Issue{
 | |
| 			Title:    issue.Title,
 | |
| 			Index:    issue.GetID(),
 | |
| 			PosterID: issue.PosterID.GetID(),
 | |
| 			Poster: &user_model.User{
 | |
| 				ID: issue.PosterID.GetID(),
 | |
| 			},
 | |
| 			Content: issue.Content,
 | |
| 			Milestone: &issues_model.Milestone{
 | |
| 				Name: issue.Milestone,
 | |
| 			},
 | |
| 			IsClosed:    issue.State == "closed",
 | |
| 			CreatedUnix: timeutil.TimeStamp(issue.Created.Unix()),
 | |
| 			UpdatedUnix: timeutil.TimeStamp(issue.Updated.Unix()),
 | |
| 			ClosedUnix:  timeutil.TimeStamp(issue.Closed.Unix()),
 | |
| 			IsLocked:    issue.IsLocked,
 | |
| 			Labels:      labels,
 | |
| 			Assignees:   assignees,
 | |
| 		},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| type IssueProvider struct {
 | |
| 	g       *Forgejo
 | |
| 	project *ProjectProvider
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) ToFormat(ctx context.Context, issue *Issue) *format.Issue {
 | |
| 	return issue.ToFormat()
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) FromFormat(ctx context.Context, i *format.Issue) *Issue {
 | |
| 	var issue Issue
 | |
| 	issue.FromFormat(i)
 | |
| 	if i.Milestone != "" {
 | |
| 		issue.Milestone.ID = o.project.milestones.GetID(issue.Milestone.Name)
 | |
| 	}
 | |
| 	for _, label := range issue.Labels {
 | |
| 		label.ID = o.project.labels.GetID(label.Name)
 | |
| 	}
 | |
| 	return &issue
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) GetObjects(ctx context.Context, user *User, project *Project, page int) []*Issue {
 | |
| 	issues, err := issues_model.Issues(ctx, &issues_model.IssuesOptions{
 | |
| 		ListOptions: db.ListOptions{Page: page, PageSize: o.g.perPage},
 | |
| 		RepoID:      project.GetID(),
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		panic(fmt.Errorf("error while listing issues: %v", err))
 | |
| 	}
 | |
| 
 | |
| 	return util.ConvertMap[*issues_model.Issue, *Issue](issues, IssueConverter)
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) ProcessObject(ctx context.Context, user *User, project *Project, issue *Issue) {
 | |
| 	if err := (&issue.Issue).LoadAttributes(ctx); err != nil {
 | |
| 		panic(true)
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) Get(ctx context.Context, user *User, project *Project, exemplar *Issue) *Issue {
 | |
| 	id := exemplar.GetID()
 | |
| 	issue, err := issues_model.GetIssueByIndex(project.GetID(), id)
 | |
| 	if issues_model.IsErrIssueNotExist(err) {
 | |
| 		return &Issue{}
 | |
| 	}
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	i := IssueConverter(issue)
 | |
| 	o.ProcessObject(ctx, user, project, i)
 | |
| 	return i
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) Put(ctx context.Context, user *User, project *Project, issue *Issue) *Issue {
 | |
| 	i := issue.Issue
 | |
| 	i.RepoID = project.GetID()
 | |
| 	labels := make([]int64, 0, len(i.Labels))
 | |
| 	for _, label := range i.Labels {
 | |
| 		labels = append(labels, label.ID)
 | |
| 	}
 | |
| 
 | |
| 	if err := issues_model.NewIssue(&project.Repository, &i, labels, []string{}); err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	return o.Get(ctx, user, project, IssueConverter(&i))
 | |
| }
 | |
| 
 | |
| func (o *IssueProvider) Delete(ctx context.Context, user *User, project *Project, issue *Issue) *Issue {
 | |
| 	m := o.Get(ctx, user, project, issue)
 | |
| 	if !m.IsNil() {
 | |
| 		repoPath := repo_model.RepoPath(user.Name, project.Name)
 | |
| 		gitRepo, err := git.OpenRepository(ctx, repoPath)
 | |
| 		if err != nil {
 | |
| 			panic(err)
 | |
| 		}
 | |
| 		defer gitRepo.Close()
 | |
| 		if err := issue_service.DeleteIssue(ctx, o.g.GetDoer(), gitRepo, &issue.Issue); err != nil {
 | |
| 			panic(err)
 | |
| 		}
 | |
| 	}
 | |
| 	return m
 | |
| }
 |