diff options
author | Ethan Koenig <ethantkoenig@gmail.com> | 2016-12-31 11:51:22 -0500 |
---|---|---|
committer | Kim "BKC" Carlbäcker <kim.carlbacker@gmail.com> | 2017-01-02 00:10:52 +0100 |
commit | 0c301f7b5c7a9cc691421724c154b40247aa6959 (patch) | |
tree | e509a85e0cc5a63cc4f8555269a8ae23ca754094 /routers/api | |
parent | b7e1bccc501c5246e6f8b9bed4853b90e9a447c5 (diff) | |
download | gitea-0c301f7b5c7a9cc691421724c154b40247aa6959.tar.gz gitea-0c301f7b5c7a9cc691421724c154b40247aa6959.zip |
Release API endpoints
Diffstat (limited to 'routers/api')
-rw-r--r-- | routers/api/v1/api.go | 7 | ||||
-rw-r--r-- | routers/api/v1/repo/release.go | 186 |
2 files changed, 193 insertions, 0 deletions
diff --git a/routers/api/v1/api.go b/routers/api/v1/api.go index 46695c79e9..c35f9afa6f 100644 --- a/routers/api/v1/api.go +++ b/routers/api/v1/api.go @@ -331,6 +331,13 @@ func RegisterRoutes(m *macaron.Macaron) { m.Put("", user.Watch) m.Delete("", user.Unwatch) }) + m.Group("/releases", func() { + m.Combo("").Get(repo.ListReleases). + Post(bind(api.CreateReleaseOption{}), repo.CreateRelease) + m.Combo("/:id").Get(repo.GetRelease). + Patch(bind(api.EditReleaseOption{}), repo.EditRelease). + Delete(repo.DeleteRelease) + }) m.Get("/editorconfig/:filename", context.RepoRef(), repo.GetEditorconfig) m.Group("/pulls", func() { m.Combo("").Get(bind(api.ListPullRequestsOptions{}), repo.ListPullRequests).Post(reqRepoWriter(), bind(api.CreatePullRequestOption{}), repo.CreatePullRequest) diff --git a/routers/api/v1/repo/release.go b/routers/api/v1/repo/release.go new file mode 100644 index 0000000000..e07fc42305 --- /dev/null +++ b/routers/api/v1/repo/release.go @@ -0,0 +1,186 @@ +// Copyright 2016 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 repo + +import ( + "strings" + + api "code.gitea.io/sdk/gitea" + + "code.gitea.io/gitea/models" + "code.gitea.io/gitea/modules/context" +) + +// GetRelease get a single release of a repository +func GetRelease(ctx *context.APIContext) { + id := ctx.ParamsInt64(":id") + release, err := models.GetReleaseByID(id) + if err != nil { + ctx.Error(500, "GetReleaseByID", err) + return + } + if release.RepoID != ctx.Repo.Repository.ID { + ctx.Status(404) + return + } + if err := release.LoadAttributes(); err != nil { + ctx.Error(500, "LoadAttributes", err) + return + } + ctx.JSON(200, release.APIFormat()) +} + +// ListReleases list a repository's releases +func ListReleases(ctx *context.APIContext) { + releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, 1, 2147483647) + if err != nil { + ctx.Error(500, "GetReleasesByRepoID", err) + return + } + rels := make([]*api.Release, len(releases)) + access, err := models.AccessLevel(ctx.User, ctx.Repo.Repository) + if err != nil { + ctx.Error(500, "AccessLevel", err) + return + } + for i, release := range releases { + if release.IsDraft && access < models.AccessModeWrite { + // hide drafts from users without push access + continue + } + if err := release.LoadAttributes(); err != nil { + ctx.Error(500, "LoadAttributes", err) + return + } + rels[i] = release.APIFormat() + } + ctx.JSON(200, rels) +} + +// CreateRelease create a release +func CreateRelease(ctx *context.APIContext, form api.CreateReleaseOption) { + if ctx.Repo.AccessMode < models.AccessModeWrite { + ctx.Status(403) + return + } + if !ctx.Repo.GitRepo.IsTagExist(form.TagName) { + ctx.Status(404) + return + } + tag, err := ctx.Repo.GitRepo.GetTag(form.TagName) + if err != nil { + ctx.Error(500, "GetTag", err) + return + } + commit, err := tag.Commit() + if err != nil { + ctx.Error(500, "Commit", err) + return + } + commitsCount, err := commit.CommitsCount() + if err != nil { + ctx.Error(500, "CommitsCount", err) + return + } + rel := &models.Release{ + RepoID: ctx.Repo.Repository.ID, + PublisherID: ctx.User.ID, + Publisher: ctx.User, + TagName: form.TagName, + LowerTagName: strings.ToLower(form.TagName), + Target: form.Target, + Title: form.Title, + Sha1: commit.ID.String(), + NumCommits: commitsCount, + Note: form.Note, + IsDraft: form.IsDraft, + IsPrerelease: form.IsPrerelease, + CreatedUnix: commit.Author.When.Unix(), + } + if err := models.CreateRelease(ctx.Repo.GitRepo, rel); err != nil { + if models.IsErrReleaseAlreadyExist(err) { + ctx.Status(409) + } else { + ctx.Error(500, "CreateRelease", err) + } + return + } + ctx.JSON(201, rel.APIFormat()) +} + +// EditRelease edit a release +func EditRelease(ctx *context.APIContext, form api.EditReleaseOption) { + if ctx.Repo.AccessMode < models.AccessModeWrite { + ctx.Status(403) + return + } + id := ctx.ParamsInt64(":id") + rel, err := models.GetReleaseByID(id) + if err != nil { + ctx.Error(500, "GetReleaseByID", err) + return + } + if rel.RepoID != ctx.Repo.Repository.ID { + ctx.Status(404) + return + } + + if len(form.TagName) > 0 { + rel.TagName = form.TagName + } + if len(form.Target) > 0 { + rel.Target = form.Target + } + if len(form.Title) > 0 { + rel.Title = form.Title + } + if len(form.Note) > 0 { + rel.Note = form.Note + } + if form.IsDraft != nil { + rel.IsDraft = *form.IsDraft + } + if form.IsPrerelease != nil { + rel.IsPrerelease = *form.IsPrerelease + } + if err := models.UpdateRelease(ctx.Repo.GitRepo, rel); err != nil { + ctx.Error(500, "UpdateRelease", err) + return + } + + rel, err = models.GetReleaseByID(id) + if err != nil { + ctx.Error(500, "GetReleaseByID", err) + return + } + if err := rel.LoadAttributes(); err != nil { + ctx.Error(500, "LoadAttributes", err) + return + } + ctx.JSON(200, rel.APIFormat()) +} + +// DeleteRelease delete a release from a repository +func DeleteRelease(ctx *context.APIContext) { + if ctx.Repo.AccessMode < models.AccessModeWrite { + ctx.Status(403) + return + } + id := ctx.ParamsInt64(":id") + release, err := models.GetReleaseByID(id) + if err != nil { + ctx.Error(500, "GetReleaseByID", err) + return + } + if release.RepoID != ctx.Repo.Repository.ID { + ctx.Status(404) + return + } + if err := models.DeleteReleaseByID(id, ctx.User); err != nil { + ctx.Error(500, "DeleteReleaseByID", err) + return + } + ctx.Status(204) +} |