mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-11 11:53:56 +01:00
Move tracked time api convert to convert package (#9665)
This commit is contained in:
parent
705b1e49a8
commit
4d06d10dba
3 changed files with 44 additions and 34 deletions
|
@ -8,7 +8,6 @@ import (
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"code.gitea.io/gitea/modules/setting"
|
"code.gitea.io/gitea/modules/setting"
|
||||||
api "code.gitea.io/gitea/modules/structs"
|
|
||||||
|
|
||||||
"xorm.io/builder"
|
"xorm.io/builder"
|
||||||
"xorm.io/xorm"
|
"xorm.io/xorm"
|
||||||
|
@ -60,25 +59,6 @@ func (t *TrackedTime) loadAttributes(e Engine) (err error) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// APIFormat converts TrackedTime to API format
|
|
||||||
func (t *TrackedTime) APIFormat() (apiT *api.TrackedTime) {
|
|
||||||
apiT = &api.TrackedTime{
|
|
||||||
ID: t.ID,
|
|
||||||
IssueID: t.IssueID,
|
|
||||||
UserID: t.UserID,
|
|
||||||
UserName: t.User.Name,
|
|
||||||
Time: t.Time,
|
|
||||||
Created: t.Created,
|
|
||||||
}
|
|
||||||
if t.Issue != nil {
|
|
||||||
apiT.Issue = t.Issue.APIFormat()
|
|
||||||
}
|
|
||||||
if t.User != nil {
|
|
||||||
apiT.UserName = t.User.Name
|
|
||||||
}
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// LoadAttributes load Issue, User
|
// LoadAttributes load Issue, User
|
||||||
func (tl TrackedTimeList) LoadAttributes() (err error) {
|
func (tl TrackedTimeList) LoadAttributes() (err error) {
|
||||||
for _, t := range tl {
|
for _, t := range tl {
|
||||||
|
@ -89,15 +69,6 @@ func (tl TrackedTimeList) LoadAttributes() (err error) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// APIFormat converts TrackedTimeList to API format
|
|
||||||
func (tl TrackedTimeList) APIFormat() api.TrackedTimeList {
|
|
||||||
result := make([]*api.TrackedTime, 0, len(tl))
|
|
||||||
for _, t := range tl {
|
|
||||||
result = append(result, t.APIFormat())
|
|
||||||
}
|
|
||||||
return result
|
|
||||||
}
|
|
||||||
|
|
||||||
// FindTrackedTimesOptions represent the filters for tracked times. If an ID is 0 it will be ignored.
|
// FindTrackedTimesOptions represent the filters for tracked times. If an ID is 0 it will be ignored.
|
||||||
type FindTrackedTimesOptions struct {
|
type FindTrackedTimesOptions struct {
|
||||||
IssueID int64
|
IssueID int64
|
||||||
|
|
38
modules/convert/issue.go
Normal file
38
modules/convert/issue.go
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
// 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 (
|
||||||
|
"code.gitea.io/gitea/models"
|
||||||
|
api "code.gitea.io/gitea/modules/structs"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ToTrackedTime converts TrackedTime to API format
|
||||||
|
func ToTrackedTime(t *models.TrackedTime) (apiT *api.TrackedTime) {
|
||||||
|
apiT = &api.TrackedTime{
|
||||||
|
ID: t.ID,
|
||||||
|
IssueID: t.IssueID,
|
||||||
|
UserID: t.UserID,
|
||||||
|
UserName: t.User.Name,
|
||||||
|
Time: t.Time,
|
||||||
|
Created: t.Created,
|
||||||
|
}
|
||||||
|
if t.Issue != nil {
|
||||||
|
apiT.Issue = t.Issue.APIFormat()
|
||||||
|
}
|
||||||
|
if t.User != nil {
|
||||||
|
apiT.UserName = t.User.Name
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// ToTrackedTimeList converts TrackedTimeList to API format
|
||||||
|
func ToTrackedTimeList(tl models.TrackedTimeList) api.TrackedTimeList {
|
||||||
|
result := make([]*api.TrackedTime, 0, len(tl))
|
||||||
|
for _, t := range tl {
|
||||||
|
result = append(result, ToTrackedTime(t))
|
||||||
|
}
|
||||||
|
return result
|
||||||
|
}
|
|
@ -12,6 +12,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"
|
||||||
)
|
)
|
||||||
|
@ -93,7 +94,7 @@ func ListTrackedTimes(ctx *context.APIContext) {
|
||||||
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, trackedTimes.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToTrackedTimeList(trackedTimes))
|
||||||
}
|
}
|
||||||
|
|
||||||
// AddTime add time manual to the given issue
|
// AddTime add time manual to the given issue
|
||||||
|
@ -178,7 +179,7 @@ func AddTime(ctx *context.APIContext, form api.AddTimeOption) {
|
||||||
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, trackedTime.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToTrackedTime(trackedTime))
|
||||||
}
|
}
|
||||||
|
|
||||||
// ResetIssueTime reset time manual to the given issue
|
// ResetIssueTime reset time manual to the given issue
|
||||||
|
@ -399,7 +400,7 @@ func ListTrackedTimesByUser(ctx *context.APIContext) {
|
||||||
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, trackedTimes.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToTrackedTimeList(trackedTimes))
|
||||||
}
|
}
|
||||||
|
|
||||||
// ListTrackedTimesByRepository lists all tracked times of the repository
|
// ListTrackedTimesByRepository lists all tracked times of the repository
|
||||||
|
@ -486,7 +487,7 @@ func ListTrackedTimesByRepository(ctx *context.APIContext) {
|
||||||
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ctx.JSON(http.StatusOK, trackedTimes.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToTrackedTimeList(trackedTimes))
|
||||||
}
|
}
|
||||||
|
|
||||||
// ListMyTrackedTimes lists all tracked times of the current user
|
// ListMyTrackedTimes lists all tracked times of the current user
|
||||||
|
@ -530,5 +531,5 @@ func ListMyTrackedTimes(ctx *context.APIContext) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.JSON(http.StatusOK, trackedTimes.APIFormat())
|
ctx.JSON(http.StatusOK, convert.ToTrackedTimeList(trackedTimes))
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue