- // 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 (
- "code.gitea.io/gitea/models"
- "code.gitea.io/gitea/modules/context"
- "code.gitea.io/gitea/modules/setting"
- api "code.gitea.io/gitea/modules/structs"
- releaseservice "code.gitea.io/gitea/services/release"
- )
-
- // GetRelease get a single release of a repository
- func GetRelease(ctx *context.APIContext) {
- // swagger:operation GET /repos/{owner}/{repo}/releases/{id} repository repoGetRelease
- // ---
- // summary: Get a release
- // produces:
- // - application/json
- // parameters:
- // - name: owner
- // in: path
- // description: owner of the repo
- // type: string
- // required: true
- // - name: repo
- // in: path
- // description: name of the repo
- // type: string
- // required: true
- // - name: id
- // in: path
- // description: id of the release to get
- // type: integer
- // format: int64
- // required: true
- // responses:
- // "200":
- // "$ref": "#/responses/Release"
- 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.NotFound()
- return
- }
- if err := release.LoadAttributes(); err != nil {
- ctx.Error(500, "LoadAttributes", err)
- return
- }
- ctx.JSON(200, release.APIFormat())
- }
-
- func getPagesInfo(ctx *context.APIContext) (int, int) {
- page := ctx.QueryInt("page")
- if page == 0 {
- page = 1
- }
- perPage := ctx.QueryInt("per_page")
- if perPage == 0 {
- perPage = setting.API.DefaultPagingNum
- } else if perPage > setting.API.MaxResponseItems {
- perPage = setting.API.MaxResponseItems
- }
- return page, perPage
- }
-
- // ListReleases list a repository's releases
- func ListReleases(ctx *context.APIContext) {
- // swagger:operation GET /repos/{owner}/{repo}/releases repository repoListReleases
- // ---
- // summary: List a repo's releases
- // produces:
- // - application/json
- // parameters:
- // - name: owner
- // in: path
- // description: owner of the repo
- // type: string
- // required: true
- // - name: repo
- // in: path
- // description: name of the repo
- // type: string
- // required: true
- // - name: page
- // in: query
- // description: page wants to load
- // type: integer
- // - name: per_page
- // in: query
- // description: items count every page wants to load
- // type: integer
- // responses:
- // "200":
- // "$ref": "#/responses/ReleaseList"
- page, limit := getPagesInfo(ctx)
- releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, models.FindReleasesOptions{
- IncludeDrafts: ctx.Repo.AccessMode >= models.AccessModeWrite,
- IncludeTags: false,
- }, page, limit)
- if err != nil {
- ctx.Error(500, "GetReleasesByRepoID", err)
- return
- }
- rels := make([]*api.Release, len(releases))
- for i, release := range releases {
- 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) {
- // swagger:operation POST /repos/{owner}/{repo}/releases repository repoCreateRelease
- // ---
- // summary: Create a release
- // consumes:
- // - application/json
- // produces:
- // - application/json
- // parameters:
- // - name: owner
- // in: path
- // description: owner of the repo
- // type: string
- // required: true
- // - name: repo
- // in: path
- // description: name of the repo
- // type: string
- // required: true
- // - name: body
- // in: body
- // schema:
- // "$ref": "#/definitions/CreateReleaseOption"
- // responses:
- // "201":
- // "$ref": "#/responses/Release"
- rel, err := models.GetRelease(ctx.Repo.Repository.ID, form.TagName)
- if err != nil {
- if !models.IsErrReleaseNotExist(err) {
- ctx.ServerError("GetRelease", err)
- return
- }
- // If target is not provided use default branch
- if len(form.Target) == 0 {
- form.Target = ctx.Repo.Repository.DefaultBranch
- }
- rel = &models.Release{
- RepoID: ctx.Repo.Repository.ID,
- PublisherID: ctx.User.ID,
- Publisher: ctx.User,
- TagName: form.TagName,
- Target: form.Target,
- Title: form.Title,
- Note: form.Note,
- IsDraft: form.IsDraft,
- IsPrerelease: form.IsPrerelease,
- IsTag: false,
- Repo: ctx.Repo.Repository,
- }
- if err := releaseservice.CreateRelease(ctx.Repo.GitRepo, rel, nil); err != nil {
- if models.IsErrReleaseAlreadyExist(err) {
- ctx.Status(409)
- } else {
- ctx.Error(500, "CreateRelease", err)
- }
- return
- }
- } else {
- if !rel.IsTag {
- ctx.Status(409)
- return
- }
-
- rel.Title = form.Title
- rel.Note = form.Note
- rel.IsDraft = form.IsDraft
- rel.IsPrerelease = form.IsPrerelease
- rel.PublisherID = ctx.User.ID
- rel.IsTag = false
- rel.Repo = ctx.Repo.Repository
- rel.Publisher = ctx.User
-
- if err = releaseservice.UpdateRelease(ctx.User, ctx.Repo.GitRepo, rel, nil); err != nil {
- ctx.ServerError("UpdateRelease", err)
- return
- }
- }
- ctx.JSON(201, rel.APIFormat())
- }
-
- // EditRelease edit a release
- func EditRelease(ctx *context.APIContext, form api.EditReleaseOption) {
- // swagger:operation PATCH /repos/{owner}/{repo}/releases/{id} repository repoEditRelease
- // ---
- // summary: Update a release
- // consumes:
- // - application/json
- // produces:
- // - application/json
- // parameters:
- // - name: owner
- // in: path
- // description: owner of the repo
- // type: string
- // required: true
- // - name: repo
- // in: path
- // description: name of the repo
- // type: string
- // required: true
- // - name: id
- // in: path
- // description: id of the release to edit
- // type: integer
- // format: int64
- // required: true
- // - name: body
- // in: body
- // schema:
- // "$ref": "#/definitions/EditReleaseOption"
- // responses:
- // "200":
- // "$ref": "#/responses/Release"
- id := ctx.ParamsInt64(":id")
- rel, err := models.GetReleaseByID(id)
- if err != nil && !models.IsErrReleaseNotExist(err) {
- ctx.Error(500, "GetReleaseByID", err)
- return
- }
- if err != nil && models.IsErrReleaseNotExist(err) ||
- rel.IsTag || rel.RepoID != ctx.Repo.Repository.ID {
- ctx.NotFound()
- 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 := releaseservice.UpdateRelease(ctx.User, ctx.Repo.GitRepo, rel, nil); 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) {
- // swagger:operation DELETE /repos/{owner}/{repo}/releases/{id} repository repoDeleteRelease
- // ---
- // summary: Delete a release
- // parameters:
- // - name: owner
- // in: path
- // description: owner of the repo
- // type: string
- // required: true
- // - name: repo
- // in: path
- // description: name of the repo
- // type: string
- // required: true
- // - name: id
- // in: path
- // description: id of the release to delete
- // type: integer
- // format: int64
- // required: true
- // responses:
- // "204":
- // "$ref": "#/responses/empty"
- id := ctx.ParamsInt64(":id")
- rel, err := models.GetReleaseByID(id)
- if err != nil && !models.IsErrReleaseNotExist(err) {
- ctx.Error(500, "GetReleaseByID", err)
- return
- }
- if err != nil && models.IsErrReleaseNotExist(err) ||
- rel.IsTag || rel.RepoID != ctx.Repo.Repository.ID {
- ctx.NotFound()
- return
- }
- if err := releaseservice.DeleteReleaseByID(id, ctx.User, false); err != nil {
- ctx.Error(500, "DeleteReleaseByID", err)
- return
- }
- ctx.Status(204)
- }
|