aboutsummaryrefslogtreecommitdiffstats
path: root/modules/git
diff options
context:
space:
mode:
authorKN4CK3R <admin@oldschoolhack.me>2021-06-14 19:20:43 +0200
committerGitHub <noreply@github.com>2021-06-14 19:20:43 +0200
commit440039c0cce18622b12da5677bf6585caed6070a (patch)
tree8f8532a2d40983b35b3fdb5460b47218b26bbd89 /modules/git
parent5d113bdd1905c73fb8071f420ae2d248202971f9 (diff)
downloadgitea-440039c0cce18622b12da5677bf6585caed6070a.tar.gz
gitea-440039c0cce18622b12da5677bf6585caed6070a.zip
Add push to remote mirror repository (#15157)
* Added push mirror model. * Integrated push mirror into queue. * Moved methods into own file. * Added basic implementation. * Mirror wiki too. * Removed duplicated method. * Get url for different remotes. * Added migration. * Unified remote url access. * Add/Remove push mirror remotes. * Prevent hangs with missing credentials. * Moved code between files. * Changed sanitizer interface. * Added push mirror backend methods. * Only update the mirror remote. * Limit refs on push. * Added UI part. * Added missing table. * Delete mirror if repository gets removed. * Changed signature. Handle object errors. * Added upload method. * Added "upload" unit tests. * Added transfer adapter unit tests. * Send correct headers. * Added pushing of LFS objects. * Added more logging. * Simpler body handling. * Process files in batches to reduce HTTP calls. * Added created timestamp. * Fixed invalid column name. * Changed name to prevent xorm auto setting. * Remove table header im empty. * Strip exit code from error message. * Added docs page about mirroring. * Fixed date. * Fixed merge errors. * Moved test to integrations. * Added push mirror test. * Added test.
Diffstat (limited to 'modules/git')
-rw-r--r--modules/git/remote.go31
-rw-r--r--modules/git/repo.go24
2 files changed, 49 insertions, 6 deletions
diff --git a/modules/git/remote.go b/modules/git/remote.go
new file mode 100644
index 0000000000..7ba2b35a5e
--- /dev/null
+++ b/modules/git/remote.go
@@ -0,0 +1,31 @@
+// Copyright 2021 The Gitea Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package git
+
+import "net/url"
+
+// GetRemoteAddress returns the url of a specific remote of the repository.
+func GetRemoteAddress(repoPath, remoteName string) (*url.URL, error) {
+ err := LoadGitVersion()
+ if err != nil {
+ return nil, err
+ }
+ var cmd *Command
+ if CheckGitVersionAtLeast("2.7") == nil {
+ cmd = NewCommand("remote", "get-url", remoteName)
+ } else {
+ cmd = NewCommand("config", "--get", "remote."+remoteName+".url")
+ }
+
+ result, err := cmd.RunInDir(repoPath)
+ if err != nil {
+ return nil, err
+ }
+
+ if len(result) > 0 {
+ result = result[:len(result)-1]
+ }
+ return url.Parse(result)
+}
diff --git a/modules/git/repo.go b/modules/git/repo.go
index 515899ab04..e06cd43935 100644
--- a/modules/git/repo.go
+++ b/modules/git/repo.go
@@ -182,10 +182,12 @@ func Pull(repoPath string, opts PullRemoteOptions) error {
// PushOptions options when push to remote
type PushOptions struct {
- Remote string
- Branch string
- Force bool
- Env []string
+ Remote string
+ Branch string
+ Force bool
+ Mirror bool
+ Env []string
+ Timeout time.Duration
}
// Push pushs local commits to given remote branch.
@@ -194,10 +196,20 @@ func Push(repoPath string, opts PushOptions) error {
if opts.Force {
cmd.AddArguments("-f")
}
- cmd.AddArguments("--", opts.Remote, opts.Branch)
+ if opts.Mirror {
+ cmd.AddArguments("--mirror")
+ }
+ cmd.AddArguments("--", opts.Remote)
+ if len(opts.Branch) > 0 {
+ cmd.AddArguments(opts.Branch)
+ }
var outbuf, errbuf strings.Builder
- err := cmd.RunInDirTimeoutEnvPipeline(opts.Env, -1, repoPath, &outbuf, &errbuf)
+ if opts.Timeout == 0 {
+ opts.Timeout = -1
+ }
+
+ err := cmd.RunInDirTimeoutEnvPipeline(opts.Env, opts.Timeout, repoPath, &outbuf, &errbuf)
if err != nil {
if strings.Contains(errbuf.String(), "non-fast-forward") {
return &ErrPushOutOfDate{