2016-12-23 20:53:11 -05:00
// 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 user
import (
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
"code.gitea.io/gitea/modules/setting"
2019-08-23 09:40:30 -07:00
api "code.gitea.io/gitea/modules/structs"
2016-12-23 20:53:11 -05:00
)
// getWatchedRepos returns the repos that the user with the specified userID is
// watching
2018-11-28 19:26:14 +08:00
func getWatchedRepos ( user * models . User , private bool ) ( [ ] * api . Repository , error ) {
watchedRepos , err := models . GetWatchedRepos ( user . ID , private )
2016-12-23 20:53:11 -05:00
if err != nil {
return nil , err
}
repos := make ( [ ] * api . Repository , len ( watchedRepos ) )
for i , watched := range watchedRepos {
2018-11-28 19:26:14 +08:00
access , err := models . AccessLevel ( user , watched )
2016-12-23 20:53:11 -05:00
if err != nil {
return nil , err
}
repos [ i ] = watched . APIFormat ( access )
}
return repos , nil
}
// GetWatchedRepos returns the repos that the user specified in ctx is watching
func GetWatchedRepos ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /users/{username}/subscriptions user userListSubscriptions
// ---
// summary: List the repositories watched by a user
// produces:
// - application/json
// parameters:
// - name: username
// type: string
// in: path
// description: username of the user
2018-06-02 08:20:28 -07:00
// required: true
2017-11-12 23:02:25 -08:00
// responses:
// "200":
// "$ref": "#/responses/RepositoryList"
2016-12-23 20:53:11 -05:00
user := GetUserByParams ( ctx )
private := user . ID == ctx . User . ID
2018-11-28 19:26:14 +08:00
repos , err := getWatchedRepos ( user , private )
2016-12-23 20:53:11 -05:00
if err != nil {
ctx . Error ( 500 , "getWatchedRepos" , err )
}
ctx . JSON ( 200 , & repos )
}
// GetMyWatchedRepos returns the repos that the authenticated user is watching
func GetMyWatchedRepos ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /user/subscriptions user userCurrentListSubscriptions
// ---
// summary: List repositories watched by the authenticated user
// produces:
// - application/json
// responses:
// "200":
// "$ref": "#/responses/RepositoryList"
2018-11-28 19:26:14 +08:00
repos , err := getWatchedRepos ( ctx . User , true )
2016-12-23 20:53:11 -05:00
if err != nil {
ctx . Error ( 500 , "getWatchedRepos" , err )
}
ctx . JSON ( 200 , & repos )
}
// IsWatching returns whether the authenticated user is watching the repo
// specified in ctx
func IsWatching ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /repos/{owner}/{repo}/subscription repository userCurrentCheckSubscription
// ---
// summary: Check if the current user is watching a repo
// 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
// responses:
// "200":
// "$ref": "#/responses/WatchInfo"
2016-12-23 20:53:11 -05:00
if models . IsWatching ( ctx . User . ID , ctx . Repo . Repository . ID ) {
2017-04-16 14:51:04 +02:00
ctx . JSON ( 200 , api . WatchInfo {
2016-12-23 20:53:11 -05:00
Subscribed : true ,
Ignored : false ,
Reason : nil ,
2017-12-11 12:37:04 +08:00
CreatedAt : ctx . Repo . Repository . CreatedUnix . AsTime ( ) ,
2016-12-23 20:53:11 -05:00
URL : subscriptionURL ( ctx . Repo . Repository ) ,
RepositoryURL : repositoryURL ( ctx . Repo . Repository ) ,
} )
} else {
2019-03-18 21:29:43 -05:00
ctx . NotFound ( )
2016-12-23 20:53:11 -05:00
}
}
// Watch the repo specified in ctx, as the authenticated user
func Watch ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation PUT /repos/{owner}/{repo}/subscription repository userCurrentPutSubscription
// ---
// summary: Watch a repo
// 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
// responses:
// "200":
// "$ref": "#/responses/WatchInfo"
2016-12-23 20:53:11 -05:00
err := models . WatchRepo ( ctx . User . ID , ctx . Repo . Repository . ID , true )
if err != nil {
ctx . Error ( 500 , "WatchRepo" , err )
return
}
2017-04-16 14:51:04 +02:00
ctx . JSON ( 200 , api . WatchInfo {
2016-12-23 20:53:11 -05:00
Subscribed : true ,
Ignored : false ,
Reason : nil ,
2017-12-11 12:37:04 +08:00
CreatedAt : ctx . Repo . Repository . CreatedUnix . AsTime ( ) ,
2016-12-23 20:53:11 -05:00
URL : subscriptionURL ( ctx . Repo . Repository ) ,
RepositoryURL : repositoryURL ( ctx . Repo . Repository ) ,
} )
}
// Unwatch the repo specified in ctx, as the authenticated user
func Unwatch ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation DELETE /repos/{owner}/{repo}/subscription repository userCurrentDeleteSubscription
// ---
// summary: Unwatch a repo
// 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
// responses:
// "204":
// "$ref": "#/responses/empty"
2016-12-23 20:53:11 -05:00
err := models . WatchRepo ( ctx . User . ID , ctx . Repo . Repository . ID , false )
if err != nil {
ctx . Error ( 500 , "UnwatchRepo" , err )
return
}
ctx . Status ( 204 )
}
// subscriptionURL returns the URL of the subscription API endpoint of a repo
func subscriptionURL ( repo * models . Repository ) string {
return repositoryURL ( repo ) + "/subscription"
}
// repositoryURL returns the URL of the API endpoint of a repo
func repositoryURL ( repo * models . Repository ) string {
return setting . AppURL + "api/v1/" + repo . FullName ( )
}