Files
Atay-Makhzan/routers/api/v1/user/repo.go
T

165 lines
4.5 KiB
Go
Raw Normal View History

2017-07-13 04:14:15 -07:00
// Copyright 2017 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT
2017-07-13 04:14:15 -07:00
2017-02-24 16:39:49 -05:00
package user
import (
2019-12-20 18:07:12 +01:00
"net/http"
2021-11-28 19:58:28 +08:00
"code.gitea.io/gitea/models/perm"
access_model "code.gitea.io/gitea/models/perm/access"
repo_model "code.gitea.io/gitea/models/repo"
user_model "code.gitea.io/gitea/models/user"
2017-02-24 16:39:49 -05:00
"code.gitea.io/gitea/modules/context"
"code.gitea.io/gitea/modules/convert"
2019-05-11 18:21:34 +08:00
api "code.gitea.io/gitea/modules/structs"
2020-01-24 19:00:29 +00:00
"code.gitea.io/gitea/routers/api/v1/utils"
2017-02-24 16:39:49 -05:00
)
// listUserRepos - List the repositories owned by the given user.
func listUserRepos(ctx *context.APIContext, u *user_model.User, private bool) {
opts := utils.GetListOptions(ctx)
repos, count, err := repo_model.GetUserRepositories(&repo_model.SearchRepoOptions{
2020-01-24 19:00:29 +00:00
Actor: u,
Private: private,
ListOptions: opts,
2020-07-02 07:55:42 -07:00
OrderBy: "id ASC",
2020-01-24 19:00:29 +00:00
})
2017-02-24 16:39:49 -05:00
if err != nil {
2019-12-20 18:07:12 +01:00
ctx.Error(http.StatusInternalServerError, "GetUserRepositories", err)
2017-02-24 16:39:49 -05:00
return
}
if err := repos.LoadAttributes(); err != nil {
ctx.Error(http.StatusInternalServerError, "RepositoryList.LoadAttributes", err)
return
}
apiRepos := make([]*api.Repository, 0, len(repos))
for i := range repos {
access, err := access_model.AccessLevel(ctx, ctx.Doer, repos[i])
if err != nil {
2019-12-20 18:07:12 +01:00
ctx.Error(http.StatusInternalServerError, "AccessLevel", err)
return
}
2022-03-22 08:03:22 +01:00
if ctx.IsSigned && ctx.Doer.IsAdmin || access >= perm.AccessModeRead {
apiRepos = append(apiRepos, convert.ToRepo(ctx, repos[i], access))
}
2017-02-24 16:39:49 -05:00
}
ctx.SetLinkHeader(int(count), opts.PageSize)
2021-08-12 14:43:08 +02:00
ctx.SetTotalCountHeader(count)
2019-12-20 18:07:12 +01:00
ctx.JSON(http.StatusOK, &apiRepos)
2017-02-24 16:39:49 -05:00
}
// ListUserRepos - list the repos owned by the given user.
2017-02-24 16:39:49 -05:00
func ListUserRepos(ctx *context.APIContext) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /users/{username}/repos user userListRepos
// ---
// summary: List the repos owned by the given user
// produces:
// - application/json
// parameters:
// - name: username
// in: path
// description: username of user
// type: string
// 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
// 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
private := ctx.IsSigned
listUserRepos(ctx, ctx.ContextUser, private)
2017-02-24 16:39:49 -05:00
}
// ListMyRepos - list the repositories you own or have access to.
2017-02-24 16:39:49 -05:00
func ListMyRepos(ctx *context.APIContext) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /user/repos user userCurrentListRepos
// ---
2021-07-21 18:49:10 +02:00
// summary: List the repos that the authenticated user owns
2017-11-12 23:02:25 -08:00
// 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
// 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
opts := &repo_model.SearchRepoOptions{
ListOptions: utils.GetListOptions(ctx),
2022-03-22 08:03:22 +01:00
Actor: ctx.Doer,
OwnerID: ctx.Doer.ID,
Private: ctx.IsSigned,
IncludeDescription: true,
}
var err error
repos, count, err := repo_model.SearchRepository(ctx, opts)
2017-02-24 16:39:49 -05:00
if err != nil {
ctx.Error(http.StatusInternalServerError, "SearchRepository", err)
return
2017-02-24 16:39:49 -05:00
}
results := make([]*api.Repository, len(repos))
for i, repo := range repos {
if err = repo.GetOwner(ctx); err != nil {
ctx.Error(http.StatusInternalServerError, "GetOwner", err)
return
}
accessMode, err := access_model.AccessLevel(ctx, ctx.Doer, repo)
if err != nil {
ctx.Error(http.StatusInternalServerError, "AccessLevel", err)
}
results[i] = convert.ToRepo(ctx, repo, accessMode)
2017-02-24 16:39:49 -05:00
}
ctx.SetLinkHeader(int(count), opts.ListOptions.PageSize)
2021-08-12 14:43:08 +02:00
ctx.SetTotalCountHeader(count)
ctx.JSON(http.StatusOK, &results)
2017-02-24 16:39:49 -05:00
}
2017-07-13 04:14:15 -07:00
// ListOrgRepos - list the repositories of an organization.
func ListOrgRepos(ctx *context.APIContext) {
2017-11-12 23:02:25 -08:00
// swagger:operation GET /orgs/{org}/repos organization orgListRepos
// ---
// summary: List an organization's repos
// produces:
// - application/json
// parameters:
// - name: org
// in: path
// description: name of the organization
// type: string
// 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
// 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
listUserRepos(ctx, ctx.Org.Organization.AsUser(), ctx.IsSigned)
2017-07-13 04:14:15 -07:00
}