summaryrefslogtreecommitdiffstats
path: root/routers/repo/setting.go
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-08-30 16:18:33 -0700
committerUnknwon <u@gogs.io>2016-08-30 16:18:33 -0700
commit8516dfcb6cb008f286ec84bed4243928acb94844 (patch)
tree9b3882438a04a3e659e49e35364a5643a71c9258 /routers/repo/setting.go
parentc1ecb6c60a1acacf530e226b8043ca93d2fe4a07 (diff)
downloadgitea-8516dfcb6cb008f286ec84bed4243928acb94844.tar.gz
gitea-8516dfcb6cb008f286ec84bed4243928acb94844.zip
#2018 able to sync now for mirrors
- Refactor code to use sync.UniqueQueue - Closes #3509
Diffstat (limited to 'routers/repo/setting.go')
-rw-r--r--routers/repo/setting.go51
1 files changed, 31 insertions, 20 deletions
diff --git a/routers/repo/setting.go b/routers/repo/setting.go
index 33ed5b8aae..80b44ad220 100644
--- a/routers/repo/setting.go
+++ b/routers/repo/setting.go
@@ -104,34 +104,42 @@ func SettingsPost(ctx *context.Context, form auth.RepoSettingForm) {
}
}
- if repo.IsMirror {
- if isNameChanged {
- var err error
- ctx.Repo.Mirror, err = models.GetMirror(repo.ID)
- if err != nil {
- ctx.Handle(500, "RefreshRepositoryMirror", err)
- return
- }
- }
+ ctx.Flash.Success(ctx.Tr("repo.settings.update_settings_success"))
+ ctx.Redirect(repo.Link() + "/settings")
- if form.Interval > 0 {
- ctx.Repo.Mirror.EnablePrune = form.EnablePrune
- ctx.Repo.Mirror.Interval = form.Interval
- ctx.Repo.Mirror.NextUpdate = time.Now().Add(time.Duration(form.Interval) * time.Hour)
- if err := models.UpdateMirror(ctx.Repo.Mirror); err != nil {
- ctx.Handle(500, "UpdateMirror", err)
- return
- }
- }
- if err := ctx.Repo.Mirror.SaveAddress(form.MirrorAddress); err != nil {
- ctx.Handle(500, "SaveAddress", err)
+ case "mirror":
+ if !repo.IsMirror {
+ ctx.Handle(404, "", nil)
+ return
+ }
+
+ if form.Interval > 0 {
+ ctx.Repo.Mirror.EnablePrune = form.EnablePrune
+ ctx.Repo.Mirror.Interval = form.Interval
+ ctx.Repo.Mirror.NextUpdate = time.Now().Add(time.Duration(form.Interval) * time.Hour)
+ if err := models.UpdateMirror(ctx.Repo.Mirror); err != nil {
+ ctx.Handle(500, "UpdateMirror", err)
return
}
}
+ if err := ctx.Repo.Mirror.SaveAddress(form.MirrorAddress); err != nil {
+ ctx.Handle(500, "SaveAddress", err)
+ return
+ }
ctx.Flash.Success(ctx.Tr("repo.settings.update_settings_success"))
ctx.Redirect(repo.Link() + "/settings")
+ case "mirror-sync":
+ if !repo.IsMirror {
+ ctx.Handle(404, "", nil)
+ return
+ }
+
+ go models.MirrorQueue.Add(repo.ID)
+ ctx.Flash.Info(ctx.Tr("repo.settings.mirror_sync_in_progress"))
+ ctx.Redirect(repo.Link() + "/settings")
+
case "advanced":
repo.EnableWiki = form.EnableWiki
repo.EnableExternalWiki = form.EnableExternalWiki
@@ -278,6 +286,9 @@ func SettingsPost(ctx *context.Context, form auth.RepoSettingForm) {
ctx.Flash.Success(ctx.Tr("repo.settings.wiki_deletion_success"))
ctx.Redirect(ctx.Repo.RepoLink + "/settings")
+
+ default:
+ ctx.Handle(404, "", nil)
}
}