// Copyright 2018 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 repo import ( "net/http" "code.gitea.io/gitea/modules/context" "code.gitea.io/gitea/modules/repofiles" ) // GetTree get the tree of a repository. func GetTree(ctx *context.APIContext) { // swagger:operation GET /repos/{owner}/{repo}/git/trees/{sha} repository GetTree // --- // summary: Gets the tree of a repository. // 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: sha // in: path // description: sha of the commit // type: string // required: true // - name: recursive // in: query // description: show all directories and files // required: false // type: boolean // - name: page // in: query // description: page number; the 'truncated' field in the response will be true if there are still more items after this page, false if the last page // required: false // type: integer // - name: per_page // in: query // description: number of items per page; default is 1000 or what is set in app.ini as DEFAULT_GIT_TREES_PER_PAGE // required: false // type: integer // responses: // "200": // "$ref": "#/responses/GitTreeResponse" // "400": // "$ref": "#/responses/error" sha := ctx.Params(":sha") if len(sha) == 0 { ctx.Error(http.StatusBadRequest, "", "sha not provided") return } if tree, err := repofiles.GetTreeBySHA(ctx.Repo.Repository, sha, ctx.QueryInt("page"), ctx.QueryInt("per_page"), ctx.QueryBool("recursive")); err != nil { ctx.Error(http.StatusBadRequest, "", err.Error()) } else { ctx.JSON(http.StatusOK, tree) } }