Skip to content

Commit e6a97b6

Browse files
ethantkoeniglunny
authored andcommitted
Use api.TrackedTime in API (#2807)
* Use api.TrackedTime in API * APIFormat() method * Rename function
1 parent e225497 commit e6a97b6

File tree

2 files changed

+47
-16
lines changed

2 files changed

+47
-16
lines changed

models/issue_tracked_time.go

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,8 @@ package models
77
import (
88
"time"
99

10+
api "code.gitea.io/sdk/gitea"
11+
1012
"github.com/go-xorm/builder"
1113
)
1214

@@ -25,6 +27,17 @@ func (t *TrackedTime) AfterLoad() {
2527
t.Created = time.Unix(t.CreatedUnix, 0).Local()
2628
}
2729

30+
// APIFormat converts TrackedTime to API format
31+
func (t *TrackedTime) APIFormat() *api.TrackedTime {
32+
return &api.TrackedTime{
33+
ID: t.ID,
34+
IssueID: t.IssueID,
35+
UserID: t.UserID,
36+
Time: t.Time,
37+
Created: t.Created,
38+
}
39+
}
40+
2841
// FindTrackedTimesOptions represent the filters for tracked times. If an ID is 0 it will be ignored.
2942
type FindTrackedTimesOptions struct {
3043
IssueID int64

routers/api/v1/repo/issue_tracked_time.go

Lines changed: 34 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,14 @@ import (
1010
api "code.gitea.io/sdk/gitea"
1111
)
1212

13+
func trackedTimesToAPIFormat(trackedTimes []*models.TrackedTime) []*api.TrackedTime {
14+
apiTrackedTimes := make([]*api.TrackedTime, len(trackedTimes))
15+
for i, trackedTime := range trackedTimes {
16+
apiTrackedTimes[i] = trackedTime.APIFormat()
17+
}
18+
return apiTrackedTimes
19+
}
20+
1321
// ListTrackedTimes list all the tracked times of an issue
1422
func ListTrackedTimes(ctx *context.APIContext) {
1523
// swagger:route GET /repos/{username}/{reponame}/issues/{issue}/times repository issueTrackedTimes
@@ -35,11 +43,13 @@ func ListTrackedTimes(ctx *context.APIContext) {
3543
return
3644
}
3745

38-
if trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{IssueID: issue.ID}); err != nil {
46+
trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{IssueID: issue.ID})
47+
if err != nil {
3948
ctx.Error(500, "GetTrackedTimesByIssue", err)
40-
} else {
41-
ctx.JSON(200, &trackedTimes)
49+
return
4250
}
51+
apiTrackedTimes := trackedTimesToAPIFormat(trackedTimes)
52+
ctx.JSON(200, &apiTrackedTimes)
4353
}
4454

4555
// AddTime adds time manual to the given issue
@@ -73,13 +83,12 @@ func AddTime(ctx *context.APIContext, form api.AddTimeOption) {
7383
ctx.Status(403)
7484
return
7585
}
76-
var tt *models.TrackedTime
77-
if tt, err = models.AddTime(ctx.User, issue, form.Time); err != nil {
86+
trackedTime, err := models.AddTime(ctx.User, issue, form.Time)
87+
if err != nil {
7888
ctx.Error(500, "AddTime", err)
7989
return
8090
}
81-
ctx.JSON(200, tt)
82-
91+
ctx.JSON(200, trackedTime.APIFormat())
8392
}
8493

8594
// ListTrackedTimesByUser lists all tracked times of the user
@@ -111,11 +120,15 @@ func ListTrackedTimesByUser(ctx *context.APIContext) {
111120
ctx.Status(404)
112121
return
113122
}
114-
if trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{UserID: user.ID, RepositoryID: ctx.Repo.Repository.ID}); err != nil {
123+
trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{
124+
UserID: user.ID,
125+
RepositoryID: ctx.Repo.Repository.ID})
126+
if err != nil {
115127
ctx.Error(500, "GetTrackedTimesByUser", err)
116-
} else {
117-
ctx.JSON(200, &trackedTimes)
128+
return
118129
}
130+
apiTrackedTimes := trackedTimesToAPIFormat(trackedTimes)
131+
ctx.JSON(200, &apiTrackedTimes)
119132
}
120133

121134
// ListTrackedTimesByRepository lists all tracked times of the user
@@ -133,11 +146,14 @@ func ListTrackedTimesByRepository(ctx *context.APIContext) {
133146
ctx.JSON(400, struct{ Message string }{Message: "time tracking disabled"})
134147
return
135148
}
136-
if trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{RepositoryID: ctx.Repo.Repository.ID}); err != nil {
149+
trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{
150+
RepositoryID: ctx.Repo.Repository.ID})
151+
if err != nil {
137152
ctx.Error(500, "GetTrackedTimesByUser", err)
138-
} else {
139-
ctx.JSON(200, &trackedTimes)
153+
return
140154
}
155+
apiTrackedTimes := trackedTimesToAPIFormat(trackedTimes)
156+
ctx.JSON(200, &apiTrackedTimes)
141157
}
142158

143159
// ListMyTrackedTimes lists all tracked times of the current user
@@ -150,9 +166,11 @@ func ListMyTrackedTimes(ctx *context.APIContext) {
150166
// Responses:
151167
// 200: TrackedTimes
152168
// 500: error
153-
if trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{UserID: ctx.User.ID}); err != nil {
169+
trackedTimes, err := models.GetTrackedTimes(models.FindTrackedTimesOptions{UserID: ctx.User.ID})
170+
if err != nil {
154171
ctx.Error(500, "GetTrackedTimesByUser", err)
155-
} else {
156-
ctx.JSON(200, &trackedTimes)
172+
return
157173
}
174+
apiTrackedTimes := trackedTimesToAPIFormat(trackedTimes)
175+
ctx.JSON(200, &apiTrackedTimes)
158176
}

0 commit comments

Comments
 (0)