mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-11-29 09:31:11 -05:00
[Refactor] move APIFormat() of Issue and Label to convert package (#10423)
* Label: delete .APIFormat() and use convert.ToLabel() * move issue APIFormat too * add missing one * move TEST too * handle error -> return empty APIIssue * Apply suggestions from code review Co-Authored-By: guillep2k <18600385+guillep2k@users.noreply.github.com> Co-authored-by: zeripath <art27@cantab.net> Co-authored-by: guillep2k <18600385+guillep2k@users.noreply.github.com>
This commit is contained in:
parent
c32f3da33c
commit
7e8cdba181
11 changed files with 167 additions and 145 deletions
|
@ -138,6 +138,11 @@ func (issue *Issue) GetPullRequest() (pr *PullRequest, err error) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LoadLabels loads labels
|
||||||
|
func (issue *Issue) LoadLabels() error {
|
||||||
|
return issue.loadLabels(x)
|
||||||
|
}
|
||||||
|
|
||||||
func (issue *Issue) loadLabels(e Engine) (err error) {
|
func (issue *Issue) loadLabels(e Engine) (err error) {
|
||||||
if issue.Labels == nil {
|
if issue.Labels == nil {
|
||||||
issue.Labels, err = getLabelsByIssueID(e, issue.ID)
|
issue.Labels, err = getLabelsByIssueID(e, issue.ID)
|
||||||
|
@ -364,76 +369,6 @@ func (issue *Issue) State() api.StateType {
|
||||||
return api.StateOpen
|
return api.StateOpen
|
||||||
}
|
}
|
||||||
|
|
||||||
// APIFormat assumes some fields assigned with values:
|
|
||||||
// Required - Poster, Labels,
|
|
||||||
// Optional - Milestone, Assignee, PullRequest
|
|
||||||
func (issue *Issue) APIFormat() *api.Issue {
|
|
||||||
return issue.apiFormat(x)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (issue *Issue) apiFormat(e Engine) *api.Issue {
|
|
||||||
issue.loadLabels(e)
|
|
||||||
apiLabels := make([]*api.Label, len(issue.Labels))
|
|
||||||
for i := range issue.Labels {
|
|
||||||
apiLabels[i] = issue.Labels[i].APIFormat()
|
|
||||||
}
|
|
||||||
|
|
||||||
issue.loadPoster(e)
|
|
||||||
issue.loadRepo(e)
|
|
||||||
apiIssue := &api.Issue{
|
|
||||||
ID: issue.ID,
|
|
||||||
URL: issue.APIURL(),
|
|
||||||
HTMLURL: issue.HTMLURL(),
|
|
||||||
Index: issue.Index,
|
|
||||||
Poster: issue.Poster.APIFormat(),
|
|
||||||
Title: issue.Title,
|
|
||||||
Body: issue.Content,
|
|
||||||
Labels: apiLabels,
|
|
||||||
State: issue.State(),
|
|
||||||
Comments: issue.NumComments,
|
|
||||||
Created: issue.CreatedUnix.AsTime(),
|
|
||||||
Updated: issue.UpdatedUnix.AsTime(),
|
|
||||||
}
|
|
||||||
|
|
||||||
apiIssue.Repo = &api.RepositoryMeta{
|
|
||||||
ID: issue.Repo.ID,
|
|
||||||
Name: issue.Repo.Name,
|
|
||||||
Owner: issue.Repo.OwnerName,
|
|
||||||
FullName: issue.Repo.FullName(),
|
|
||||||
}
|
|
||||||
|
|
||||||
if issue.ClosedUnix != 0 {
|
|
||||||
apiIssue.Closed = issue.ClosedUnix.AsTimePtr()
|
|
||||||
}
|
|
||||||
|
|
||||||
issue.loadMilestone(e)
|
|
||||||
if issue.Milestone != nil {
|
|
||||||
apiIssue.Milestone = issue.Milestone.APIFormat()
|
|
||||||
}
|
|
||||||
|
|
||||||
issue.loadAssignees(e)
|
|
||||||
if len(issue.Assignees) > 0 {
|
|
||||||
for _, assignee := range issue.Assignees {
|
|
||||||
apiIssue.Assignees = append(apiIssue.Assignees, assignee.APIFormat())
|
|
||||||
}
|
|
||||||
apiIssue.Assignee = issue.Assignees[0].APIFormat() // For compatibility, we're keeping the first assignee as `apiIssue.Assignee`
|
|
||||||
}
|
|
||||||
if issue.IsPull {
|
|
||||||
issue.loadPullRequest(e)
|
|
||||||
apiIssue.PullRequest = &api.PullRequestMeta{
|
|
||||||
HasMerged: issue.PullRequest.HasMerged,
|
|
||||||
}
|
|
||||||
if issue.PullRequest.HasMerged {
|
|
||||||
apiIssue.PullRequest.Merged = issue.PullRequest.MergedUnix.AsTimePtr()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if issue.DeadlineUnix != 0 {
|
|
||||||
apiIssue.Deadline = issue.DeadlineUnix.AsTimePtr()
|
|
||||||
}
|
|
||||||
|
|
||||||
return apiIssue
|
|
||||||
}
|
|
||||||
|
|
||||||
// HashTag returns unique hash tag for issue.
|
// HashTag returns unique hash tag for issue.
|
||||||
func (issue *Issue) HashTag() string {
|
func (issue *Issue) HashTag() string {
|
||||||
return "issue-" + com.ToStr(issue.ID)
|
return "issue-" + com.ToStr(issue.ID)
|
||||||
|
|
|
@ -19,6 +19,11 @@ type IssueAssignees struct {
|
||||||
IssueID int64 `xorm:"INDEX"`
|
IssueID int64 `xorm:"INDEX"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// LoadAssignees load assignees of this issue.
|
||||||
|
func (issue *Issue) LoadAssignees() error {
|
||||||
|
return issue.loadAssignees(x)
|
||||||
|
}
|
||||||
|
|
||||||
// This loads all assignees of an issue
|
// This loads all assignees of an issue
|
||||||
func (issue *Issue) loadAssignees(e Engine) (err error) {
|
func (issue *Issue) loadAssignees(e Engine) (err error) {
|
||||||
// Reset maybe preexisting assignees
|
// Reset maybe preexisting assignees
|
||||||
|
|
|
@ -12,8 +12,6 @@ import (
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
|
||||||
|
|
||||||
"xorm.io/builder"
|
"xorm.io/builder"
|
||||||
"xorm.io/xorm"
|
"xorm.io/xorm"
|
||||||
)
|
)
|
||||||
|
@ -37,16 +35,6 @@ type Label struct {
|
||||||
IsExcluded bool `xorm:"-"`
|
IsExcluded bool `xorm:"-"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// APIFormat converts a Label to the api.Label format
|
|
||||||
func (label *Label) APIFormat() *api.Label {
|
|
||||||
return &api.Label{
|
|
||||||
ID: label.ID,
|
|
||||||
Name: label.Name,
|
|
||||||
Color: strings.TrimLeft(label.Color, "#"),
|
|
||||||
Description: label.Description,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// GetLabelTemplateFile loads the label template file by given name,
|
// GetLabelTemplateFile loads the label template file by given name,
|
||||||
// then parses and returns a list of name-color pairs and optionally description.
|
// then parses and returns a list of name-color pairs and optionally description.
|
||||||
func GetLabelTemplateFile(name string) ([][3]string, error) {
|
func GetLabelTemplateFile(name string) ([][3]string, error) {
|
||||||
|
|
|
@ -8,23 +8,11 @@ import (
|
||||||
"html/template"
|
"html/template"
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
|
||||||
|
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
)
|
)
|
||||||
|
|
||||||
// TODO TestGetLabelTemplateFile
|
// TODO TestGetLabelTemplateFile
|
||||||
|
|
||||||
func TestLabel_APIFormat(t *testing.T) {
|
|
||||||
assert.NoError(t, PrepareTestDatabase())
|
|
||||||
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
|
||||||
assert.Equal(t, api.Label{
|
|
||||||
ID: label.ID,
|
|
||||||
Name: label.Name,
|
|
||||||
Color: "abcdef",
|
|
||||||
}, *label.APIFormat())
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestLabel_CalOpenIssues(t *testing.T) {
|
func TestLabel_CalOpenIssues(t *testing.T) {
|
||||||
assert.NoError(t, PrepareTestDatabase())
|
assert.NoError(t, PrepareTestDatabase())
|
||||||
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
label := AssertExistsAndLoadBean(t, &Label{ID: 1}).(*Label)
|
||||||
|
|
|
@ -5,10 +5,96 @@
|
||||||
package convert
|
package convert
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"strings"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
api "code.gitea.io/gitea/modules/structs"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// ToAPIIssue converts an Issue to API format
|
||||||
|
// it assumes some fields assigned with values:
|
||||||
|
// Required - Poster, Labels,
|
||||||
|
// Optional - Milestone, Assignee, PullRequest
|
||||||
|
func ToAPIIssue(issue *models.Issue) *api.Issue {
|
||||||
|
if err := issue.LoadLabels(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
if err := issue.LoadPoster(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
if err := issue.LoadRepo(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
|
||||||
|
apiIssue := &api.Issue{
|
||||||
|
ID: issue.ID,
|
||||||
|
URL: issue.APIURL(),
|
||||||
|
HTMLURL: issue.HTMLURL(),
|
||||||
|
Index: issue.Index,
|
||||||
|
Poster: issue.Poster.APIFormat(),
|
||||||
|
Title: issue.Title,
|
||||||
|
Body: issue.Content,
|
||||||
|
Labels: ToLabelList(issue.Labels),
|
||||||
|
State: issue.State(),
|
||||||
|
Comments: issue.NumComments,
|
||||||
|
Created: issue.CreatedUnix.AsTime(),
|
||||||
|
Updated: issue.UpdatedUnix.AsTime(),
|
||||||
|
}
|
||||||
|
|
||||||
|
apiIssue.Repo = &api.RepositoryMeta{
|
||||||
|
ID: issue.Repo.ID,
|
||||||
|
Name: issue.Repo.Name,
|
||||||
|
Owner: issue.Repo.OwnerName,
|
||||||
|
FullName: issue.Repo.FullName(),
|
||||||
|
}
|
||||||
|
|
||||||
|
if issue.ClosedUnix != 0 {
|
||||||
|
apiIssue.Closed = issue.ClosedUnix.AsTimePtr()
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := issue.LoadMilestone(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
if issue.Milestone != nil {
|
||||||
|
apiIssue.Milestone = issue.Milestone.APIFormat()
|
||||||
|
}
|
||||||
|
|
||||||
|
if err := issue.LoadAssignees(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
if len(issue.Assignees) > 0 {
|
||||||
|
for _, assignee := range issue.Assignees {
|
||||||
|
apiIssue.Assignees = append(apiIssue.Assignees, assignee.APIFormat())
|
||||||
|
}
|
||||||
|
apiIssue.Assignee = issue.Assignees[0].APIFormat() // For compatibility, we're keeping the first assignee as `apiIssue.Assignee`
|
||||||
|
}
|
||||||
|
if issue.IsPull {
|
||||||
|
if err := issue.LoadPullRequest(); err != nil {
|
||||||
|
return &api.Issue{}
|
||||||
|
}
|
||||||
|
apiIssue.PullRequest = &api.PullRequestMeta{
|
||||||
|
HasMerged: issue.PullRequest.HasMerged,
|
||||||
|
}
|
||||||
|
if issue.PullRequest.HasMerged {
|
||||||
|
apiIssue.PullRequest.Merged = issue.PullRequest.MergedUnix.AsTimePtr()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if issue.DeadlineUnix != 0 {
|
||||||
|
apiIssue.Deadline = issue.DeadlineUnix.AsTimePtr()
|
||||||
|
}
|
||||||
|
|
||||||
|
return apiIssue
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToAPIIssueList converts an IssueList to API format
|
||||||
|
func ToAPIIssueList(il models.IssueList) []*api.Issue {
|
||||||
|
result := make([]*api.Issue, len(il))
|
||||||
|
for i := range il {
|
||||||
|
result[i] = ToAPIIssue(il[i])
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
||||||
// ToTrackedTime converts TrackedTime to API format
|
// ToTrackedTime converts TrackedTime to API format
|
||||||
func ToTrackedTime(t *models.TrackedTime) (apiT *api.TrackedTime) {
|
func ToTrackedTime(t *models.TrackedTime) (apiT *api.TrackedTime) {
|
||||||
apiT = &api.TrackedTime{
|
apiT = &api.TrackedTime{
|
||||||
|
@ -20,7 +106,7 @@ func ToTrackedTime(t *models.TrackedTime) (apiT *api.TrackedTime) {
|
||||||
Created: t.Created,
|
Created: t.Created,
|
||||||
}
|
}
|
||||||
if t.Issue != nil {
|
if t.Issue != nil {
|
||||||
apiT.Issue = t.Issue.APIFormat()
|
apiT.Issue = ToAPIIssue(t.Issue)
|
||||||
}
|
}
|
||||||
if t.User != nil {
|
if t.User != nil {
|
||||||
apiT.UserName = t.User.Name
|
apiT.UserName = t.User.Name
|
||||||
|
@ -36,3 +122,22 @@ func ToTrackedTimeList(tl models.TrackedTimeList) api.TrackedTimeList {
|
||||||
}
|
}
|
||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ToLabel converts Label to API format
|
||||||
|
func ToLabel(label *models.Label) *api.Label {
|
||||||
|
return &api.Label{
|
||||||
|
ID: label.ID,
|
||||||
|
Name: label.Name,
|
||||||
|
Color: strings.TrimLeft(label.Color, "#"),
|
||||||
|
Description: label.Description,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToLabelList converts list of Label to API format
|
||||||
|
func ToLabelList(labels []*models.Label) []*api.Label {
|
||||||
|
result := make([]*api.Label, len(labels))
|
||||||
|
for i := range labels {
|
||||||
|
result[i] = ToLabel(labels[i])
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
|
24
modules/convert/issue_test.go
Normal file
24
modules/convert/issue_test.go
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
// Copyright 2020 The Gitea Authors. All rights reserved.
|
||||||
|
// Use of this source code is governed by a MIT-style
|
||||||
|
// license that can be found in the LICENSE file.
|
||||||
|
|
||||||
|
package convert
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"code.gitea.io/gitea/models"
|
||||||
|
api "code.gitea.io/gitea/modules/structs"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestLabel_ToLabel(t *testing.T) {
|
||||||
|
assert.NoError(t, models.PrepareTestDatabase())
|
||||||
|
label := models.AssertExistsAndLoadBean(t, &models.Label{ID: 1}).(*models.Label)
|
||||||
|
assert.Equal(t, &api.Label{
|
||||||
|
ID: label.ID,
|
||||||
|
Name: label.Name,
|
||||||
|
Color: "abcdef",
|
||||||
|
}, ToLabel(label))
|
||||||
|
}
|
|
@ -31,7 +31,7 @@ func ToAPIPullRequest(pr *models.PullRequest) *api.PullRequest {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
apiIssue := pr.Issue.APIFormat()
|
apiIssue := ToAPIIssue(pr.Issue)
|
||||||
if pr.BaseRepo == nil {
|
if pr.BaseRepo == nil {
|
||||||
pr.BaseRepo, err = models.GetRepositoryByID(pr.BaseRepoID)
|
pr.BaseRepo, err = models.GetRepositoryByID(pr.BaseRepoID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
|
@ -59,7 +59,7 @@ func (m *webhookNotifier) NotifyIssueClearLabels(doer *models.User, issue *model
|
||||||
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
||||||
Action: api.HookIssueLabelCleared,
|
Action: api.HookIssueLabelCleared,
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
})
|
})
|
||||||
|
@ -155,7 +155,7 @@ func (m *webhookNotifier) NotifyIssueChangeAssignee(doer *models.User, issue *mo
|
||||||
mode, _ := models.AccessLevelUnit(doer, issue.Repo, models.UnitTypeIssues)
|
mode, _ := models.AccessLevelUnit(doer, issue.Repo, models.UnitTypeIssues)
|
||||||
apiIssue := &api.IssuePayload{
|
apiIssue := &api.IssuePayload{
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
}
|
}
|
||||||
|
@ -202,7 +202,7 @@ func (m *webhookNotifier) NotifyIssueChangeTitle(doer *models.User, issue *model
|
||||||
From: oldTitle,
|
From: oldTitle,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: issue.Poster.APIFormat(),
|
Sender: issue.Poster.APIFormat(),
|
||||||
})
|
})
|
||||||
|
@ -237,7 +237,7 @@ func (m *webhookNotifier) NotifyIssueChangeStatus(doer *models.User, issue *mode
|
||||||
} else {
|
} else {
|
||||||
apiIssue := &api.IssuePayload{
|
apiIssue := &api.IssuePayload{
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
}
|
}
|
||||||
|
@ -267,7 +267,7 @@ func (m *webhookNotifier) NotifyNewIssue(issue *models.Issue) {
|
||||||
if err := webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
if err := webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
||||||
Action: api.HookIssueOpened,
|
Action: api.HookIssueOpened,
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: issue.Poster.APIFormat(),
|
Sender: issue.Poster.APIFormat(),
|
||||||
}); err != nil {
|
}); err != nil {
|
||||||
|
@ -327,7 +327,7 @@ func (m *webhookNotifier) NotifyIssueChangeContent(doer *models.User, issue *mod
|
||||||
From: oldContent,
|
From: oldContent,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
})
|
})
|
||||||
|
@ -355,7 +355,7 @@ func (m *webhookNotifier) NotifyUpdateComment(doer *models.User, c *models.Comme
|
||||||
mode, _ := models.AccessLevel(doer, c.Issue.Repo)
|
mode, _ := models.AccessLevel(doer, c.Issue.Repo)
|
||||||
if err := webhook_module.PrepareWebhooks(c.Issue.Repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
if err := webhook_module.PrepareWebhooks(c.Issue.Repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
||||||
Action: api.HookIssueCommentEdited,
|
Action: api.HookIssueCommentEdited,
|
||||||
Issue: c.Issue.APIFormat(),
|
Issue: convert.ToAPIIssue(c.Issue),
|
||||||
Comment: c.APIFormat(),
|
Comment: c.APIFormat(),
|
||||||
Changes: &api.ChangesPayload{
|
Changes: &api.ChangesPayload{
|
||||||
Body: &api.ChangesFromPayload{
|
Body: &api.ChangesFromPayload{
|
||||||
|
@ -375,7 +375,7 @@ func (m *webhookNotifier) NotifyCreateIssueComment(doer *models.User, repo *mode
|
||||||
mode, _ := models.AccessLevel(doer, repo)
|
mode, _ := models.AccessLevel(doer, repo)
|
||||||
if err := webhook_module.PrepareWebhooks(repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
if err := webhook_module.PrepareWebhooks(repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
||||||
Action: api.HookIssueCommentCreated,
|
Action: api.HookIssueCommentCreated,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Comment: comment.APIFormat(),
|
Comment: comment.APIFormat(),
|
||||||
Repository: repo.APIFormat(mode),
|
Repository: repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
|
@ -404,7 +404,7 @@ func (m *webhookNotifier) NotifyDeleteComment(doer *models.User, comment *models
|
||||||
|
|
||||||
if err := webhook_module.PrepareWebhooks(comment.Issue.Repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
if err := webhook_module.PrepareWebhooks(comment.Issue.Repo, models.HookEventIssueComment, &api.IssueCommentPayload{
|
||||||
Action: api.HookIssueCommentDeleted,
|
Action: api.HookIssueCommentDeleted,
|
||||||
Issue: comment.Issue.APIFormat(),
|
Issue: convert.ToAPIIssue(comment.Issue),
|
||||||
Comment: comment.APIFormat(),
|
Comment: comment.APIFormat(),
|
||||||
Repository: comment.Issue.Repo.APIFormat(mode),
|
Repository: comment.Issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
|
@ -449,7 +449,7 @@ func (m *webhookNotifier) NotifyIssueChangeLabels(doer *models.User, issue *mode
|
||||||
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
||||||
Action: api.HookIssueLabelUpdated,
|
Action: api.HookIssueLabelUpdated,
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
})
|
})
|
||||||
|
@ -491,7 +491,7 @@ func (m *webhookNotifier) NotifyIssueChangeMilestone(doer *models.User, issue *m
|
||||||
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
err = webhook_module.PrepareWebhooks(issue.Repo, models.HookEventIssues, &api.IssuePayload{
|
||||||
Action: hookAction,
|
Action: hookAction,
|
||||||
Index: issue.Index,
|
Index: issue.Index,
|
||||||
Issue: issue.APIFormat(),
|
Issue: convert.ToAPIIssue(issue),
|
||||||
Repository: issue.Repo.APIFormat(mode),
|
Repository: issue.Repo.APIFormat(mode),
|
||||||
Sender: doer.APIFormat(),
|
Sender: doer.APIFormat(),
|
||||||
})
|
})
|
||||||
|
|
|
@ -13,6 +13,7 @@ import (
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
"code.gitea.io/gitea/modules/context"
|
"code.gitea.io/gitea/modules/context"
|
||||||
|
"code.gitea.io/gitea/modules/convert"
|
||||||
issue_indexer "code.gitea.io/gitea/modules/indexer/issues"
|
issue_indexer "code.gitea.io/gitea/modules/indexer/issues"
|
||||||
"code.gitea.io/gitea/modules/log"
|
"code.gitea.io/gitea/modules/log"
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
@ -168,13 +169,8 @@ func SearchIssues(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiIssues := make([]*api.Issue, len(issues))
|
|
||||||
for i := range issues {
|
|
||||||
apiIssues[i] = issues[i].APIFormat()
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.SetLinkHeader(issueCount, setting.UI.IssuePagingNum)
|
ctx.SetLinkHeader(issueCount, setting.UI.IssuePagingNum)
|
||||||
ctx.JSON(http.StatusOK, &apiIssues)
|
ctx.JSON(http.StatusOK, convert.ToAPIIssueList(issues))
|
||||||
}
|
}
|
||||||
|
|
||||||
// ListIssues list the issues of a repository
|
// ListIssues list the issues of a repository
|
||||||
|
@ -287,13 +283,8 @@ func ListIssues(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiIssues := make([]*api.Issue, len(issues))
|
|
||||||
for i := range issues {
|
|
||||||
apiIssues[i] = issues[i].APIFormat()
|
|
||||||
}
|
|
||||||
|
|
||||||
ctx.SetLinkHeader(ctx.Repo.Repository.NumIssues, listOptions.PageSize)
|
ctx.SetLinkHeader(ctx.Repo.Repository.NumIssues, listOptions.PageSize)
|
||||||
ctx.JSON(http.StatusOK, &apiIssues)
|
ctx.JSON(http.StatusOK, convert.ToAPIIssueList(issues))
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetIssue get an issue of a repository
|
// GetIssue get an issue of a repository
|
||||||
|
@ -335,7 +326,7 @@ func GetIssue(ctx *context.APIContext) {
|
||||||
}
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, issue.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToAPIIssue(issue))
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateIssue create an issue of a repository
|
// CreateIssue create an issue of a repository
|
||||||
|
@ -450,7 +441,7 @@ func CreateIssue(ctx *context.APIContext, form api.CreateIssueOption) {
|
||||||
ctx.Error(http.StatusInternalServerError, "GetIssueByID", err)
|
ctx.Error(http.StatusInternalServerError, "GetIssueByID", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusCreated, issue.APIFormat())
|
ctx.JSON(http.StatusCreated, convert.ToAPIIssue(issue))
|
||||||
}
|
}
|
||||||
|
|
||||||
// EditIssue modify an issue of a repository
|
// EditIssue modify an issue of a repository
|
||||||
|
@ -596,7 +587,7 @@ func EditIssue(ctx *context.APIContext, form api.EditIssueOption) {
|
||||||
ctx.InternalServerError(err)
|
ctx.InternalServerError(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusCreated, issue.APIFormat())
|
ctx.JSON(http.StatusCreated, convert.ToAPIIssue(issue))
|
||||||
}
|
}
|
||||||
|
|
||||||
// UpdateIssueDeadline updates an issue deadline
|
// UpdateIssueDeadline updates an issue deadline
|
||||||
|
|
|
@ -10,6 +10,7 @@ import (
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
"code.gitea.io/gitea/modules/context"
|
"code.gitea.io/gitea/modules/context"
|
||||||
|
"code.gitea.io/gitea/modules/convert"
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
api "code.gitea.io/gitea/modules/structs"
|
||||||
issue_service "code.gitea.io/gitea/services/issue"
|
issue_service "code.gitea.io/gitea/services/issue"
|
||||||
)
|
)
|
||||||
|
@ -59,11 +60,7 @@ func ListIssueLabels(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiLabels := make([]*api.Label, len(issue.Labels))
|
ctx.JSON(http.StatusOK, convert.ToLabelList(issue.Labels))
|
||||||
for i := range issue.Labels {
|
|
||||||
apiLabels[i] = issue.Labels[i].APIFormat()
|
|
||||||
}
|
|
||||||
ctx.JSON(http.StatusOK, &apiLabels)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// AddIssueLabels add labels for an issue
|
// AddIssueLabels add labels for an issue
|
||||||
|
@ -118,11 +115,7 @@ func AddIssueLabels(ctx *context.APIContext, form api.IssueLabelsOption) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiLabels := make([]*api.Label, len(labels))
|
ctx.JSON(http.StatusOK, convert.ToLabelList(labels))
|
||||||
for i := range labels {
|
|
||||||
apiLabels[i] = labels[i].APIFormat()
|
|
||||||
}
|
|
||||||
ctx.JSON(http.StatusOK, &apiLabels)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteIssueLabel delete a label for an issue
|
// DeleteIssueLabel delete a label for an issue
|
||||||
|
@ -248,11 +241,7 @@ func ReplaceIssueLabels(ctx *context.APIContext, form api.IssueLabelsOption) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiLabels := make([]*api.Label, len(labels))
|
ctx.JSON(http.StatusOK, convert.ToLabelList(labels))
|
||||||
for i := range labels {
|
|
||||||
apiLabels[i] = labels[i].APIFormat()
|
|
||||||
}
|
|
||||||
ctx.JSON(http.StatusOK, &apiLabels)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// ClearIssueLabels delete all the labels for an issue
|
// ClearIssueLabels delete all the labels for an issue
|
||||||
|
|
|
@ -13,6 +13,7 @@ import (
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
"code.gitea.io/gitea/modules/context"
|
"code.gitea.io/gitea/modules/context"
|
||||||
|
"code.gitea.io/gitea/modules/convert"
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
api "code.gitea.io/gitea/modules/structs"
|
||||||
"code.gitea.io/gitea/routers/api/v1/utils"
|
"code.gitea.io/gitea/routers/api/v1/utils"
|
||||||
)
|
)
|
||||||
|
@ -53,11 +54,7 @@ func ListLabels(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
apiLabels := make([]*api.Label, len(labels))
|
ctx.JSON(http.StatusOK, convert.ToLabelList(labels))
|
||||||
for i := range labels {
|
|
||||||
apiLabels[i] = labels[i].APIFormat()
|
|
||||||
}
|
|
||||||
ctx.JSON(http.StatusOK, &apiLabels)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetLabel get label by repository and label id
|
// GetLabel get label by repository and label id
|
||||||
|
@ -107,7 +104,7 @@ func GetLabel(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.JSON(http.StatusOK, label.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToLabel(label))
|
||||||
}
|
}
|
||||||
|
|
||||||
// CreateLabel create a label for a repository
|
// CreateLabel create a label for a repository
|
||||||
|
@ -159,7 +156,7 @@ func CreateLabel(ctx *context.APIContext, form api.CreateLabelOption) {
|
||||||
ctx.Error(http.StatusInternalServerError, "NewLabel", err)
|
ctx.Error(http.StatusInternalServerError, "NewLabel", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusCreated, label.APIFormat())
|
ctx.JSON(http.StatusCreated, convert.ToLabel(label))
|
||||||
}
|
}
|
||||||
|
|
||||||
// EditLabel modify a label for a repository
|
// EditLabel modify a label for a repository
|
||||||
|
@ -228,7 +225,7 @@ func EditLabel(ctx *context.APIContext, form api.EditLabelOption) {
|
||||||
ctx.ServerError("UpdateLabel", err)
|
ctx.ServerError("UpdateLabel", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, label.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToLabel(label))
|
||||||
}
|
}
|
||||||
|
|
||||||
// DeleteLabel delete a label for a repository
|
// DeleteLabel delete a label for a repository
|
||||||
|
|
Loading…
Reference in a new issue