mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 03:18:24 +00:00 
			
		
		
		
	* Signed SSH commits can look in the UI like on GitHub, just like gpg keys today in Gitea * SSH format can be added in gitea config * SSH Signing worked before with DEFAULT_TRUST_MODEL=committer `TRUSTED_SSH_KEYS` can be a list of additional ssh public key contents to trust for every user of this instance Closes #34329 Related #31392 --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: techknowlogick <techknowlogick@gitea.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			84 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2024 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package repository
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"time"
 | |
| 
 | |
| 	repo_model "code.gitea.io/gitea/models/repo"
 | |
| 	user_model "code.gitea.io/gitea/models/user"
 | |
| 	"code.gitea.io/gitea/modules/git"
 | |
| 	"code.gitea.io/gitea/modules/log"
 | |
| 	repo_module "code.gitea.io/gitea/modules/repository"
 | |
| 	"code.gitea.io/gitea/modules/setting"
 | |
| 	asymkey_service "code.gitea.io/gitea/services/asymkey"
 | |
| )
 | |
| 
 | |
| // initRepoCommit temporarily changes with work directory.
 | |
| func initRepoCommit(ctx context.Context, tmpPath string, repo *repo_model.Repository, u *user_model.User, defaultBranch string) (err error) {
 | |
| 	commitTimeStr := time.Now().Format(time.RFC3339)
 | |
| 
 | |
| 	sig := u.NewGitSig()
 | |
| 	// Because this may call hooks we should pass in the environment
 | |
| 	env := append(os.Environ(),
 | |
| 		"GIT_AUTHOR_NAME="+sig.Name,
 | |
| 		"GIT_AUTHOR_EMAIL="+sig.Email,
 | |
| 		"GIT_AUTHOR_DATE="+commitTimeStr,
 | |
| 		"GIT_COMMITTER_DATE="+commitTimeStr,
 | |
| 	)
 | |
| 	committerName := sig.Name
 | |
| 	committerEmail := sig.Email
 | |
| 
 | |
| 	if stdout, _, err := git.NewCommand("add", "--all").
 | |
| 		RunStdString(ctx, &git.RunOpts{Dir: tmpPath}); err != nil {
 | |
| 		log.Error("git add --all failed: Stdout: %s\nError: %v", stdout, err)
 | |
| 		return fmt.Errorf("git add --all: %w", err)
 | |
| 	}
 | |
| 
 | |
| 	cmd := git.NewCommand("commit", "--message=Initial commit").
 | |
| 		AddOptionFormat("--author='%s <%s>'", sig.Name, sig.Email)
 | |
| 
 | |
| 	sign, key, signer, _ := asymkey_service.SignInitialCommit(ctx, tmpPath, u)
 | |
| 	if sign {
 | |
| 		if key.Format != "" {
 | |
| 			cmd.AddConfig("gpg.format", key.Format)
 | |
| 		}
 | |
| 		cmd.AddOptionFormat("-S%s", key.KeyID)
 | |
| 
 | |
| 		if repo.GetTrustModel() == repo_model.CommitterTrustModel || repo.GetTrustModel() == repo_model.CollaboratorCommitterTrustModel {
 | |
| 			// need to set the committer to the KeyID owner
 | |
| 			committerName = signer.Name
 | |
| 			committerEmail = signer.Email
 | |
| 		}
 | |
| 	} else {
 | |
| 		cmd.AddArguments("--no-gpg-sign")
 | |
| 	}
 | |
| 
 | |
| 	env = append(env,
 | |
| 		"GIT_COMMITTER_NAME="+committerName,
 | |
| 		"GIT_COMMITTER_EMAIL="+committerEmail,
 | |
| 	)
 | |
| 
 | |
| 	if stdout, _, err := cmd.
 | |
| 		RunStdString(ctx, &git.RunOpts{Dir: tmpPath, Env: env}); err != nil {
 | |
| 		log.Error("Failed to commit: %v: Stdout: %s\nError: %v", cmd.LogString(), stdout, err)
 | |
| 		return fmt.Errorf("git commit: %w", err)
 | |
| 	}
 | |
| 
 | |
| 	if len(defaultBranch) == 0 {
 | |
| 		defaultBranch = setting.Repository.DefaultBranch
 | |
| 	}
 | |
| 
 | |
| 	if stdout, _, err := git.NewCommand("push", "origin").AddDynamicArguments("HEAD:"+defaultBranch).
 | |
| 		RunStdString(ctx, &git.RunOpts{Dir: tmpPath, Env: repo_module.InternalPushingEnvironment(u, repo)}); err != nil {
 | |
| 		log.Error("Failed to push back to HEAD: Stdout: %s\nError: %v", stdout, err)
 | |
| 		return fmt.Errorf("git push: %w", err)
 | |
| 	}
 | |
| 
 | |
| 	return nil
 | |
| }
 |