mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Make API "compare" accept commit IDs (#32801)
This commit is contained in:
		| @@ -39,10 +39,9 @@ import ( | ||||
|  | ||||
| // PullRequest contains information to make a pull request | ||||
| type PullRequest struct { | ||||
| 	BaseRepo       *repo_model.Repository | ||||
| 	Allowed        bool | ||||
| 	SameRepo       bool | ||||
| 	HeadInfoSubURL string // [<user>:]<branch> url segment | ||||
| 	BaseRepo *repo_model.Repository | ||||
| 	Allowed  bool // it only used by the web tmpl: "PullRequestCtx.Allowed" | ||||
| 	SameRepo bool // it only used by the web tmpl: "PullRequestCtx.SameRepo" | ||||
| } | ||||
|  | ||||
| // Repository contains information to operate a repository | ||||
| @@ -401,6 +400,7 @@ func repoAssignment(ctx *Context, repo *repo_model.Repository) { | ||||
| // RepoAssignment returns a middleware to handle repository assignment | ||||
| func RepoAssignment(ctx *Context) context.CancelFunc { | ||||
| 	if _, repoAssignmentOnce := ctx.Data["repoAssignmentExecuted"]; repoAssignmentOnce { | ||||
| 		// FIXME: it should panic in dev/test modes to have a clear behavior | ||||
| 		log.Trace("RepoAssignment was exec already, skipping second call ...") | ||||
| 		return nil | ||||
| 	} | ||||
| @@ -697,7 +697,6 @@ func RepoAssignment(ctx *Context) context.CancelFunc { | ||||
| 		ctx.Data["BaseRepo"] = repo.BaseRepo | ||||
| 		ctx.Repo.PullRequest.BaseRepo = repo.BaseRepo | ||||
| 		ctx.Repo.PullRequest.Allowed = canPush | ||||
| 		ctx.Repo.PullRequest.HeadInfoSubURL = url.PathEscape(ctx.Repo.Owner.Name) + ":" + util.PathEscapeSegments(ctx.Repo.BranchName) | ||||
| 	} else if repo.AllowsPulls(ctx) { | ||||
| 		// Or, this is repository accepts pull requests between branches. | ||||
| 		canCompare = true | ||||
| @@ -705,7 +704,6 @@ func RepoAssignment(ctx *Context) context.CancelFunc { | ||||
| 		ctx.Repo.PullRequest.BaseRepo = repo | ||||
| 		ctx.Repo.PullRequest.Allowed = canPush | ||||
| 		ctx.Repo.PullRequest.SameRepo = true | ||||
| 		ctx.Repo.PullRequest.HeadInfoSubURL = util.PathEscapeSegments(ctx.Repo.BranchName) | ||||
| 	} | ||||
| 	ctx.Data["CanCompareOrPull"] = canCompare | ||||
| 	ctx.Data["PullRequestCtx"] = ctx.Repo.PullRequest | ||||
| @@ -771,20 +769,6 @@ func getRefNameFromPath(repo *Repository, path string, isExist func(string) bool | ||||
| 	return "" | ||||
| } | ||||
|  | ||||
| func isStringLikelyCommitID(objFmt git.ObjectFormat, s string, minLength ...int) bool { | ||||
| 	minLen := util.OptionalArg(minLength, objFmt.FullLength()) | ||||
| 	if len(s) < minLen || len(s) > objFmt.FullLength() { | ||||
| 		return false | ||||
| 	} | ||||
| 	for _, c := range s { | ||||
| 		isHex := (c >= '0' && c <= '9') || (c >= 'a' && c <= 'f') | ||||
| 		if !isHex { | ||||
| 			return false | ||||
| 		} | ||||
| 	} | ||||
| 	return true | ||||
| } | ||||
|  | ||||
| func getRefNameLegacy(ctx *Base, repo *Repository, optionalExtraRef ...string) (string, RepoRefType) { | ||||
| 	extraRef := util.OptionalArg(optionalExtraRef) | ||||
| 	reqPath := ctx.PathParam("*") | ||||
| @@ -799,7 +783,7 @@ func getRefNameLegacy(ctx *Base, repo *Repository, optionalExtraRef ...string) ( | ||||
|  | ||||
| 	// For legacy support only full commit sha | ||||
| 	parts := strings.Split(reqPath, "/") | ||||
| 	if isStringLikelyCommitID(git.ObjectFormatFromName(repo.Repository.ObjectFormatName), parts[0]) { | ||||
| 	if git.IsStringLikelyCommitID(git.ObjectFormatFromName(repo.Repository.ObjectFormatName), parts[0]) { | ||||
| 		// FIXME: this logic is different from other types. Ideally, it should also try to GetCommit to check if it exists | ||||
| 		repo.TreePath = strings.Join(parts[1:], "/") | ||||
| 		return parts[0], RepoRefCommit | ||||
| @@ -849,7 +833,7 @@ func getRefName(ctx *Base, repo *Repository, pathType RepoRefType) string { | ||||
| 		return getRefNameFromPath(repo, path, repo.GitRepo.IsTagExist) | ||||
| 	case RepoRefCommit: | ||||
| 		parts := strings.Split(path, "/") | ||||
| 		if isStringLikelyCommitID(repo.GetObjectFormat(), parts[0], 7) { | ||||
| 		if git.IsStringLikelyCommitID(repo.GetObjectFormat(), parts[0], 7) { | ||||
| 			// FIXME: this logic is different from other types. Ideally, it should also try to GetCommit to check if it exists | ||||
| 			repo.TreePath = strings.Join(parts[1:], "/") | ||||
| 			return parts[0] | ||||
| @@ -985,7 +969,7 @@ func RepoRefByType(detectRefType RepoRefType, opts ...RepoRefByTypeOptions) func | ||||
| 					return cancel | ||||
| 				} | ||||
| 				ctx.Repo.CommitID = ctx.Repo.Commit.ID.String() | ||||
| 			} else if isStringLikelyCommitID(ctx.Repo.GetObjectFormat(), refName, 7) { | ||||
| 			} else if git.IsStringLikelyCommitID(ctx.Repo.GetObjectFormat(), refName, 7) { | ||||
| 				ctx.Repo.IsViewCommit = true | ||||
| 				ctx.Repo.CommitID = refName | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user