2021-06-14 19:20:43 +02:00
|
|
|
// Copyright 2021 The Gitea Authors. All rights reserved.
|
2022-11-27 13:20:29 -05:00
|
|
|
// SPDX-License-Identifier: MIT
|
2021-06-14 19:20:43 +02:00
|
|
|
|
|
|
|
package git
|
|
|
|
|
2021-11-30 20:06:32 +00:00
|
|
|
import (
|
|
|
|
"context"
|
2025-01-08 13:08:44 +08:00
|
|
|
"strings"
|
2022-06-11 21:50:14 +08:00
|
|
|
|
|
|
|
giturl "code.gitea.io/gitea/modules/git/url"
|
2021-11-30 20:06:32 +00:00
|
|
|
)
|
2021-06-14 19:20:43 +02:00
|
|
|
|
2022-06-11 21:50:14 +08:00
|
|
|
// GetRemoteAddress returns remote url of git repository in the repoPath with special remote name
|
|
|
|
func GetRemoteAddress(ctx context.Context, repoPath, remoteName string) (string, error) {
|
2021-06-14 19:20:43 +02:00
|
|
|
var cmd *Command
|
2024-05-07 00:34:16 +08:00
|
|
|
if DefaultFeatures().CheckVersionAtLeast("2.7") {
|
2022-10-23 22:44:45 +08:00
|
|
|
cmd = NewCommand(ctx, "remote", "get-url").AddDynamicArguments(remoteName)
|
2021-06-14 19:20:43 +02:00
|
|
|
} else {
|
2022-10-23 22:44:45 +08:00
|
|
|
cmd = NewCommand(ctx, "config", "--get").AddDynamicArguments("remote." + remoteName + ".url")
|
2021-06-14 19:20:43 +02:00
|
|
|
}
|
|
|
|
|
2022-04-01 10:55:30 +08:00
|
|
|
result, _, err := cmd.RunStdString(&RunOpts{Dir: repoPath})
|
2021-06-14 19:20:43 +02:00
|
|
|
if err != nil {
|
2022-06-11 21:50:14 +08:00
|
|
|
return "", err
|
2021-06-14 19:20:43 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(result) > 0 {
|
|
|
|
result = result[:len(result)-1]
|
|
|
|
}
|
2022-06-11 21:50:14 +08:00
|
|
|
return result, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetRemoteURL returns the url of a specific remote of the repository.
|
|
|
|
func GetRemoteURL(ctx context.Context, repoPath, remoteName string) (*giturl.GitURL, error) {
|
|
|
|
addr, err := GetRemoteAddress(ctx, repoPath, remoteName)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return giturl.Parse(addr)
|
2021-06-14 19:20:43 +02:00
|
|
|
}
|
2025-01-08 13:08:44 +08:00
|
|
|
|
|
|
|
// IsRemoteNotExistError checks the prefix of the error message to see whether a remote does not exist.
|
|
|
|
func IsRemoteNotExistError(err error) bool {
|
|
|
|
// see: https://github.com/go-gitea/gitea/issues/32889#issuecomment-2571848216
|
|
|
|
// Should not add space in the end, sometimes git will add a `:`
|
|
|
|
prefix1 := "exit status 128 - fatal: No such remote" // git < 2.30
|
|
|
|
prefix2 := "exit status 2 - error: No such remote" // git >= 2.30
|
|
|
|
return strings.HasPrefix(err.Error(), prefix1) || strings.HasPrefix(err.Error(), prefix2)
|
|
|
|
}
|