aboutsummaryrefslogtreecommitdiff
path: root/routes/api/v1/repo/repo.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2018-12-02 12:55:05 -0500
committerUnknwon <u@gogs.io>2018-12-02 12:55:05 -0500
commite1b3a250085195122c3b41b998504692f47fcb63 (patch)
tree40614fe982572c95f401af688c7d4d1617921ae8 /routes/api/v1/repo/repo.go
parent69c1cd3f381b19b988a6af51a8e38303f216b001 (diff)
api/repo: support edit repository issue tracker (gogs/go-gogs-client#94)
Diffstat (limited to 'routes/api/v1/repo/repo.go')
-rw-r--r--routes/api/v1/repo/repo.go31
1 files changed, 31 insertions, 0 deletions
diff --git a/routes/api/v1/repo/repo.go b/routes/api/v1/repo/repo.go
index 6d4d0497..9c1ab476 100644
--- a/routes/api/v1/repo/repo.go
+++ b/routes/api/v1/repo/repo.go
@@ -291,6 +291,7 @@ func Migrate(c *context.APIContext, f form.MigrateRepo) {
c.JSON(201, repo.APIFormat(&api.Permission{true, true, true}))
}
+// FIXME: Inject to *context.APIContext
func parseOwnerAndRepo(c *context.APIContext) (*models.User, *models.Repository) {
owner, err := models.GetUserByName(c.Params(":username"))
if err != nil {
@@ -373,6 +374,36 @@ func ListForks(c *context.APIContext) {
c.JSON(200, &apiForks)
}
+func IssueTracker(c *context.APIContext, form api.EditIssueTrackerOption) {
+ _, repo := parseOwnerAndRepo(c)
+ if c.Written() {
+ return
+ }
+
+ if form.EnableIssues != nil {
+ repo.EnableIssues = *form.EnableIssues
+ }
+ if form.EnableExternalTracker != nil {
+ repo.EnableExternalTracker = *form.EnableExternalTracker
+ }
+ if form.ExternalTrackerURL != nil {
+ repo.ExternalTrackerURL = *form.ExternalTrackerURL
+ }
+ if form.TrackerURLFormat != nil {
+ repo.ExternalTrackerFormat = *form.TrackerURLFormat
+ }
+ if form.TrackerIssueStyle != nil {
+ repo.ExternalTrackerStyle = *form.TrackerIssueStyle
+ }
+
+ if err := models.UpdateRepository(repo, false); err != nil {
+ c.ServerError("UpdateRepository", err)
+ return
+ }
+
+ c.NoContent()
+}
+
func MirrorSync(c *context.APIContext) {
_, repo := parseOwnerAndRepo(c)
if c.Written() {