summaryrefslogtreecommitdiffstats
path: root/routers/api
diff options
context:
space:
mode:
Diffstat (limited to 'routers/api')
-rw-r--r--routers/api/v1/repo/issue.go27
-rw-r--r--routers/api/v1/repo/pull.go35
2 files changed, 48 insertions, 14 deletions
diff --git a/routers/api/v1/repo/issue.go b/routers/api/v1/repo/issue.go
index ce13d8a6ed..cc033554f3 100644
--- a/routers/api/v1/repo/issue.go
+++ b/routers/api/v1/repo/issue.go
@@ -163,12 +163,19 @@ func CreateIssue(ctx *context.APIContext, form api.CreateIssueOption) {
// responses:
// "201":
// "$ref": "#/responses/Issue"
+
+ var deadlineUnix util.TimeStamp
+ if form.Deadline != nil {
+ deadlineUnix = util.TimeStamp(form.Deadline.Unix())
+ }
+
issue := &models.Issue{
- RepoID: ctx.Repo.Repository.ID,
- Title: form.Title,
- PosterID: ctx.User.ID,
- Poster: ctx.User,
- Content: form.Body,
+ RepoID: ctx.Repo.Repository.ID,
+ Title: form.Title,
+ PosterID: ctx.User.ID,
+ Poster: ctx.User,
+ Content: form.Body,
+ DeadlineUnix: deadlineUnix,
}
if ctx.Repo.IsWriter() {
@@ -265,6 +272,16 @@ func EditIssue(ctx *context.APIContext, form api.EditIssueOption) {
issue.Content = *form.Body
}
+ var deadlineUnix util.TimeStamp
+ if form.Deadline != nil && !form.Deadline.IsZero() {
+ deadlineUnix = util.TimeStamp(form.Deadline.Unix())
+ }
+
+ if err := models.UpdateIssueDeadline(issue, deadlineUnix, ctx.User); err != nil {
+ ctx.Error(500, "UpdateIssueDeadline", err)
+ return
+ }
+
if ctx.Repo.IsWriter() && form.Assignee != nil &&
(issue.Assignee == nil || issue.Assignee.LowerName != strings.ToLower(*form.Assignee)) {
if len(*form.Assignee) == 0 {
diff --git a/routers/api/v1/repo/pull.go b/routers/api/v1/repo/pull.go
index 742c0bccf9..3ea4b8d327 100644
--- a/routers/api/v1/repo/pull.go
+++ b/routers/api/v1/repo/pull.go
@@ -13,6 +13,7 @@ import (
"code.gitea.io/gitea/modules/auth"
"code.gitea.io/gitea/modules/context"
"code.gitea.io/gitea/modules/log"
+ "code.gitea.io/gitea/modules/util"
api "code.gitea.io/sdk/gitea"
)
@@ -236,16 +237,22 @@ func CreatePullRequest(ctx *context.APIContext, form api.CreatePullRequestOption
return
}
+ var deadlineUnix util.TimeStamp
+ if form.Deadline != nil {
+ deadlineUnix = util.TimeStamp(form.Deadline.Unix())
+ }
+
prIssue := &models.Issue{
- RepoID: repo.ID,
- Index: repo.NextIssueIndex(),
- Title: form.Title,
- PosterID: ctx.User.ID,
- Poster: ctx.User,
- MilestoneID: milestoneID,
- AssigneeID: assigneeID,
- IsPull: true,
- Content: form.Body,
+ RepoID: repo.ID,
+ Index: repo.NextIssueIndex(),
+ Title: form.Title,
+ PosterID: ctx.User.ID,
+ Poster: ctx.User,
+ MilestoneID: milestoneID,
+ AssigneeID: assigneeID,
+ IsPull: true,
+ Content: form.Body,
+ DeadlineUnix: deadlineUnix,
}
pr := &models.PullRequest{
HeadRepoID: headRepo.ID,
@@ -328,6 +335,16 @@ func EditPullRequest(ctx *context.APIContext, form api.EditPullRequestOption) {
issue.Content = form.Body
}
+ var deadlineUnix util.TimeStamp
+ if form.Deadline != nil && !form.Deadline.IsZero() {
+ deadlineUnix = util.TimeStamp(form.Deadline.Unix())
+ }
+
+ if err := models.UpdateIssueDeadline(issue, deadlineUnix, ctx.User); err != nil {
+ ctx.Error(500, "UpdateIssueDeadline", err)
+ return
+ }
+
if ctx.Repo.IsWriter() && len(form.Assignee) > 0 &&
(issue.Assignee == nil || issue.Assignee.LowerName != strings.ToLower(form.Assignee)) {
if len(form.Assignee) == 0 {