forked from Shiloh/githaven
722a7c902d
In investigating #7947 it has become clear that the storage component of go-git repositories needs closing. This PR adds this Close function and adds the Close functions as necessary. In TransferOwnership the ctx.Repo.GitRepo is closed if it is open to help prevent the risk of multiple open files. Fixes #7947
119 lines
3.0 KiB
Go
119 lines
3.0 KiB
Go
// 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 (
|
|
"code.gitea.io/gitea/modules/context"
|
|
"code.gitea.io/gitea/modules/git"
|
|
api "code.gitea.io/gitea/modules/structs"
|
|
)
|
|
|
|
// GetGitAllRefs get ref or an list all the refs of a repository
|
|
func GetGitAllRefs(ctx *context.APIContext) {
|
|
// swagger:operation GET /repos/{owner}/{repo}/git/refs repository repoListAllGitRefs
|
|
// ---
|
|
// summary: Get specified ref or filtered repository's refs
|
|
// 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
|
|
// responses:
|
|
// "200":
|
|
// "$ref": "#/responses/Reference"
|
|
// "$ref": "#/responses/ReferenceList"
|
|
// "404":
|
|
// "$ref": "#/responses/notFound"
|
|
|
|
getGitRefsInternal(ctx, "")
|
|
}
|
|
|
|
// GetGitRefs get ref or an filteresd list of refs of a repository
|
|
func GetGitRefs(ctx *context.APIContext) {
|
|
// swagger:operation GET /repos/{owner}/{repo}/git/refs/{ref} repository repoListGitRefs
|
|
// ---
|
|
// summary: Get specified ref or filtered repository's refs
|
|
// 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: ref
|
|
// in: path
|
|
// description: part or full name of the ref
|
|
// type: string
|
|
// required: true
|
|
// responses:
|
|
// "200":
|
|
// "$ref": "#/responses/Reference"
|
|
// "$ref": "#/responses/ReferenceList"
|
|
// "404":
|
|
// "$ref": "#/responses/notFound"
|
|
|
|
getGitRefsInternal(ctx, ctx.Params("*"))
|
|
}
|
|
|
|
func getGitRefs(ctx *context.APIContext, filter string) ([]*git.Reference, string, error) {
|
|
gitRepo, err := git.OpenRepository(ctx.Repo.Repository.RepoPath())
|
|
if err != nil {
|
|
return nil, "OpenRepository", err
|
|
}
|
|
defer gitRepo.Close()
|
|
|
|
if len(filter) > 0 {
|
|
filter = "refs/" + filter
|
|
}
|
|
refs, err := gitRepo.GetRefsFiltered(filter)
|
|
return refs, "GetRefsFiltered", err
|
|
}
|
|
|
|
func getGitRefsInternal(ctx *context.APIContext, filter string) {
|
|
refs, lastMethodName, err := getGitRefs(ctx, filter)
|
|
if err != nil {
|
|
ctx.Error(500, lastMethodName, err)
|
|
return
|
|
}
|
|
|
|
if len(refs) == 0 {
|
|
ctx.NotFound()
|
|
return
|
|
}
|
|
|
|
apiRefs := make([]*api.Reference, len(refs))
|
|
for i := range refs {
|
|
apiRefs[i] = &api.Reference{
|
|
Ref: refs[i].Name,
|
|
URL: ctx.Repo.Repository.APIURL() + "/git/" + refs[i].Name,
|
|
Object: &api.GitObject{
|
|
SHA: refs[i].Object.String(),
|
|
Type: refs[i].Type,
|
|
URL: ctx.Repo.Repository.APIURL() + "/git/" + refs[i].Type + "s/" + refs[i].Object.String(),
|
|
},
|
|
}
|
|
}
|
|
// If single reference is found and it matches filter exactly return it as object
|
|
if len(apiRefs) == 1 && apiRefs[0].Ref == filter {
|
|
ctx.JSON(200, &apiRefs[0])
|
|
return
|
|
}
|
|
ctx.JSON(200, &apiRefs)
|
|
}
|