mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-26 21:43:41 +08:00 
			
		
		
		
	show pull link for agit pull request also (#18235)
This commit is contained in:
		| @ -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) | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 a1012112796
					a1012112796