// 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 ( "code.gitea.io/gitea/models" "code.gitea.io/gitea/modules/context" api "code.gitea.io/gitea/modules/structs" ) // listUserRepos - List the repositories owned by the given user. func listUserRepos(ctx *context.APIContext, u *models.User, private bool) { repos, err := models.GetUserRepositories(u.ID, private, 1, u.NumRepos, "") if err != nil { ctx.Error(500, "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(500, "AccessLevel", err) return } if ctx.IsSigned && ctx.User.IsAdmin || access >= models.AccessModeRead { apiRepos = append(apiRepos, repos[i].APIFormat(access)) } } ctx.JSON(200, &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 // 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 // responses: // "200": // "$ref": "#/responses/RepositoryList" ownRepos, err := models.GetUserRepositories(ctx.User.ID, true, 1, ctx.User.NumRepos, "") if err != nil { ctx.Error(500, "GetUserRepositories", err) return } accessibleReposMap, err := ctx.User.GetRepositoryAccesses() if err != nil { ctx.Error(500, "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(200, &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 // responses: // "200": // "$ref": "#/responses/RepositoryList" listUserRepos(ctx, ctx.Org.Organization, ctx.IsSigned) }