// Copyright 2017 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 ( "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" ) // listUserRepos - List the repositories owned by the given user. func listUserRepos(ctx *context.APIContext, u *models.User, private bool) { repos, err := models.GetUserRepositories(&models.SearchRepoOptions{ Actor: u, Private: private, ListOptions: utils.GetListOptions(ctx), }) if err != nil { ctx.Error(http.StatusInternalServerError, "GetUserRepositories", err) return } apiRepos := make([]*api.Repository, 0, len(repos)) for i := range repos { access, err := models.AccessLevel(ctx.User, repos[i]) if err != nil { ctx.Error(http.StatusInternalServerError, "AccessLevel", err) return } if ctx.IsSigned && ctx.User.IsAdmin || access >= models.AccessModeRead { apiRepos = append(apiRepos, repos[i].APIFormat(access)) } } ctx.JSON(http.StatusOK, &apiRepos) } // ListUserRepos - list the repos owned by the given user. func ListUserRepos(ctx *context.APIContext) { // 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 // - name: page // in: query // description: page number of results to return (1-based) // type: integer // - name: limit // in: query // description: page size of results, maximum page size is 50 // type: integer // responses: // "200": // "$ref": "#/responses/RepositoryList" user := GetUserByParams(ctx) if ctx.Written() { return } private := ctx.IsSigned listUserRepos(ctx, user, private) } // ListMyRepos - list the repositories you own or have access to. func ListMyRepos(ctx *context.APIContext) { // swagger:operation GET /user/repos user userCurrentListRepos // --- // summary: List the repos that the authenticated user owns or has access to // produces: // - application/json // 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, maximum page size is 50 // type: integer // responses: // "200": // "$ref": "#/responses/RepositoryList" ownRepos, err := models.GetUserRepositories(&models.SearchRepoOptions{ Actor: ctx.User, Private: true, ListOptions: utils.GetListOptions(ctx), }) if err != nil { ctx.Error(http.StatusInternalServerError, "GetUserRepositories", err) return } accessibleReposMap, err := ctx.User.GetRepositoryAccesses() if err != nil { ctx.Error(http.StatusInternalServerError, "GetRepositoryAccesses", err) return } apiRepos := make([]*api.Repository, len(ownRepos)+len(accessibleReposMap)) for i := range ownRepos { apiRepos[i] = ownRepos[i].APIFormat(models.AccessModeOwner) } i := len(ownRepos) for repo, access := range accessibleReposMap { apiRepos[i] = repo.APIFormat(access) i++ } ctx.JSON(http.StatusOK, &apiRepos) } // ListOrgRepos - list the repositories of an organization. func ListOrgRepos(ctx *context.APIContext) { // 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 // - name: page // in: query // description: page number of results to return (1-based) // type: integer // - name: limit // in: query // description: page size of results, maximum page size is 50 // type: integer // responses: // "200": // "$ref": "#/responses/RepositoryList" listUserRepos(ctx, ctx.Org.Organization, ctx.IsSigned) }