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.

release.go 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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 gitea
  5. import (
  6. "bytes"
  7. "encoding/json"
  8. "fmt"
  9. "time"
  10. )
  11. // Release represents a repository release
  12. type Release struct {
  13. ID int64 `json:"id"`
  14. TagName string `json:"tag_name"`
  15. Target string `json:"target_commitish"`
  16. Title string `json:"name"`
  17. Note string `json:"body"`
  18. URL string `json:"url"`
  19. TarURL string `json:"tarball_url"`
  20. ZipURL string `json:"zipball_url"`
  21. IsDraft bool `json:"draft"`
  22. IsPrerelease bool `json:"prerelease"`
  23. // swagger:strfmt date-time
  24. CreatedAt time.Time `json:"created_at"`
  25. // swagger:strfmt date-time
  26. PublishedAt time.Time `json:"published_at"`
  27. Publisher *User `json:"author"`
  28. Attachments []*Attachment `json:"assets"`
  29. }
  30. // ListReleases list releases of a repository
  31. func (c *Client) ListReleases(user, repo string) ([]*Release, error) {
  32. releases := make([]*Release, 0, 10)
  33. err := c.getParsedResponse("GET",
  34. fmt.Sprintf("/repos/%s/%s/releases", user, repo),
  35. nil, nil, &releases)
  36. return releases, err
  37. }
  38. // GetRelease get a release of a repository
  39. func (c *Client) GetRelease(user, repo string, id int64) (*Release, error) {
  40. r := new(Release)
  41. err := c.getParsedResponse("GET",
  42. fmt.Sprintf("/repos/%s/%s/releases/%d", user, repo, id),
  43. nil, nil, &r)
  44. return r, err
  45. }
  46. // CreateReleaseOption options when creating a release
  47. type CreateReleaseOption struct {
  48. // required: true
  49. TagName string `json:"tag_name" binding:"Required"`
  50. Target string `json:"target_commitish" binding:"Required"`
  51. Title string `json:"name"`
  52. Note string `json:"body"`
  53. IsDraft bool `json:"draft"`
  54. IsPrerelease bool `json:"prerelease"`
  55. }
  56. // CreateRelease create a release
  57. func (c *Client) CreateRelease(user, repo string, form CreateReleaseOption) (*Release, error) {
  58. body, err := json.Marshal(form)
  59. if err != nil {
  60. return nil, err
  61. }
  62. r := new(Release)
  63. err = c.getParsedResponse("POST",
  64. fmt.Sprintf("/repos/%s/%s/releases", user, repo),
  65. jsonHeader, bytes.NewReader(body), r)
  66. return r, err
  67. }
  68. // EditReleaseOption options when editing a release
  69. type EditReleaseOption struct {
  70. TagName string `json:"tag_name"`
  71. Target string `json:"target_commitish"`
  72. Title string `json:"name"`
  73. Note string `json:"body"`
  74. IsDraft *bool `json:"draft"`
  75. IsPrerelease *bool `json:"prerelease"`
  76. }
  77. // EditRelease edit a release
  78. func (c *Client) EditRelease(user, repo string, id int64, form EditReleaseOption) (*Release, error) {
  79. body, err := json.Marshal(form)
  80. if err != nil {
  81. return nil, err
  82. }
  83. r := new(Release)
  84. err = c.getParsedResponse("PATCH",
  85. fmt.Sprintf("/repos/%s/%s/releases/%d", user, repo, id),
  86. jsonHeader, bytes.NewReader(body), r)
  87. return r, err
  88. }
  89. // DeleteRelease delete a release from a repository
  90. func (c *Client) DeleteRelease(user, repo string, id int64) error {
  91. _, err := c.getResponse("DELETE",
  92. fmt.Sprintf("/repos/%s/%s/releases/%d", user, repo, id),
  93. nil, nil)
  94. return err
  95. }