diff options
author | Bwko <bouwko@gmail.com> | 2016-12-25 17:19:25 +0100 |
---|---|---|
committer | Kim "BKC" Carlbäcker <kim.carlbacker@gmail.com> | 2016-12-26 11:55:28 +0100 |
commit | 71dee6b7c09242707028cdfe23373a1f88d6a663 (patch) | |
tree | c5d424d2f68880728baca8a211899ff662f6f2b8 /routers/repo/branch.go | |
parent | 71634452e17a6c954e5612f861780effe7528992 (diff) | |
download | gitea-71dee6b7c09242707028cdfe23373a1f88d6a663.tar.gz gitea-71dee6b7c09242707028cdfe23373a1f88d6a663.zip |
Improve the way how branches are deleted
Delete branch from HeadRepo instead of BaseRepo
Prevent the deletion of a master branch
Show a yes/no overlay when you press the delete branch button
Diffstat (limited to 'routers/repo/branch.go')
-rw-r--r-- | routers/repo/branch.go | 42 |
1 files changed, 36 insertions, 6 deletions
diff --git a/routers/repo/branch.go b/routers/repo/branch.go index c3336e598c..104d459a7d 100644 --- a/routers/repo/branch.go +++ b/routers/repo/branch.go @@ -8,6 +8,7 @@ import ( "code.gitea.io/git" "code.gitea.io/gitea/modules/base" "code.gitea.io/gitea/modules/context" + "code.gitea.io/gitea/modules/log" ) const ( @@ -35,17 +36,46 @@ func Branches(ctx *context.Context) { // DeleteBranchPost responses for delete merged branch func DeleteBranchPost(ctx *context.Context) { branchName := ctx.Params(":name") + commitID := ctx.Query("commit") + + defer func() { + redirectTo := ctx.Query("redirect_to") + if len(redirectTo) == 0 { + redirectTo = ctx.Repo.RepoLink + } + + ctx.JSON(200, map[string]interface{}{ + "redirect": redirectTo, + }) + }() + + fullBranchName := ctx.Repo.Owner.Name + "/" + branchName + + if !ctx.Repo.GitRepo.IsBranchExist(branchName) || branchName == "master" { + ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName)) + return + } + + if len(commitID) > 0 { + branchCommitID, err := ctx.Repo.GitRepo.GetBranchCommitID(branchName) + if err != nil { + log.Error(4, "GetBranchCommitID: %v", err) + return + } + + if branchCommitID != commitID { + ctx.Flash.Error(ctx.Tr("repo.branch.delete_branch_has_new_commits", fullBranchName)) + return + } + } if err := ctx.Repo.GitRepo.DeleteBranch(branchName, git.DeleteBranchOptions{ Force: false, }); err != nil { - ctx.Handle(500, "DeleteBranch", err) + log.Error(4, "DeleteBranch: %v", err) + ctx.Flash.Error(ctx.Tr("repo.branch.deletion_failed", fullBranchName)) return } - redirectTo := ctx.Query("redirect_to") - if len(redirectTo) == 0 { - redirectTo = ctx.Repo.RepoLink - } - ctx.Redirect(redirectTo) + ctx.Flash.Success(ctx.Tr("repo.branch.deletion_success", fullBranchName)) } |