From dad806d3ea0da6a09eea14ac467d0c843a98dda4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kim=20=22BKC=22=20Carlb=C3=A4cker?= Date: Tue, 29 Nov 2016 09:13:30 +0100 Subject: [PATCH] CreateBranch-hook has shasum. Use the full ref for fetching shasum --- models/action.go | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/models/action.go b/models/action.go index aebc02be54e..e2ac1756ab3 100644 --- a/models/action.go +++ b/models/action.go @@ -540,6 +540,8 @@ func CommitRepoAction(opts CommitRepoActionOptions) error { apiPusher := pusher.APIFormat() apiRepo := repo.APIFormat(nil) + + var shaSum string switch opType { case ActionCommitRepo: // Push if err = PrepareWebhooks(repo, HookEventPush, &api.PushPayload{ @@ -556,8 +558,17 @@ func CommitRepoAction(opts CommitRepoActionOptions) error { } if isNewBranch { + gitRepo, err := git.OpenRepository(repo.RepoPath()) + if err != nil { + log.Error(4, "OpenRepository[%s]: %v", repo.RepoPath(), err) + } + shaSum, err = gitRepo.GetBranchCommitID(opts.RefFullName) + if err != nil { + log.Error(4, "GetBranchCommitID[%s]: %v", opts.RefFullName, err) + } return PrepareWebhooks(repo, HookEventCreate, &api.CreatePayload{ Ref: refName, + Sha: shaSum, RefType: "branch", Repo: apiRepo, Sender: apiPusher, @@ -565,7 +576,14 @@ func CommitRepoAction(opts CommitRepoActionOptions) error { } case ActionPushTag: // Create - shaSum := git.OpenRepository(repo.RepoPath()).GetTagCommitID(refName) + gitRepo, err := git.OpenRepository(repo.RepoPath()) + if err != nil { + log.Error(4, "OpenRepository[%s]: %v", repo.RepoPath(), err) + } + shaSum, err = gitRepo.GetTagCommitID(opts.RefFullName) + if err != nil { + log.Error(4, "GetTagCommitID[%s]: %v", opts.RefFullName, err) + } return PrepareWebhooks(repo, HookEventCreate, &api.CreatePayload{ Ref: refName, Sha: shaSum,