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

milestone.go 6.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. // Copyright 2016 The Gogs Authors. All rights reserved.
  2. // Copyright 2020 The Gitea Authors.
  3. // Use of this source code is governed by a MIT-style
  4. // license that can be found in the LICENSE file.
  5. package repo
  6. import (
  7. "net/http"
  8. "time"
  9. "code.gitea.io/gitea/models"
  10. "code.gitea.io/gitea/modules/context"
  11. "code.gitea.io/gitea/modules/convert"
  12. api "code.gitea.io/gitea/modules/structs"
  13. "code.gitea.io/gitea/modules/timeutil"
  14. "code.gitea.io/gitea/routers/api/v1/utils"
  15. )
  16. // ListMilestones list milestones for a repository
  17. func ListMilestones(ctx *context.APIContext) {
  18. // swagger:operation GET /repos/{owner}/{repo}/milestones issue issueGetMilestonesList
  19. // ---
  20. // summary: Get all of a repository's opened milestones
  21. // produces:
  22. // - application/json
  23. // parameters:
  24. // - name: owner
  25. // in: path
  26. // description: owner of the repo
  27. // type: string
  28. // required: true
  29. // - name: repo
  30. // in: path
  31. // description: name of the repo
  32. // type: string
  33. // required: true
  34. // - name: state
  35. // in: query
  36. // description: Milestone state, Recognised values are open, closed and all. Defaults to "open"
  37. // type: string
  38. // - name: page
  39. // in: query
  40. // description: page number of results to return (1-based)
  41. // type: integer
  42. // - name: limit
  43. // in: query
  44. // description: page size of results
  45. // type: integer
  46. // responses:
  47. // "200":
  48. // "$ref": "#/responses/MilestoneList"
  49. milestones, err := models.GetMilestonesByRepoID(ctx.Repo.Repository.ID, api.StateType(ctx.Query("state")), utils.GetListOptions(ctx))
  50. if err != nil {
  51. ctx.Error(http.StatusInternalServerError, "GetMilestonesByRepoID", err)
  52. return
  53. }
  54. apiMilestones := make([]*api.Milestone, len(milestones))
  55. for i := range milestones {
  56. apiMilestones[i] = convert.ToAPIMilestone(milestones[i])
  57. }
  58. ctx.JSON(http.StatusOK, &apiMilestones)
  59. }
  60. // GetMilestone get a milestone for a repository
  61. func GetMilestone(ctx *context.APIContext) {
  62. // swagger:operation GET /repos/{owner}/{repo}/milestones/{id} issue issueGetMilestone
  63. // ---
  64. // summary: Get a milestone
  65. // produces:
  66. // - application/json
  67. // parameters:
  68. // - name: owner
  69. // in: path
  70. // description: owner of the repo
  71. // type: string
  72. // required: true
  73. // - name: repo
  74. // in: path
  75. // description: name of the repo
  76. // type: string
  77. // required: true
  78. // - name: id
  79. // in: path
  80. // description: id of the milestone
  81. // type: integer
  82. // format: int64
  83. // required: true
  84. // responses:
  85. // "200":
  86. // "$ref": "#/responses/Milestone"
  87. milestone, err := models.GetMilestoneByRepoID(ctx.Repo.Repository.ID, ctx.ParamsInt64(":id"))
  88. if err != nil {
  89. if models.IsErrMilestoneNotExist(err) {
  90. ctx.NotFound()
  91. } else {
  92. ctx.Error(http.StatusInternalServerError, "GetMilestoneByRepoID", err)
  93. }
  94. return
  95. }
  96. ctx.JSON(http.StatusOK, convert.ToAPIMilestone(milestone))
  97. }
  98. // CreateMilestone create a milestone for a repository
  99. func CreateMilestone(ctx *context.APIContext, form api.CreateMilestoneOption) {
  100. // swagger:operation POST /repos/{owner}/{repo}/milestones issue issueCreateMilestone
  101. // ---
  102. // summary: Create a milestone
  103. // consumes:
  104. // - application/json
  105. // produces:
  106. // - application/json
  107. // parameters:
  108. // - name: owner
  109. // in: path
  110. // description: owner of the repo
  111. // type: string
  112. // required: true
  113. // - name: repo
  114. // in: path
  115. // description: name of the repo
  116. // type: string
  117. // required: true
  118. // - name: body
  119. // in: body
  120. // schema:
  121. // "$ref": "#/definitions/CreateMilestoneOption"
  122. // responses:
  123. // "201":
  124. // "$ref": "#/responses/Milestone"
  125. if form.Deadline == nil {
  126. defaultDeadline, _ := time.ParseInLocation("2006-01-02", "9999-12-31", time.Local)
  127. form.Deadline = &defaultDeadline
  128. }
  129. milestone := &models.Milestone{
  130. RepoID: ctx.Repo.Repository.ID,
  131. Name: form.Title,
  132. Content: form.Description,
  133. DeadlineUnix: timeutil.TimeStamp(form.Deadline.Unix()),
  134. }
  135. if form.State == "closed" {
  136. milestone.IsClosed = true
  137. milestone.ClosedDateUnix = timeutil.TimeStampNow()
  138. }
  139. if err := models.NewMilestone(milestone); err != nil {
  140. ctx.Error(http.StatusInternalServerError, "NewMilestone", err)
  141. return
  142. }
  143. ctx.JSON(http.StatusCreated, convert.ToAPIMilestone(milestone))
  144. }
  145. // EditMilestone modify a milestone for a repository
  146. func EditMilestone(ctx *context.APIContext, form api.EditMilestoneOption) {
  147. // swagger:operation PATCH /repos/{owner}/{repo}/milestones/{id} issue issueEditMilestone
  148. // ---
  149. // summary: Update a milestone
  150. // consumes:
  151. // - application/json
  152. // produces:
  153. // - application/json
  154. // parameters:
  155. // - name: owner
  156. // in: path
  157. // description: owner of the repo
  158. // type: string
  159. // required: true
  160. // - name: repo
  161. // in: path
  162. // description: name of the repo
  163. // type: string
  164. // required: true
  165. // - name: id
  166. // in: path
  167. // description: id of the milestone
  168. // type: integer
  169. // format: int64
  170. // required: true
  171. // - name: body
  172. // in: body
  173. // schema:
  174. // "$ref": "#/definitions/EditMilestoneOption"
  175. // responses:
  176. // "200":
  177. // "$ref": "#/responses/Milestone"
  178. milestone, err := models.GetMilestoneByRepoID(ctx.Repo.Repository.ID, ctx.ParamsInt64(":id"))
  179. if err != nil {
  180. if models.IsErrMilestoneNotExist(err) {
  181. ctx.NotFound()
  182. } else {
  183. ctx.Error(http.StatusInternalServerError, "GetMilestoneByRepoID", err)
  184. }
  185. return
  186. }
  187. if len(form.Title) > 0 {
  188. milestone.Name = form.Title
  189. }
  190. if form.Description != nil {
  191. milestone.Content = *form.Description
  192. }
  193. if form.Deadline != nil && !form.Deadline.IsZero() {
  194. milestone.DeadlineUnix = timeutil.TimeStamp(form.Deadline.Unix())
  195. }
  196. var oldIsClosed = milestone.IsClosed
  197. if form.State != nil {
  198. milestone.IsClosed = *form.State == string(api.StateClosed)
  199. }
  200. if err := models.UpdateMilestone(milestone, oldIsClosed); err != nil {
  201. ctx.ServerError("UpdateMilestone", err)
  202. return
  203. }
  204. ctx.JSON(http.StatusOK, convert.ToAPIMilestone(milestone))
  205. }
  206. // DeleteMilestone delete a milestone for a repository
  207. func DeleteMilestone(ctx *context.APIContext) {
  208. // swagger:operation DELETE /repos/{owner}/{repo}/milestones/{id} issue issueDeleteMilestone
  209. // ---
  210. // summary: Delete a milestone
  211. // parameters:
  212. // - name: owner
  213. // in: path
  214. // description: owner of the repo
  215. // type: string
  216. // required: true
  217. // - name: repo
  218. // in: path
  219. // description: name of the repo
  220. // type: string
  221. // required: true
  222. // - name: id
  223. // in: path
  224. // description: id of the milestone to delete
  225. // type: integer
  226. // format: int64
  227. // required: true
  228. // responses:
  229. // "204":
  230. // "$ref": "#/responses/empty"
  231. if err := models.DeleteMilestoneByRepoID(ctx.Repo.Repository.ID, ctx.ParamsInt64(":id")); err != nil {
  232. ctx.Error(http.StatusInternalServerError, "DeleteMilestoneByRepoID", err)
  233. return
  234. }
  235. ctx.Status(http.StatusNoContent)
  236. }