mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 11:28:24 +00:00 
			
		
		
		
	Use gitrepo.Repository instead of wikipath (#35398)
Now the wikipath will not be referenced directly.
This commit is contained in:
		| @@ -17,7 +17,6 @@ import ( | ||||
| 	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/git/gitcmd" | ||||
| 	"code.gitea.io/gitea/modules/gitrepo" | ||||
| 	"code.gitea.io/gitea/modules/log" | ||||
| 	"code.gitea.io/gitea/modules/process" | ||||
| @@ -109,54 +108,9 @@ func IsErrWontSign(err error) bool { | ||||
| 	return ok | ||||
| } | ||||
|  | ||||
| // SigningKey returns the KeyID and git Signature for the repo | ||||
| func SigningKey(ctx context.Context, repoPath string) (*git.SigningKey, *git.Signature) { | ||||
| 	if setting.Repository.Signing.SigningKey == "none" { | ||||
| 		return nil, nil | ||||
| 	} | ||||
|  | ||||
| 	if setting.Repository.Signing.SigningKey == "default" || setting.Repository.Signing.SigningKey == "" { | ||||
| 		// Can ignore the error here as it means that commit.gpgsign is not set | ||||
| 		value, _, _ := gitcmd.NewCommand("config", "--get", "commit.gpgsign").WithDir(repoPath).RunStdString(ctx) | ||||
| 		sign, valid := git.ParseBool(strings.TrimSpace(value)) | ||||
| 		if !sign || !valid { | ||||
| 			return nil, nil | ||||
| 		} | ||||
|  | ||||
| 		format, _, _ := gitcmd.NewCommand("config", "--default", git.SigningKeyFormatOpenPGP, "--get", "gpg.format").WithDir(repoPath).RunStdString(ctx) | ||||
| 		signingKey, _, _ := gitcmd.NewCommand("config", "--get", "user.signingkey").WithDir(repoPath).RunStdString(ctx) | ||||
| 		signingName, _, _ := gitcmd.NewCommand("config", "--get", "user.name").WithDir(repoPath).RunStdString(ctx) | ||||
| 		signingEmail, _, _ := gitcmd.NewCommand("config", "--get", "user.email").WithDir(repoPath).RunStdString(ctx) | ||||
|  | ||||
| 		if strings.TrimSpace(signingKey) == "" { | ||||
| 			return nil, nil | ||||
| 		} | ||||
|  | ||||
| 		return &git.SigningKey{ | ||||
| 				KeyID:  strings.TrimSpace(signingKey), | ||||
| 				Format: strings.TrimSpace(format), | ||||
| 			}, &git.Signature{ | ||||
| 				Name:  strings.TrimSpace(signingName), | ||||
| 				Email: strings.TrimSpace(signingEmail), | ||||
| 			} | ||||
| 	} | ||||
|  | ||||
| 	if setting.Repository.Signing.SigningKey == "" { | ||||
| 		return nil, nil | ||||
| 	} | ||||
|  | ||||
| 	return &git.SigningKey{ | ||||
| 			KeyID:  setting.Repository.Signing.SigningKey, | ||||
| 			Format: setting.Repository.Signing.SigningFormat, | ||||
| 		}, &git.Signature{ | ||||
| 			Name:  setting.Repository.Signing.SigningName, | ||||
| 			Email: setting.Repository.Signing.SigningEmail, | ||||
| 		} | ||||
| } | ||||
|  | ||||
| // PublicSigningKey gets the public signing key within a provided repository directory | ||||
| func PublicSigningKey(ctx context.Context, repoPath string) (content, format string, err error) { | ||||
| 	signingKey, _ := SigningKey(ctx, repoPath) | ||||
| 	signingKey, _ := git.GetSigningKey(ctx, repoPath) | ||||
| 	if signingKey == nil { | ||||
| 		return "", "", nil | ||||
| 	} | ||||
| @@ -181,7 +135,7 @@ func PublicSigningKey(ctx context.Context, repoPath string) (content, format str | ||||
| // SignInitialCommit determines if we should sign the initial commit to this repository | ||||
| func SignInitialCommit(ctx context.Context, repoPath string, u *user_model.User) (bool, *git.SigningKey, *git.Signature, error) { | ||||
| 	rules := signingModeFromStrings(setting.Repository.Signing.InitialCommit) | ||||
| 	signingKey, sig := SigningKey(ctx, repoPath) | ||||
| 	signingKey, sig := git.GetSigningKey(ctx, repoPath) | ||||
| 	if signingKey == nil { | ||||
| 		return false, nil, nil, &ErrWontSign{noKey} | ||||
| 	} | ||||
| @@ -216,9 +170,8 @@ Loop: | ||||
|  | ||||
| // SignWikiCommit determines if we should sign the commits to this repository wiki | ||||
| func SignWikiCommit(ctx context.Context, repo *repo_model.Repository, u *user_model.User) (bool, *git.SigningKey, *git.Signature, error) { | ||||
| 	repoWikiPath := repo.WikiPath() | ||||
| 	rules := signingModeFromStrings(setting.Repository.Signing.Wiki) | ||||
| 	signingKey, sig := SigningKey(ctx, repoWikiPath) | ||||
| 	signingKey, sig := gitrepo.GetSigningKey(ctx, repo.WikiStorageRepo()) | ||||
| 	if signingKey == nil { | ||||
| 		return false, nil, nil, &ErrWontSign{noKey} | ||||
| 	} | ||||
| @@ -271,7 +224,7 @@ Loop: | ||||
| // SignCRUDAction determines if we should sign a CRUD commit to this repository | ||||
| func SignCRUDAction(ctx context.Context, repoPath string, u *user_model.User, tmpBasePath, parentCommit string) (bool, *git.SigningKey, *git.Signature, error) { | ||||
| 	rules := signingModeFromStrings(setting.Repository.Signing.CRUDActions) | ||||
| 	signingKey, sig := SigningKey(ctx, repoPath) | ||||
| 	signingKey, sig := git.GetSigningKey(ctx, repoPath) | ||||
| 	if signingKey == nil { | ||||
| 		return false, nil, nil, &ErrWontSign{noKey} | ||||
| 	} | ||||
| @@ -335,7 +288,7 @@ func SignMerge(ctx context.Context, pr *issues_model.PullRequest, u *user_model. | ||||
| 	} | ||||
| 	repo := pr.BaseRepo | ||||
|  | ||||
| 	signingKey, signer := SigningKey(ctx, repo.RepoPath()) | ||||
| 	signingKey, signer := gitrepo.GetSigningKey(ctx, repo) | ||||
| 	if signingKey == nil { | ||||
| 		return false, nil, nil, &ErrWontSign{noKey} | ||||
| 	} | ||||
|   | ||||
		Reference in New Issue
	
	Block a user