aboutsummaryrefslogtreecommitdiffstats
path: root/modules/git/remote.go
diff options
context:
space:
mode:
Diffstat (limited to 'modules/git/remote.go')
-rw-r--r--modules/git/remote.go20
1 files changed, 15 insertions, 5 deletions
diff --git a/modules/git/remote.go b/modules/git/remote.go
index b2a2e6d7ab..cbb4ac6126 100644
--- a/modules/git/remote.go
+++ b/modules/git/remote.go
@@ -6,11 +6,12 @@ package git
import (
"context"
- "net/url"
+
+ giturl "code.gitea.io/gitea/modules/git/url"
)
-// GetRemoteAddress returns the url of a specific remote of the repository.
-func GetRemoteAddress(ctx context.Context, repoPath, remoteName string) (*url.URL, error) {
+// GetRemoteAddress returns remote url of git repository in the repoPath with special remote name
+func GetRemoteAddress(ctx context.Context, repoPath, remoteName string) (string, error) {
var cmd *Command
if CheckGitVersionAtLeast("2.7") == nil {
cmd = NewCommand(ctx, "remote", "get-url", remoteName)
@@ -20,11 +21,20 @@ func GetRemoteAddress(ctx context.Context, repoPath, remoteName string) (*url.UR
result, _, err := cmd.RunStdString(&RunOpts{Dir: repoPath})
if err != nil {
- return nil, err
+ return "", err
}
if len(result) > 0 {
result = result[:len(result)-1]
}
- return url.Parse(result)
+ 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)
}