mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2024-12-22 12:54:53 -05:00
show pull link for agit pull request also (#18235)
This commit is contained in:
parent
bd7680f450
commit
43a22c6a21
1 changed files with 38 additions and 0 deletions
|
@ -8,6 +8,7 @@ package private
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"code.gitea.io/gitea/models"
|
"code.gitea.io/gitea/models"
|
||||||
|
@ -124,6 +125,43 @@ func HookPostReceive(ctx *gitea_context.PrivateContext) {
|
||||||
refFullName := opts.RefFullNames[i]
|
refFullName := opts.RefFullNames[i]
|
||||||
newCommitID := opts.NewCommitIDs[i]
|
newCommitID := opts.NewCommitIDs[i]
|
||||||
|
|
||||||
|
// post update for agit pull request
|
||||||
|
if git.SupportProcReceive && strings.HasPrefix(refFullName, git.PullPrefix) {
|
||||||
|
if repo == nil {
|
||||||
|
repo = loadRepository(ctx, ownerName, repoName)
|
||||||
|
if ctx.Written() {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pullIndexStr := strings.TrimPrefix(refFullName, git.PullPrefix)
|
||||||
|
pullIndexStr = strings.Split(pullIndexStr, "/")[0]
|
||||||
|
pullIndex, _ := strconv.ParseInt(pullIndexStr, 10, 64)
|
||||||
|
if pullIndex <= 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
pr, err := models.GetPullRequestByIndex(repo.ID, pullIndex)
|
||||||
|
if err != nil && !models.IsErrPullRequestNotExist(err) {
|
||||||
|
log.Error("Failed to get PR by index %v Error: %v", pullIndex, err)
|
||||||
|
ctx.JSON(http.StatusInternalServerError, private.Response{
|
||||||
|
Err: fmt.Sprintf("Failed to get PR by index %v Error: %v", pullIndex, err),
|
||||||
|
})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if pr == nil {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
results = append(results, private.HookPostReceiveBranchResult{
|
||||||
|
Message: setting.Git.PullRequestPushMessage && repo.AllowsPulls(),
|
||||||
|
Create: false,
|
||||||
|
Branch: "",
|
||||||
|
URL: fmt.Sprintf("%s/pulls/%d", repo.HTMLURL(), pr.Index),
|
||||||
|
})
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
branch := git.RefEndName(opts.RefFullNames[i])
|
branch := git.RefEndName(opts.RefFullNames[i])
|
||||||
|
|
||||||
// If we've pushed a branch (and not deleted it)
|
// If we've pushed a branch (and not deleted it)
|
||||||
|
|
Loading…
Reference in a new issue