Skip to content

Commit da4bbc4

Browse files
authored
Allow including Reviewed-on/Reviewed-by lines for custom merge messages (#31211)
This PR introduces the `ReviewedOn` and `ReviewedBy` variables for the default merge message templates (e.g., `.gitea/default_merge_message/MERGE_TEMPLATE.md`). This allows customizing the default merge messages while retaining these trailers. This also moves the associated logic out of `pull.tmpl` into the relevant Go function. This is a first contribution towards #11077. --- For illustration, this allows to recreate the "default default" merge message with the following template: ``` .gitea/default_merge_message/MERGE_TEMPLATE.md Merge pull request '${PullRequestTitle}' (${PullRequestReference}) from ${HeadBranch} into ${BaseBranch} ${ReviewedOn} ${ReviewedBy} ```
1 parent f7125ab commit da4bbc4

File tree

3 files changed

+18
-8
lines changed

3 files changed

+18
-8
lines changed

docs/content/usage/merge-message-templates.en-us.md

+2
Original file line numberDiff line numberDiff line change
@@ -44,6 +44,8 @@ You can use the following variables enclosed in `${}` inside these templates whi
4444
- PullRequestIndex: Pull request's index number
4545
- PullRequestReference: Pull request's reference char with index number. i.e. #1, !2
4646
- ClosingIssues: return a string contains all issues which will be closed by this pull request i.e. `close #1, close #2`
47+
- ReviewedOn: Which pull request this commit belongs to. For example `Reviewed-on: https://gitea.com/foo/bar/pulls/1`
48+
- ReviewedBy: Who approved the pull request before the merge. For example `Reviewed-by: Jane Doe <[email protected]>`
4749

4850
## Rebase
4951

services/pull/merge.go

+14-4
Original file line numberDiff line numberDiff line change
@@ -46,13 +46,19 @@ func getMergeMessage(ctx context.Context, baseGitRepo *git.Repository, pr *issue
4646
if err := pr.Issue.LoadPoster(ctx); err != nil {
4747
return "", "", err
4848
}
49+
if err := pr.Issue.LoadRepo(ctx); err != nil {
50+
return "", "", err
51+
}
4952

5053
isExternalTracker := pr.BaseRepo.UnitEnabled(ctx, unit.TypeExternalTracker)
5154
issueReference := "#"
5255
if isExternalTracker {
5356
issueReference = "!"
5457
}
5558

59+
reviewedOn := fmt.Sprintf("Reviewed-on: %s/%s", setting.AppURL, pr.Issue.Link())
60+
reviewedBy := pr.GetApprovers(ctx)
61+
5662
if mergeStyle != "" {
5763
templateFilepath := fmt.Sprintf(".gitea/default_merge_message/%s_TEMPLATE.md", strings.ToUpper(string(mergeStyle)))
5864
commit, err := baseGitRepo.GetBranchCommit(pr.BaseRepo.DefaultBranch)
@@ -77,6 +83,8 @@ func getMergeMessage(ctx context.Context, baseGitRepo *git.Repository, pr *issue
7783
"PullRequestPosterName": pr.Issue.Poster.Name,
7884
"PullRequestIndex": strconv.FormatInt(pr.Index, 10),
7985
"PullRequestReference": fmt.Sprintf("%s%d", issueReference, pr.Index),
86+
"ReviewedOn": reviewedOn,
87+
"ReviewedBy": reviewedBy,
8088
}
8189
if pr.HeadRepo != nil {
8290
vars["HeadRepoOwnerName"] = pr.HeadRepo.OwnerName
@@ -116,20 +124,22 @@ func getMergeMessage(ctx context.Context, baseGitRepo *git.Repository, pr *issue
116124
return "", "", nil
117125
}
118126

127+
body = fmt.Sprintf("%s\n%s", reviewedOn, reviewedBy)
128+
119129
// Squash merge has a different from other styles.
120130
if mergeStyle == repo_model.MergeStyleSquash {
121-
return fmt.Sprintf("%s (%s%d)", pr.Issue.Title, issueReference, pr.Issue.Index), "", nil
131+
return fmt.Sprintf("%s (%s%d)", pr.Issue.Title, issueReference, pr.Issue.Index), body, nil
122132
}
123133

124134
if pr.BaseRepoID == pr.HeadRepoID {
125-
return fmt.Sprintf("Merge pull request '%s' (%s%d) from %s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadBranch, pr.BaseBranch), "", nil
135+
return fmt.Sprintf("Merge pull request '%s' (%s%d) from %s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadBranch, pr.BaseBranch), body, nil
126136
}
127137

128138
if pr.HeadRepo == nil {
129-
return fmt.Sprintf("Merge pull request '%s' (%s%d) from <deleted>:%s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadBranch, pr.BaseBranch), "", nil
139+
return fmt.Sprintf("Merge pull request '%s' (%s%d) from <deleted>:%s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadBranch, pr.BaseBranch), body, nil
130140
}
131141

132-
return fmt.Sprintf("Merge pull request '%s' (%s%d) from %s:%s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadRepo.FullName(), pr.HeadBranch, pr.BaseBranch), "", nil
142+
return fmt.Sprintf("Merge pull request '%s' (%s%d) from %s:%s into %s", pr.Issue.Title, issueReference, pr.Issue.Index, pr.HeadRepo.FullName(), pr.HeadBranch, pr.BaseBranch), body, nil
133143
}
134144

135145
func expandDefaultMergeMessage(template string, vars map[string]string) (message, body string) {

templates/repo/issue/view_content/pull.tmpl

+2-4
Original file line numberDiff line numberDiff line change
@@ -199,7 +199,6 @@
199199

200200
{{if .AllowMerge}} {{/* user is allowed to merge */}}
201201
{{$prUnit := .Repository.MustGetUnit $.Context ctx.Consts.RepoUnitTypePullRequests}}
202-
{{$approvers := (.Issue.PullRequest.GetApprovers ctx)}}
203202
{{if or $prUnit.PullRequestsConfig.AllowMerge $prUnit.PullRequestsConfig.AllowRebase $prUnit.PullRequestsConfig.AllowRebaseMerge $prUnit.PullRequestsConfig.AllowSquash $prUnit.PullRequestsConfig.AllowFastForwardOnly}}
204203
{{$hasPendingPullRequestMergeTip := ""}}
205204
{{if .HasPendingPullRequestMerge}}
@@ -208,11 +207,10 @@
208207
{{end}}
209208
<div class="divider"></div>
210209
<script type="module">
211-
const issueUrl = window.location.origin + {{$.Issue.Link}};
212210
const defaultMergeTitle = {{.DefaultMergeMessage}};
213211
const defaultSquashMergeTitle = {{.DefaultSquashMergeMessage}};
214-
const defaultMergeMessage = {{if .DefaultMergeBody}}{{.DefaultMergeBody}}{{else}}`Reviewed-on: ${issueUrl}\n` + {{$approvers}}{{end}};
215-
const defaultSquashMergeMessage = {{if .DefaultSquashMergeBody}}{{.DefaultSquashMergeBody}}{{else}}`Reviewed-on: ${issueUrl}\n` + {{$approvers}}{{end}};
212+
const defaultMergeMessage = {{.DefaultMergeBody}};
213+
const defaultSquashMergeMessage = {{.DefaultSquashMergeBody}};
216214
const mergeForm = {
217215
'baseLink': {{.Link}},
218216
'textCancel': {{ctx.Locale.Tr "cancel"}},

0 commit comments

Comments
 (0)