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 (
2019-12-20 18:07:12 +01:00
"net/http"
2016-12-23 20:53:11 -05:00
"code.gitea.io/gitea/models"
2021-09-24 19:32:56 +08:00
"code.gitea.io/gitea/models/db"
2021-11-24 17:49:20 +08:00
user_model "code.gitea.io/gitea/models/user"
2016-12-23 20:53:11 -05:00
"code.gitea.io/gitea/modules/context"
2020-12-02 22:38:30 +01:00
"code.gitea.io/gitea/modules/convert"
2019-08-23 09:40:30 -07:00
api "code.gitea.io/gitea/modules/structs"
2020-01-24 19:00:29 +00:00
"code.gitea.io/gitea/routers/api/v1/utils"
2016-12-23 20:53:11 -05:00
)
2021-08-12 14:43:08 +02:00
// getWatchedRepos returns the repos that the user with the specified userID is watching
2021-11-24 17:49:20 +08:00
func getWatchedRepos ( user * user_model . User , private bool , listOptions db . ListOptions ) ( [ ] * api . Repository , int64 , error ) {
2021-08-12 14:43:08 +02:00
watchedRepos , total , err := models . GetWatchedRepos ( user . ID , private , listOptions )
2016-12-23 20:53:11 -05:00
if err != nil {
2021-08-12 14:43:08 +02:00
return nil , 0 , err
2016-12-23 20:53:11 -05:00
}
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 {
2021-08-12 14:43:08 +02:00
return nil , 0 , err
2016-12-23 20:53:11 -05:00
}
2020-12-02 22:38:30 +01:00
repos [ i ] = convert . ToRepo ( watched , access )
2016-12-23 20:53:11 -05:00
}
2021-08-12 14:43:08 +02:00
return repos , total , nil
2016-12-23 20:53:11 -05:00
}
// 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
2020-01-24 19:00:29 +00:00
// - name: page
// in: query
// description: page number of results to return (1-based)
// type: integer
// - name: limit
// in: query
2020-06-09 06:57:38 +02:00
// description: page size of results
2020-01-24 19:00:29 +00:00
// type: integer
2017-11-12 23:02:25 -08:00
// responses:
// "200":
// "$ref": "#/responses/RepositoryList"
2019-12-20 18:07:12 +01:00
2016-12-23 20:53:11 -05:00
user := GetUserByParams ( ctx )
private := user . ID == ctx . User . ID
2021-08-12 14:43:08 +02:00
repos , total , err := getWatchedRepos ( user , private , utils . GetListOptions ( ctx ) )
2016-12-23 20:53:11 -05:00
if err != nil {
2019-12-20 18:07:12 +01:00
ctx . Error ( http . StatusInternalServerError , "getWatchedRepos" , err )
2016-12-23 20:53:11 -05:00
}
2021-08-12 14:43:08 +02:00
ctx . SetTotalCountHeader ( total )
2019-12-20 18:07:12 +01:00
ctx . JSON ( http . StatusOK , & repos )
2016-12-23 20:53:11 -05:00
}
// 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
2020-01-24 19:00:29 +00:00
// parameters:
// - name: page
// in: query
// description: page number of results to return (1-based)
// type: integer
// - name: limit
// in: query
2020-06-09 06:57:38 +02:00
// description: page size of results
2020-01-24 19:00:29 +00:00
// type: integer
2017-11-12 23:02:25 -08:00
// responses:
// "200":
// "$ref": "#/responses/RepositoryList"
2019-12-20 18:07:12 +01:00
2021-08-12 14:43:08 +02:00
repos , total , err := getWatchedRepos ( ctx . User , true , utils . GetListOptions ( ctx ) )
2016-12-23 20:53:11 -05:00
if err != nil {
2019-12-20 18:07:12 +01:00
ctx . Error ( http . StatusInternalServerError , "getWatchedRepos" , err )
2016-12-23 20:53:11 -05:00
}
2021-08-12 14:43:08 +02:00
ctx . SetTotalCountHeader ( total )
2019-12-20 18:07:12 +01:00
ctx . JSON ( http . StatusOK , & repos )
2016-12-23 20:53:11 -05:00
}
// 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"
2020-04-15 15:03:05 +02:00
// "404":
// description: User is not watching this repo or repo do not exist
2019-12-20 18:07:12 +01:00
2016-12-23 20:53:11 -05:00
if models . IsWatching ( ctx . User . ID , ctx . Repo . Repository . ID ) {
2019-12-20 18:07:12 +01:00
ctx . JSON ( http . StatusOK , 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 ) ,
2020-04-21 15:48:53 +02:00
RepositoryURL : ctx . Repo . Repository . APIURL ( ) ,
2016-12-23 20:53:11 -05:00
} )
} 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"
2019-12-20 18:07:12 +01:00
2016-12-23 20:53:11 -05:00
err := models . WatchRepo ( ctx . User . ID , ctx . Repo . Repository . ID , true )
if err != nil {
2019-12-20 18:07:12 +01:00
ctx . Error ( http . StatusInternalServerError , "WatchRepo" , err )
2016-12-23 20:53:11 -05:00
return
}
2019-12-20 18:07:12 +01:00
ctx . JSON ( http . StatusOK , 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 ) ,
2020-04-21 15:48:53 +02:00
RepositoryURL : ctx . Repo . Repository . APIURL ( ) ,
2016-12-23 20:53:11 -05:00
} )
}
// 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"
2019-12-20 18:07:12 +01:00
2016-12-23 20:53:11 -05:00
err := models . WatchRepo ( ctx . User . ID , ctx . Repo . Repository . ID , false )
if err != nil {
2019-12-20 18:07:12 +01:00
ctx . Error ( http . StatusInternalServerError , "UnwatchRepo" , err )
2016-12-23 20:53:11 -05:00
return
}
2019-12-20 18:07:12 +01:00
ctx . Status ( http . StatusNoContent )
2016-12-23 20:53:11 -05:00
}
// subscriptionURL returns the URL of the subscription API endpoint of a repo
func subscriptionURL ( repo * models . Repository ) string {
2020-04-21 15:48:53 +02:00
return repo . APIURL ( ) + "/subscription"
2016-12-23 20:53:11 -05:00
}