mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-25 07:37:48 -04:00 
			
		
		
		
	Refactor Git command functions to use WithXXX methods instead of exposing RunOpts. This change simplifies reuse across gitrepo and improves consistency, encapsulation, and maintainability of command options. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2015 The Gogs Authors. All rights reserved.
 | |
| // Copyright 2017 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package git
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"os"
 | |
| 	"strings"
 | |
| 
 | |
| 	"code.gitea.io/gitea/modules/git/gitcmd"
 | |
| 	"code.gitea.io/gitea/modules/process"
 | |
| )
 | |
| 
 | |
| // LoadPublicKeyContent will load the key from gpg
 | |
| func (gpgSettings *GPGSettings) LoadPublicKeyContent() error {
 | |
| 	if gpgSettings.Format == SigningKeyFormatSSH {
 | |
| 		content, err := os.ReadFile(gpgSettings.KeyID)
 | |
| 		if err != nil {
 | |
| 			return fmt.Errorf("unable to read SSH public key file: %s, %w", gpgSettings.KeyID, err)
 | |
| 		}
 | |
| 		gpgSettings.PublicKeyContent = string(content)
 | |
| 		return nil
 | |
| 	}
 | |
| 	content, stderr, err := process.GetManager().Exec(
 | |
| 		"gpg -a --export",
 | |
| 		"gpg", "-a", "--export", gpgSettings.KeyID)
 | |
| 	if err != nil {
 | |
| 		return fmt.Errorf("unable to get default signing key: %s, %s, %w", gpgSettings.KeyID, stderr, err)
 | |
| 	}
 | |
| 	gpgSettings.PublicKeyContent = content
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| // GetDefaultPublicGPGKey will return and cache the default public GPG settings for this repository
 | |
| func (repo *Repository) GetDefaultPublicGPGKey(forceUpdate bool) (*GPGSettings, error) {
 | |
| 	if repo.gpgSettings != nil && !forceUpdate {
 | |
| 		return repo.gpgSettings, nil
 | |
| 	}
 | |
| 
 | |
| 	gpgSettings := &GPGSettings{
 | |
| 		Sign: true,
 | |
| 	}
 | |
| 
 | |
| 	value, _, _ := gitcmd.NewCommand("config", "--get", "commit.gpgsign").WithDir(repo.Path).RunStdString(repo.Ctx)
 | |
| 	sign, valid := ParseBool(strings.TrimSpace(value))
 | |
| 	if !sign || !valid {
 | |
| 		gpgSettings.Sign = false
 | |
| 		repo.gpgSettings = gpgSettings
 | |
| 		return gpgSettings, nil
 | |
| 	}
 | |
| 
 | |
| 	signingKey, _, _ := gitcmd.NewCommand("config", "--get", "user.signingkey").WithDir(repo.Path).RunStdString(repo.Ctx)
 | |
| 	gpgSettings.KeyID = strings.TrimSpace(signingKey)
 | |
| 
 | |
| 	format, _, _ := gitcmd.NewCommand("config", "--default", SigningKeyFormatOpenPGP, "--get", "gpg.format").WithDir(repo.Path).RunStdString(repo.Ctx)
 | |
| 	gpgSettings.Format = strings.TrimSpace(format)
 | |
| 
 | |
| 	defaultEmail, _, _ := gitcmd.NewCommand("config", "--get", "user.email").WithDir(repo.Path).RunStdString(repo.Ctx)
 | |
| 	gpgSettings.Email = strings.TrimSpace(defaultEmail)
 | |
| 
 | |
| 	defaultName, _, _ := gitcmd.NewCommand("config", "--get", "user.name").WithDir(repo.Path).RunStdString(repo.Ctx)
 | |
| 	gpgSettings.Name = strings.TrimSpace(defaultName)
 | |
| 
 | |
| 	if err := gpgSettings.LoadPublicKeyContent(); err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	repo.gpgSettings = gpgSettings
 | |
| 	return repo.gpgSettings, nil
 | |
| }
 |