123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- package repo
- import (
- "time"
- log "gopkg.in/clog.v1"
- "github.com/gogs/git-module"
- api "github.com/gogs/go-gogs-client"
- "github.com/gogs/gogs/models"
- "github.com/gogs/gogs/pkg/context"
- "github.com/gogs/gogs/pkg/tool"
- )
- const (
- BRANCHES_OVERVIEW = "repo/branches/overview"
- BRANCHES_ALL = "repo/branches/all"
- )
- type Branch struct {
- Name string
- Commit *git.Commit
- IsProtected bool
- }
- func loadBranches(c *context.Context) []*Branch {
- rawBranches, err := c.Repo.Repository.GetBranches()
- if err != nil {
- c.Handle(500, "GetBranches", err)
- return nil
- }
- protectBranches, err := models.GetProtectBranchesByRepoID(c.Repo.Repository.ID)
- if err != nil {
- c.Handle(500, "GetProtectBranchesByRepoID", err)
- return nil
- }
- branches := make([]*Branch, len(rawBranches))
- for i := range rawBranches {
- commit, err := rawBranches[i].GetCommit()
- if err != nil {
- c.Handle(500, "GetCommit", err)
- return nil
- }
- branches[i] = &Branch{
- Name: rawBranches[i].Name,
- Commit: commit,
- }
- for j := range protectBranches {
- if branches[i].Name == protectBranches[j].Name {
- branches[i].IsProtected = true
- break
- }
- }
- }
- c.Data["AllowPullRequest"] = c.Repo.Repository.AllowsPulls()
- return branches
- }
- func Branches(c *context.Context) {
- c.Data["Title"] = c.Tr("repo.git_branches")
- c.Data["PageIsBranchesOverview"] = true
- branches := loadBranches(c)
- if c.Written() {
- return
- }
- now := time.Now()
- activeBranches := make([]*Branch, 0, 3)
- staleBranches := make([]*Branch, 0, 3)
- for i := range branches {
- switch {
- case branches[i].Name == c.Repo.BranchName:
- c.Data["DefaultBranch"] = branches[i]
- case branches[i].Commit.Committer.When.Add(30 * 24 * time.Hour).After(now):
- activeBranches = append(activeBranches, branches[i])
- case branches[i].Commit.Committer.When.Add(3 * 30 * 24 * time.Hour).Before(now):
- staleBranches = append(staleBranches, branches[i])
- }
- }
- c.Data["ActiveBranches"] = activeBranches
- c.Data["StaleBranches"] = staleBranches
- c.HTML(200, BRANCHES_OVERVIEW)
- }
- func AllBranches(c *context.Context) {
- c.Data["Title"] = c.Tr("repo.git_branches")
- c.Data["PageIsBranchesAll"] = true
- branches := loadBranches(c)
- if c.Written() {
- return
- }
- c.Data["Branches"] = branches
- c.HTML(200, BRANCHES_ALL)
- }
- func DeleteBranchPost(c *context.Context) {
- branchName := c.Params("*")
- commitID := c.Query("commit")
- defer func() {
- redirectTo := c.Query("redirect_to")
- if !tool.IsSameSiteURLPath(redirectTo) {
- redirectTo = c.Repo.RepoLink
- }
- c.Redirect(redirectTo)
- }()
- if !c.Repo.GitRepo.IsBranchExist(branchName) {
- return
- }
- if len(commitID) > 0 {
- branchCommitID, err := c.Repo.GitRepo.GetBranchCommitID(branchName)
- if err != nil {
- log.Error(2, "Failed to get commit ID of branch %q: %v", branchName, err)
- return
- }
- if branchCommitID != commitID {
- c.Flash.Error(c.Tr("repo.pulls.delete_branch_has_new_commits"))
- return
- }
- }
- if err := c.Repo.GitRepo.DeleteBranch(branchName, git.DeleteBranchOptions{
- Force: true,
- }); err != nil {
- log.Error(2, "Failed to delete branch %q: %v", branchName, err)
- return
- }
- if err := models.PrepareWebhooks(c.Repo.Repository, models.HOOK_EVENT_DELETE, &api.DeletePayload{
- Ref: branchName,
- RefType: "branch",
- PusherType: api.PUSHER_TYPE_USER,
- Repo: c.Repo.Repository.APIFormat(nil),
- Sender: c.User.APIFormat(),
- }); err != nil {
- log.Error(2, "Failed to prepare webhooks for %q: %v", models.HOOK_EVENT_DELETE, err)
- return
- }
- }
|