Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
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.
129 lines
3.4 KiB
129 lines
3.4 KiB
// Copyright 2016 The Gogs Authors. All rights reserved. |
|
// Copyright 2020 The Gitea Authors. |
|
// Use of this source code is governed by a MIT-style |
|
// license that can be found in the LICENSE file. |
|
|
|
package repo |
|
|
|
import ( |
|
"fmt" |
|
"net/http" |
|
|
|
"code.gitea.io/gitea/models" |
|
"code.gitea.io/gitea/modules/context" |
|
api "code.gitea.io/gitea/modules/structs" |
|
"code.gitea.io/gitea/routers/api/v1/utils" |
|
repo_service "code.gitea.io/gitea/services/repository" |
|
) |
|
|
|
// ListForks list a repository's forks |
|
func ListForks(ctx *context.APIContext) { |
|
// 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 |
|
// - name: page |
|
// in: query |
|
// description: page number of results to return (1-based) |
|
// type: integer |
|
// - name: limit |
|
// in: query |
|
// description: page size of results |
|
// type: integer |
|
// responses: |
|
// "200": |
|
// "$ref": "#/responses/RepositoryList" |
|
|
|
forks, err := ctx.Repo.Repository.GetForks(utils.GetListOptions(ctx)) |
|
if err != nil { |
|
ctx.Error(http.StatusInternalServerError, "GetForks", err) |
|
return |
|
} |
|
apiForks := make([]*api.Repository, len(forks)) |
|
for i, fork := range forks { |
|
access, err := models.AccessLevel(ctx.User, fork) |
|
if err != nil { |
|
ctx.Error(http.StatusInternalServerError, "AccessLevel", err) |
|
return |
|
} |
|
apiForks[i] = fork.APIFormat(access) |
|
} |
|
ctx.JSON(http.StatusOK, apiForks) |
|
} |
|
|
|
// CreateFork create a fork of a repo |
|
func CreateFork(ctx *context.APIContext, form api.CreateForkOption) { |
|
// 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" |
|
// "403": |
|
// "$ref": "#/responses/forbidden" |
|
// "422": |
|
// "$ref": "#/responses/validationError" |
|
|
|
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 { |
|
if models.IsErrOrgNotExist(err) { |
|
ctx.Error(http.StatusUnprocessableEntity, "", err) |
|
} else { |
|
ctx.Error(http.StatusInternalServerError, "GetOrgByName", err) |
|
} |
|
return |
|
} |
|
isMember, err := org.IsOrgMember(ctx.User.ID) |
|
if err != nil { |
|
ctx.Error(http.StatusInternalServerError, "IsOrgMember", err) |
|
return |
|
} else if !isMember { |
|
ctx.Error(http.StatusForbidden, "isMemberNot", fmt.Sprintf("User is no Member of Organisation '%s'", org.Name)) |
|
return |
|
} |
|
forker = org |
|
} |
|
|
|
fork, err := repo_service.ForkRepository(ctx.User, forker, repo, repo.Name, repo.Description) |
|
if err != nil { |
|
ctx.Error(http.StatusInternalServerError, "ForkRepository", err) |
|
return |
|
} |
|
|
|
//TODO change back to 201 |
|
ctx.JSON(http.StatusAccepted, fork.APIFormat(models.AccessModeOwner)) |
|
}
|
|
|