2016-12-30 20:15:45 -05:00
// Copyright 2016 The Gogs 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 repo
import (
api "code.gitea.io/sdk/gitea"
"code.gitea.io/gitea/models"
"code.gitea.io/gitea/modules/context"
2017-07-11 21:23:41 -04:00
"code.gitea.io/gitea/routers/api/v1/utils"
2016-12-30 20:15:45 -05:00
)
// ListForks list a repository's forks
func ListForks ( ctx * context . APIContext ) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /repos/{owner}/{repo}/forks repository listForks
// ---
// summary: List a repository's forks
// produces:
// - application/json
// 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/RepositoryList"
2016-12-30 20:15:45 -05:00
forks , err := ctx . Repo . Repository . GetForks ( )
if err != nil {
ctx . Error ( 500 , "GetForks" , err )
return
}
apiForks := make ( [ ] * api . Repository , len ( forks ) )
for i , fork := range forks {
2017-07-11 21:23:41 -04:00
access , err := models . AccessLevel ( utils . UserID ( ctx ) , fork )
2016-12-30 20:15:45 -05:00
if err != nil {
ctx . Error ( 500 , "AccessLevel" , err )
return
}
apiForks [ i ] = fork . APIFormat ( access )
}
ctx . JSON ( 200 , apiForks )
}
// CreateFork create a fork of a repo
func CreateFork ( ctx * context . APIContext , form api . CreateForkOption ) {
2017-11-12 23:02:25 -08:00
// swagger:operation POST /repos/{owner}/{repo}/forks repository createFork
// ---
// summary: Fork a repository
// produces:
// - application/json
// parameters:
// - name: owner
// in: path
// description: owner of the repo to fork
// type: string
// required: true
// - name: repo
// in: path
// description: name of the repo to fork
// type: string
// required: true
// - name: body
// in: body
// schema:
// "$ref": "#/definitions/CreateForkOption"
// responses:
// "202":
// "$ref": "#/responses/Repository"
2016-12-30 20:15:45 -05:00
repo := ctx . Repo . Repository
var forker * models . User // user/org that will own the fork
if form . Organization == nil {
forker = ctx . User
} else {
org , err := models . GetOrgByName ( * form . Organization )
if err != nil {
2017-07-06 15:30:19 +02:00
if models . IsErrOrgNotExist ( err ) {
2016-12-30 20:15:45 -05:00
ctx . Error ( 422 , "" , err )
} else {
ctx . Error ( 500 , "GetOrgByName" , err )
}
return
}
if ! org . IsOrgMember ( ctx . User . ID ) {
ctx . Status ( 403 )
return
}
forker = org
}
2017-09-03 01:20:24 -07:00
fork , err := models . ForkRepository ( ctx . User , forker , repo , repo . Name , repo . Description )
2016-12-30 20:15:45 -05:00
if err != nil {
ctx . Error ( 500 , "ForkRepository" , err )
return
}
ctx . JSON ( 202 , fork . APIFormat ( models . AccessModeOwner ) )
}