Return issue subscription status from API subscribe (#10966)

* [API] issue subscription indicate by http status

* CI.restart()
This commit is contained in:
6543 2020-05-01 00:55:24 +02:00 committed by GitHub
parent 4974b7c120
commit e9e8638f18
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 35 additions and 4 deletions

View file

@ -45,8 +45,10 @@ func AddIssueSubscription(ctx *context.APIContext) {
// type: string
// required: true
// responses:
// "200":
// description: Already subscribed
// "201":
// "$ref": "#/responses/empty"
// description: Successfully Subscribed
// "304":
// description: User can only subscribe itself if he is no admin
// "404":
@ -87,8 +89,10 @@ func DelIssueSubscription(ctx *context.APIContext) {
// type: string
// required: true
// responses:
// "200":
// description: Already unsubscribed
// "201":
// "$ref": "#/responses/empty"
// description: Successfully Unsubscribed
// "304":
// description: User can only subscribe itself if he is no admin
// "404":
@ -126,6 +130,19 @@ func setIssueSubscription(ctx *context.APIContext, watch bool) {
return
}
current, err := models.CheckIssueWatch(user, issue)
if err != nil {
ctx.Error(http.StatusInternalServerError, "CheckIssueWatch", err)
return
}
// If watch state wont change
if current == watch {
ctx.Status(http.StatusOK)
return
}
// Update watch state
if err := models.CreateOrUpdateIssueWatch(user.ID, issue.ID, watch); err != nil {
ctx.Error(http.StatusInternalServerError, "CreateOrUpdateIssueWatch", err)
return