Started on Git-Trees api
This commit is contained in:
parent
8a5925b9bd
commit
347120d900
|
@ -377,6 +377,11 @@ func RegisterRoutes(m *macaron.Macaron) {
|
||||||
|
|
||||||
m.Group("/:username/:reponame", func() {
|
m.Group("/:username/:reponame", func() {
|
||||||
m.Combo("").Get(repo.Get).Delete(reqToken(), repo.Delete)
|
m.Combo("").Get(repo.Get).Delete(reqToken(), repo.Delete)
|
||||||
|
|
||||||
|
m.Group("/trees", func() {
|
||||||
|
m.Combo("/:sha", context.RepoRef()).Get(repo.GetTree)
|
||||||
|
})
|
||||||
|
|
||||||
m.Group("/hooks", func() {
|
m.Group("/hooks", func() {
|
||||||
m.Combo("").Get(repo.ListHooks).
|
m.Combo("").Get(repo.ListHooks).
|
||||||
Post(bind(api.CreateHookOption{}), repo.CreateHook)
|
Post(bind(api.CreateHookOption{}), repo.CreateHook)
|
||||||
|
@ -387,6 +392,9 @@ func RegisterRoutes(m *macaron.Macaron) {
|
||||||
m.Post("/tests", context.RepoRef(), repo.TestHook)
|
m.Post("/tests", context.RepoRef(), repo.TestHook)
|
||||||
})
|
})
|
||||||
}, reqToken(), reqRepoWriter())
|
}, reqToken(), reqRepoWriter())
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
m.Group("/collaborators", func() {
|
m.Group("/collaborators", func() {
|
||||||
m.Get("", repo.ListCollaborators)
|
m.Get("", repo.ListCollaborators)
|
||||||
m.Combo("/:collaborator").Get(repo.IsCollaborator).
|
m.Combo("/:collaborator").Get(repo.IsCollaborator).
|
||||||
|
|
89
routers/api/v1/repo/tree.go
Normal file
89
routers/api/v1/repo/tree.go
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
package repo
|
||||||
|
|
||||||
|
import (
|
||||||
|
"code.gitea.io/gitea/modules/context"
|
||||||
|
"fmt"
|
||||||
|
_"code.gitea.io/git"
|
||||||
|
"code.gitea.io/gitea/modules/setting"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
type TreeEntry struct {
|
||||||
|
Path string `json:"path"`
|
||||||
|
Mode string `json:"mode"`
|
||||||
|
Type string `json:"type"`
|
||||||
|
Size int64 `json:"size,omitempty"`
|
||||||
|
SHA string `json:"sha"`
|
||||||
|
URL string `json:"url"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type Tree struct {
|
||||||
|
SHA string `json:"sha"`
|
||||||
|
URL string `json:"url"`
|
||||||
|
Entries []TreeEntry `json:"tree,omitempty"`
|
||||||
|
Truncated bool `json:"truncated"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetTree(ctx *context.APIContext) {
|
||||||
|
sha := ctx.Params("sha")
|
||||||
|
if len(sha) == 0 {
|
||||||
|
ctx.Error(400, "sha not provided", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Temp := GetTreeBySHA(ctx, nil, "", sha, ctx.QueryBool("recursive"))
|
||||||
|
if Temp != nil {
|
||||||
|
ctx.JSON(200, Temp)
|
||||||
|
} else {
|
||||||
|
ctx.Error(400, "sha invalid", nil)
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetTreeBySHA(ctx *context.APIContext, tree *Tree, CurrentPath string, sha string, recursive bool) *Tree {
|
||||||
|
GitTree, err := ctx.Repo.GitRepo.GetTree(sha)
|
||||||
|
if err != nil {
|
||||||
|
return tree
|
||||||
|
}
|
||||||
|
RepoID := strings.TrimRight(setting.AppURL, "/") + "/api/v1/repos/" + ctx.Repo.Repository.Owner.Name + "/" + ctx.Repo.Repository.Name
|
||||||
|
if tree == nil {
|
||||||
|
tree = new(Tree)
|
||||||
|
if GitTree != nil {
|
||||||
|
tree.SHA = GitTree.ID.String()
|
||||||
|
tree.URL = RepoID + "/trees/" + tree.SHA;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if GitTree == nil {
|
||||||
|
return tree
|
||||||
|
}
|
||||||
|
Trees, err := GitTree.ListEntries()
|
||||||
|
if err != nil {
|
||||||
|
return tree
|
||||||
|
}
|
||||||
|
if len(CurrentPath) != 0 {
|
||||||
|
CurrentPath += "/"
|
||||||
|
}
|
||||||
|
for e := range Trees {
|
||||||
|
if len(tree.Entries) > 1000 {
|
||||||
|
tree.Truncated = true
|
||||||
|
break
|
||||||
|
}
|
||||||
|
E_URL := RepoID
|
||||||
|
if Trees[e].IsDir() {
|
||||||
|
E_URL += "/trees/"
|
||||||
|
} else {
|
||||||
|
E_URL += "/blobs/"
|
||||||
|
}
|
||||||
|
tree.Entries = append(tree.Entries, TreeEntry{
|
||||||
|
CurrentPath + Trees[e].Name(),
|
||||||
|
fmt.Sprintf("%06x", Trees[e].Mode()),
|
||||||
|
string(Trees[e].Type),
|
||||||
|
Trees[e].Size(),
|
||||||
|
Trees[e].ID.String(),
|
||||||
|
E_URL + Trees[e].ID.String()})
|
||||||
|
|
||||||
|
if recursive && Trees[e].IsDir() {
|
||||||
|
tree = GetTreeBySHA(ctx, tree, CurrentPath + Trees[e].Name(), Trees[e].ID.String(), recursive)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return tree
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user