Merge pull request #2506 from sapk/add-branche-api-support
Implement API for branches listingtokarchuk/v1.17
commit
5e97693e0e
@ -0,0 +1,43 @@ |
||||
// Copyright 2016 The Gogs 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 models |
||||
|
||||
import ( |
||||
"github.com/gogits/git-module" |
||||
) |
||||
|
||||
type Branch struct { |
||||
Path string |
||||
Name string |
||||
} |
||||
|
||||
func GetBranchesByPath(path string) ([]*Branch, error) { |
||||
gitRepo, err := git.OpenRepository(path) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
brs, err := gitRepo.GetBranches() |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
|
||||
Branches := make([]*Branch, len(brs)) |
||||
for i := range brs { |
||||
Branches[i] = &Branch{ |
||||
Path: path, |
||||
Name: brs[i], |
||||
} |
||||
} |
||||
return Branches, nil |
||||
} |
||||
|
||||
func (br *Branch) GetCommit() (*git.Commit, error) { |
||||
gitRepo, err := git.OpenRepository(br.Path) |
||||
if err != nil { |
||||
return nil, err |
||||
} |
||||
return gitRepo.GetBranchCommit(br.Name) |
||||
} |
@ -0,0 +1,55 @@ |
||||
// Copyright 2016 The Gogs 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 ( |
||||
api "github.com/gogits/go-gogs-client" |
||||
|
||||
"github.com/gogits/gogs/modules/middleware" |
||||
"github.com/gogits/gogs/routers/api/v1/convert" |
||||
) |
||||
|
||||
// Temporary: https://gist.github.com/sapk/df64347ff218baf4a277#get-a-branch
|
||||
// https://github.com/gogits/go-gogs-client/wiki/Repositories-Branches#get-a-branch
|
||||
func GetBranch(ctx *middleware.Context) { |
||||
// Getting the branch requested
|
||||
branch, err := ctx.Repo.Repository.GetBranch(ctx.Params(":branchname")) |
||||
if err != nil { |
||||
ctx.APIError(500, "Repository.GetBranch", err) |
||||
return |
||||
} |
||||
// Getting the last commit of the branch
|
||||
c, err := branch.GetCommit() |
||||
if err != nil { |
||||
ctx.APIError(500, "Branch.GetCommit", err) |
||||
return |
||||
} |
||||
// Converting to API format and send payload
|
||||
ctx.JSON(200, convert.ToApiBranch(branch,c)) |
||||
} |
||||
|
||||
// Temporary: https://gist.github.com/sapk/df64347ff218baf4a277#list-branches
|
||||
// https://github.com/gogits/go-gogs-client/wiki/Repositories-Branches#list-branches
|
||||
func ListBranches(ctx *middleware.Context) { |
||||
// Listing of branches
|
||||
Branches, err := ctx.Repo.Repository.GetBranches() |
||||
if err != nil { |
||||
ctx.APIError(500, "Repository.GetBranches", err) |
||||
return |
||||
} |
||||
// Getting the last commit of each branch
|
||||
apiBranches := make([]*api.Branch, len(Branches)) |
||||
for i := range Branches { |
||||
c, err := Branches[i].GetCommit() |
||||
if err != nil { |
||||
ctx.APIError(500, "Branch.GetCommit", err) |
||||
return |
||||
} |
||||
// Converting to API format
|
||||
apiBranches[i] = convert.ToApiBranch(Branches[i],c) |
||||
} |
||||
// Sending the payload
|
||||
ctx.JSON(200, &apiBranches) |
||||
} |
Loading…
Reference in new issue