mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 03:57:13 +08:00 
			
		
		
		
	Prevent panic on merge to PR (#10403)
If you attempt to merge to a branch which on a PR there will be a nil pointer error in the pull request checker. This panic is uncaught and will bring down the gitea server. This PR adds protection to prevent this.
This commit is contained in:
		| @ -324,6 +324,10 @@ func PushToBaseRepo(pr *models.PullRequest) (err error) { | ||||
| 		} | ||||
| 	}() | ||||
|  | ||||
| 	if err := pr.LoadHeadRepo(); err != nil { | ||||
| 		log.Error("Unable to load head repository for PR[%d] Error: %v", pr.ID, err) | ||||
| 		return err | ||||
| 	} | ||||
| 	headRepoPath := pr.HeadRepo.RepoPath() | ||||
|  | ||||
| 	if err := git.Clone(headRepoPath, tmpBasePath, git.CloneRepoOptions{ | ||||
| @ -340,6 +344,10 @@ func PushToBaseRepo(pr *models.PullRequest) (err error) { | ||||
| 		return fmt.Errorf("OpenRepository: %v", err) | ||||
| 	} | ||||
|  | ||||
| 	if err := pr.LoadBaseRepo(); err != nil { | ||||
| 		log.Error("Unable to load base repository for PR[%d] Error: %v", pr.ID, err) | ||||
| 		return err | ||||
| 	} | ||||
| 	if err := gitRepo.AddRemote("base", pr.BaseRepo.RepoPath(), false); err != nil { | ||||
| 		return fmt.Errorf("tmpGitRepo.AddRemote: %v", err) | ||||
| 	} | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 zeripath
					zeripath