You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

release.go 8.7 kB

Add Attachment API (#3478) * Add Attachment API * repos/:owner/:repo/releases (add attachments) * repos/:owner/:repo/releases/:id (add attachments) * repos/:owner/:repo/releases/:id/attachments * repos/:owner/:repo/releases/:id/attachments/:attachment_id Signed-off-by: Jonas Franz <info@jonasfranz.de> * Add unit tests for new attachment functions Fix comments Signed-off-by: Jonas Franz <info@jonasfranz.software> * fix lint * Update vendor.json Signed-off-by: Jonas Franz <info@jonasfranz.software> * remove version of sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix unit tests Add missing license header Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add CreateReleaseAttachment Add EditReleaseAttachment Add DeleteReleaseAttachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add filename query parameter for choosing another name for an attachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix order of imports Signed-off-by: Jonas Franz <info@jonasfranz.software> * Restricting updatable attachment columns Signed-off-by: Jonas Franz <info@jonasfranz.software> * gofmt Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update go-sdk Replace Attachments with Assets Signed-off-by: Jonas Franz <info@jonasfranz.de> * Update go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.de> * Updating go-sdk and regenerating swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add missing file of go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Change origin of code.gitea.io/sdk to code.gitea.io/sdk Update code.gitea.io/sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update updateAttachment
7 years ago
Add Attachment API (#3478) * Add Attachment API * repos/:owner/:repo/releases (add attachments) * repos/:owner/:repo/releases/:id (add attachments) * repos/:owner/:repo/releases/:id/attachments * repos/:owner/:repo/releases/:id/attachments/:attachment_id Signed-off-by: Jonas Franz <info@jonasfranz.de> * Add unit tests for new attachment functions Fix comments Signed-off-by: Jonas Franz <info@jonasfranz.software> * fix lint * Update vendor.json Signed-off-by: Jonas Franz <info@jonasfranz.software> * remove version of sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix unit tests Add missing license header Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add CreateReleaseAttachment Add EditReleaseAttachment Add DeleteReleaseAttachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add filename query parameter for choosing another name for an attachment Signed-off-by: Jonas Franz <info@jonasfranz.software> * Fix order of imports Signed-off-by: Jonas Franz <info@jonasfranz.software> * Restricting updatable attachment columns Signed-off-by: Jonas Franz <info@jonasfranz.software> * gofmt Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update go-sdk Replace Attachments with Assets Signed-off-by: Jonas Franz <info@jonasfranz.de> * Update go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.de> * Updating go-sdk and regenerating swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Add missing file of go-sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Change origin of code.gitea.io/sdk to code.gitea.io/sdk Update code.gitea.io/sdk Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update swagger Signed-off-by: Jonas Franz <info@jonasfranz.software> * Update updateAttachment
7 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333
  1. // Copyright 2016 The Gitea Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package repo
  5. import (
  6. "net/http"
  7. "code.gitea.io/gitea/models"
  8. "code.gitea.io/gitea/modules/context"
  9. "code.gitea.io/gitea/modules/setting"
  10. api "code.gitea.io/gitea/modules/structs"
  11. releaseservice "code.gitea.io/gitea/services/release"
  12. )
  13. // GetRelease get a single release of a repository
  14. func GetRelease(ctx *context.APIContext) {
  15. // swagger:operation GET /repos/{owner}/{repo}/releases/{id} repository repoGetRelease
  16. // ---
  17. // summary: Get a release
  18. // produces:
  19. // - application/json
  20. // parameters:
  21. // - name: owner
  22. // in: path
  23. // description: owner of the repo
  24. // type: string
  25. // required: true
  26. // - name: repo
  27. // in: path
  28. // description: name of the repo
  29. // type: string
  30. // required: true
  31. // - name: id
  32. // in: path
  33. // description: id of the release to get
  34. // type: integer
  35. // format: int64
  36. // required: true
  37. // responses:
  38. // "200":
  39. // "$ref": "#/responses/Release"
  40. id := ctx.ParamsInt64(":id")
  41. release, err := models.GetReleaseByID(id)
  42. if err != nil {
  43. ctx.Error(http.StatusInternalServerError, "GetReleaseByID", err)
  44. return
  45. }
  46. if release.RepoID != ctx.Repo.Repository.ID {
  47. ctx.NotFound()
  48. return
  49. }
  50. if err := release.LoadAttributes(); err != nil {
  51. ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
  52. return
  53. }
  54. ctx.JSON(http.StatusOK, release.APIFormat())
  55. }
  56. func getPagesInfo(ctx *context.APIContext) (int, int) {
  57. page := ctx.QueryInt("page")
  58. if page == 0 {
  59. page = 1
  60. }
  61. perPage := ctx.QueryInt("per_page")
  62. if perPage == 0 {
  63. perPage = setting.API.DefaultPagingNum
  64. } else if perPage > setting.API.MaxResponseItems {
  65. perPage = setting.API.MaxResponseItems
  66. }
  67. return page, perPage
  68. }
  69. // ListReleases list a repository's releases
  70. func ListReleases(ctx *context.APIContext) {
  71. // swagger:operation GET /repos/{owner}/{repo}/releases repository repoListReleases
  72. // ---
  73. // summary: List a repo's releases
  74. // produces:
  75. // - application/json
  76. // parameters:
  77. // - name: owner
  78. // in: path
  79. // description: owner of the repo
  80. // type: string
  81. // required: true
  82. // - name: repo
  83. // in: path
  84. // description: name of the repo
  85. // type: string
  86. // required: true
  87. // - name: page
  88. // in: query
  89. // description: page wants to load
  90. // type: integer
  91. // - name: per_page
  92. // in: query
  93. // description: items count every page wants to load
  94. // type: integer
  95. // responses:
  96. // "200":
  97. // "$ref": "#/responses/ReleaseList"
  98. page, limit := getPagesInfo(ctx)
  99. releases, err := models.GetReleasesByRepoID(ctx.Repo.Repository.ID, models.FindReleasesOptions{
  100. IncludeDrafts: ctx.Repo.AccessMode >= models.AccessModeWrite,
  101. IncludeTags: false,
  102. }, page, limit)
  103. if err != nil {
  104. ctx.Error(http.StatusInternalServerError, "GetReleasesByRepoID", err)
  105. return
  106. }
  107. rels := make([]*api.Release, len(releases))
  108. for i, release := range releases {
  109. if err := release.LoadAttributes(); err != nil {
  110. ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
  111. return
  112. }
  113. rels[i] = release.APIFormat()
  114. }
  115. ctx.JSON(http.StatusOK, rels)
  116. }
  117. // CreateRelease create a release
  118. func CreateRelease(ctx *context.APIContext, form api.CreateReleaseOption) {
  119. // swagger:operation POST /repos/{owner}/{repo}/releases repository repoCreateRelease
  120. // ---
  121. // summary: Create a release
  122. // consumes:
  123. // - application/json
  124. // produces:
  125. // - application/json
  126. // parameters:
  127. // - name: owner
  128. // in: path
  129. // description: owner of the repo
  130. // type: string
  131. // required: true
  132. // - name: repo
  133. // in: path
  134. // description: name of the repo
  135. // type: string
  136. // required: true
  137. // - name: body
  138. // in: body
  139. // schema:
  140. // "$ref": "#/definitions/CreateReleaseOption"
  141. // responses:
  142. // "201":
  143. // "$ref": "#/responses/Release"
  144. // "409":
  145. // "$ref": "#/responses/error"
  146. rel, err := models.GetRelease(ctx.Repo.Repository.ID, form.TagName)
  147. if err != nil {
  148. if !models.IsErrReleaseNotExist(err) {
  149. ctx.ServerError("GetRelease", err)
  150. return
  151. }
  152. // If target is not provided use default branch
  153. if len(form.Target) == 0 {
  154. form.Target = ctx.Repo.Repository.DefaultBranch
  155. }
  156. rel = &models.Release{
  157. RepoID: ctx.Repo.Repository.ID,
  158. PublisherID: ctx.User.ID,
  159. Publisher: ctx.User,
  160. TagName: form.TagName,
  161. Target: form.Target,
  162. Title: form.Title,
  163. Note: form.Note,
  164. IsDraft: form.IsDraft,
  165. IsPrerelease: form.IsPrerelease,
  166. IsTag: false,
  167. Repo: ctx.Repo.Repository,
  168. }
  169. if err := releaseservice.CreateRelease(ctx.Repo.GitRepo, rel, nil); err != nil {
  170. if models.IsErrReleaseAlreadyExist(err) {
  171. ctx.Error(http.StatusConflict, "ReleaseAlreadyExist", err)
  172. } else {
  173. ctx.Error(http.StatusInternalServerError, "CreateRelease", err)
  174. }
  175. return
  176. }
  177. } else {
  178. if !rel.IsTag {
  179. ctx.Error(http.StatusConflict, "GetRelease", "Release is has no Tag")
  180. return
  181. }
  182. rel.Title = form.Title
  183. rel.Note = form.Note
  184. rel.IsDraft = form.IsDraft
  185. rel.IsPrerelease = form.IsPrerelease
  186. rel.PublisherID = ctx.User.ID
  187. rel.IsTag = false
  188. rel.Repo = ctx.Repo.Repository
  189. rel.Publisher = ctx.User
  190. if err = releaseservice.UpdateRelease(ctx.User, ctx.Repo.GitRepo, rel, nil); err != nil {
  191. ctx.ServerError("UpdateRelease", err)
  192. return
  193. }
  194. }
  195. ctx.JSON(http.StatusCreated, rel.APIFormat())
  196. }
  197. // EditRelease edit a release
  198. func EditRelease(ctx *context.APIContext, form api.EditReleaseOption) {
  199. // swagger:operation PATCH /repos/{owner}/{repo}/releases/{id} repository repoEditRelease
  200. // ---
  201. // summary: Update a release
  202. // consumes:
  203. // - application/json
  204. // produces:
  205. // - application/json
  206. // parameters:
  207. // - name: owner
  208. // in: path
  209. // description: owner of the repo
  210. // type: string
  211. // required: true
  212. // - name: repo
  213. // in: path
  214. // description: name of the repo
  215. // type: string
  216. // required: true
  217. // - name: id
  218. // in: path
  219. // description: id of the release to edit
  220. // type: integer
  221. // format: int64
  222. // required: true
  223. // - name: body
  224. // in: body
  225. // schema:
  226. // "$ref": "#/definitions/EditReleaseOption"
  227. // responses:
  228. // "200":
  229. // "$ref": "#/responses/Release"
  230. id := ctx.ParamsInt64(":id")
  231. rel, err := models.GetReleaseByID(id)
  232. if err != nil && !models.IsErrReleaseNotExist(err) {
  233. ctx.Error(http.StatusInternalServerError, "GetReleaseByID", err)
  234. return
  235. }
  236. if err != nil && models.IsErrReleaseNotExist(err) ||
  237. rel.IsTag || rel.RepoID != ctx.Repo.Repository.ID {
  238. ctx.NotFound()
  239. return
  240. }
  241. if len(form.TagName) > 0 {
  242. rel.TagName = form.TagName
  243. }
  244. if len(form.Target) > 0 {
  245. rel.Target = form.Target
  246. }
  247. if len(form.Title) > 0 {
  248. rel.Title = form.Title
  249. }
  250. if len(form.Note) > 0 {
  251. rel.Note = form.Note
  252. }
  253. if form.IsDraft != nil {
  254. rel.IsDraft = *form.IsDraft
  255. }
  256. if form.IsPrerelease != nil {
  257. rel.IsPrerelease = *form.IsPrerelease
  258. }
  259. if err := releaseservice.UpdateRelease(ctx.User, ctx.Repo.GitRepo, rel, nil); err != nil {
  260. ctx.Error(http.StatusInternalServerError, "UpdateRelease", err)
  261. return
  262. }
  263. rel, err = models.GetReleaseByID(id)
  264. if err != nil {
  265. ctx.Error(http.StatusInternalServerError, "GetReleaseByID", err)
  266. return
  267. }
  268. if err := rel.LoadAttributes(); err != nil {
  269. ctx.Error(http.StatusInternalServerError, "LoadAttributes", err)
  270. return
  271. }
  272. ctx.JSON(http.StatusOK, rel.APIFormat())
  273. }
  274. // DeleteRelease delete a release from a repository
  275. func DeleteRelease(ctx *context.APIContext) {
  276. // swagger:operation DELETE /repos/{owner}/{repo}/releases/{id} repository repoDeleteRelease
  277. // ---
  278. // summary: Delete a release
  279. // parameters:
  280. // - name: owner
  281. // in: path
  282. // description: owner of the repo
  283. // type: string
  284. // required: true
  285. // - name: repo
  286. // in: path
  287. // description: name of the repo
  288. // type: string
  289. // required: true
  290. // - name: id
  291. // in: path
  292. // description: id of the release to delete
  293. // type: integer
  294. // format: int64
  295. // required: true
  296. // responses:
  297. // "204":
  298. // "$ref": "#/responses/empty"
  299. id := ctx.ParamsInt64(":id")
  300. rel, err := models.GetReleaseByID(id)
  301. if err != nil && !models.IsErrReleaseNotExist(err) {
  302. ctx.Error(http.StatusInternalServerError, "GetReleaseByID", err)
  303. return
  304. }
  305. if err != nil && models.IsErrReleaseNotExist(err) ||
  306. rel.IsTag || rel.RepoID != ctx.Repo.Repository.ID {
  307. ctx.NotFound()
  308. return
  309. }
  310. if err := releaseservice.DeleteReleaseByID(id, ctx.User, false); err != nil {
  311. ctx.Error(http.StatusInternalServerError, "DeleteReleaseByID", err)
  312. return
  313. }
  314. ctx.Status(http.StatusNoContent)
  315. }