mirror of https://github.com/go-gitea/gitea.git
Support choose email when creating a commit via web UI (more) (#33445)
Follow #33432pull/33449/head^2
parent
b57d9f41d4
commit
5a7b42dac7
@ -0,0 +1,40 @@
|
||||
// Copyright 2025 The Gitea Authors. All rights reserved.
|
||||
// SPDX-License-Identifier: MIT
|
||||
|
||||
package repo
|
||||
|
||||
import (
|
||||
user_model "code.gitea.io/gitea/models/user"
|
||||
"code.gitea.io/gitea/modules/log"
|
||||
"code.gitea.io/gitea/modules/setting"
|
||||
"code.gitea.io/gitea/modules/util"
|
||||
"code.gitea.io/gitea/services/context"
|
||||
files_service "code.gitea.io/gitea/services/repository/files"
|
||||
)
|
||||
|
||||
func WebGitOperationCommonData(ctx *context.Context) {
|
||||
// TODO: more places like "wiki page" and "merging a pull request or creating an auto merge merging task"
|
||||
emails, err := user_model.GetActivatedEmailAddresses(ctx, ctx.Doer.ID)
|
||||
if err != nil {
|
||||
log.Error("WebGitOperationCommonData: GetActivatedEmailAddresses: %v", err)
|
||||
}
|
||||
if ctx.Doer.KeepEmailPrivate {
|
||||
emails = append([]string{ctx.Doer.GetPlaceholderEmail()}, emails...)
|
||||
}
|
||||
ctx.Data["CommitCandidateEmails"] = emails
|
||||
ctx.Data["CommitDefaultEmail"] = ctx.Doer.GetEmail()
|
||||
}
|
||||
|
||||
func WebGitOperationGetCommitChosenEmailIdentity(ctx *context.Context, email string) (_ *files_service.IdentityOptions, valid bool) {
|
||||
if ctx.Data["CommitCandidateEmails"] == nil {
|
||||
setting.PanicInDevOrTesting("no CommitCandidateEmails in context data")
|
||||
}
|
||||
emails, _ := ctx.Data["CommitCandidateEmails"].([]string)
|
||||
if email == "" {
|
||||
return nil, true
|
||||
}
|
||||
if util.SliceContainsString(emails, email, true) {
|
||||
return &files_service.IdentityOptions{GitUserEmail: email}, true
|
||||
}
|
||||
return nil, false
|
||||
}
|
||||
@ -1 +0,0 @@
|
||||
ref: refs/heads/main
|
||||
@ -1,8 +0,0 @@
|
||||
[core]
|
||||
repositoryformatversion = 0
|
||||
filemode = true
|
||||
bare = true
|
||||
ignorecase = true
|
||||
precomposeunicode = true
|
||||
[remote "origin"]
|
||||
url = https://try.gitea.io/me-heer/test_commit_revert.git
|
||||
Binary file not shown.
Binary file not shown.
@ -1,3 +0,0 @@
|
||||
# pack-refs with: peeled fully-peeled sorted
|
||||
46aa6ab2c881ae90e15d9ccfc947d1625c892ce5 refs/heads/develop
|
||||
deebcbc752e540bab4ce3ee713d3fc8fdc35b2f7 refs/heads/main
|
||||
@ -1 +0,0 @@
|
||||
deebcbc752e540bab4ce3ee713d3fc8fdc35b2f7
|
||||
@ -1,37 +0,0 @@
|
||||
// Copyright 2024 The Gitea Authors. All rights reserved.
|
||||
// SPDX-License-Identifier: MIT
|
||||
|
||||
package integration
|
||||
|
||||
import (
|
||||
"net/http"
|
||||
"testing"
|
||||
|
||||
"code.gitea.io/gitea/tests"
|
||||
|
||||
"github.com/stretchr/testify/assert"
|
||||
)
|
||||
|
||||
func TestRepoMergeCommitRevert(t *testing.T) {
|
||||
defer tests.PrepareTestEnv(t)()
|
||||
session := loginUser(t, "user2")
|
||||
|
||||
req := NewRequest(t, "GET", "/user2/test_commit_revert/_cherrypick/deebcbc752e540bab4ce3ee713d3fc8fdc35b2f7/main?ref=main&refType=branch&cherry-pick-type=revert")
|
||||
resp := session.MakeRequest(t, req, http.StatusOK)
|
||||
|
||||
htmlDoc := NewHTMLParser(t, resp.Body)
|
||||
req = NewRequestWithValues(t, "POST", "/user2/test_commit_revert/_cherrypick/deebcbc752e540bab4ce3ee713d3fc8fdc35b2f7/main", map[string]string{
|
||||
"_csrf": htmlDoc.GetCSRF(),
|
||||
"last_commit": "deebcbc752e540bab4ce3ee713d3fc8fdc35b2f7",
|
||||
"page_has_posted": "true",
|
||||
"revert": "true",
|
||||
"commit_summary": "reverting test commit",
|
||||
"commit_message": "test message",
|
||||
"commit_choice": "direct",
|
||||
"new_branch_name": "test-revert-branch-1",
|
||||
})
|
||||
resp = session.MakeRequest(t, req, http.StatusSeeOther)
|
||||
|
||||
// A successful revert redirects to the main branch
|
||||
assert.EqualValues(t, "/user2/test_commit_revert/src/branch/main", resp.Header().Get("Location"))
|
||||
}
|
||||
Loading…
Reference in New Issue