aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
author6543 <6543@obermui.de>2020-01-02 00:36:00 +0100
committerLauris BH <lauris@nix.lv>2020-01-02 01:36:00 +0200
commitcb3fe4cbf18caa93b2006b801210c02ab4eaf007 (patch)
tree7b62c447ea63f35a45dce26d559d36a98723db41
parentc63a80138a29aa9a8164d3eddd1eddaaf414ddc6 (diff)
downloadgitea-cb3fe4cbf18caa93b2006b801210c02ab4eaf007.tar.gz
gitea-cb3fe4cbf18caa93b2006b801210c02ab4eaf007.zip
[Backport] Fix bug when migrate from API (#8631) (#9563)
* Fix bug when migrate from API (#8631) * fix bug when migrate from API * fix test * fix test * improve * fix error message * Update routers/api/v1/repo/repo.go * remove unrelated Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
-rw-r--r--integrations/api_repo_test.go2
-rw-r--r--models/repo.go6
-rw-r--r--modules/task/migrate.go2
-rw-r--r--routers/api/v1/repo/repo.go31
4 files changed, 31 insertions, 10 deletions
diff --git a/integrations/api_repo_test.go b/integrations/api_repo_test.go
index 60fe4a3649..a2683d4af4 100644
--- a/integrations/api_repo_test.go
+++ b/integrations/api_repo_test.go
@@ -334,7 +334,7 @@ func testAPIRepoMigrateConflict(t *testing.T, u *url.URL) {
resp := httpContext.Session.MakeRequest(t, req, http.StatusConflict)
respJSON := map[string]string{}
DecodeJSON(t, resp, &respJSON)
- assert.Equal(t, respJSON["message"], "The repository with the same name already exists.")
+ assert.Equal(t, "The repository with the same name already exists.", respJSON["message"])
})
}
diff --git a/models/repo.go b/models/repo.go
index 582df7613a..dc0b42ee31 100644
--- a/models/repo.go
+++ b/models/repo.go
@@ -2811,3 +2811,9 @@ func (repo *Repository) GetOriginalURLHostname() string {
return u.Host
}
+
+// UpdateRepositoryCols updates repository's columns
+func UpdateRepositoryCols(repo *Repository, cols ...string) error {
+ _, err := x.ID(repo.ID).Cols(cols...).Update(repo)
+ return err
+}
diff --git a/modules/task/migrate.go b/modules/task/migrate.go
index 5d15a506d7..247403d7be 100644
--- a/modules/task/migrate.go
+++ b/modules/task/migrate.go
@@ -97,8 +97,6 @@ func runMigrateTask(t *models.Task) (err error) {
opts.MigrateToRepoID = t.RepoID
repo, err := migrations.MigrateRepository(t.Doer, t.Owner.Name, *opts)
if err == nil {
- notification.NotifyMigrateRepository(t.Doer, t.Owner, repo)
-
log.Trace("Repository migrated [%d]: %s/%s", repo.ID, t.Owner.Name, repo.Name)
return nil
}
diff --git a/routers/api/v1/repo/repo.go b/routers/api/v1/repo/repo.go
index 8edb53a61f..7eb397b68c 100644
--- a/routers/api/v1/repo/repo.go
+++ b/routers/api/v1/repo/repo.go
@@ -433,7 +433,21 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
opts.Releases = false
}
- var repo *models.Repository
+ repo, err := models.CreateRepository(ctx.User, ctxUser, models.CreateRepoOptions{
+ Name: opts.RepoName,
+ Description: opts.Description,
+ OriginalURL: opts.CloneAddr,
+ IsPrivate: opts.Private,
+ IsMirror: opts.Mirror,
+ Status: models.RepositoryBeingMigrated,
+ })
+ if err != nil {
+ handleMigrateError(ctx, ctxUser, remoteAddr, err)
+ return
+ }
+
+ opts.MigrateToRepoID = repo.ID
+
defer func() {
if e := recover(); e != nil {
var buf bytes.Buffer
@@ -443,7 +457,7 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
if err == nil {
repo.Status = models.RepositoryReady
- if err := models.UpdateRepositoryStatus(repo.ID, repo.Status); err == nil {
+ if err := models.UpdateRepositoryCols(repo, "status"); err == nil {
notification.NotifyMigrateRepository(ctx.User, ctxUser, repo)
return
}
@@ -456,13 +470,16 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
}
}()
- repo, err = migrations.MigrateRepository(ctx.User, ctxUser.Name, opts)
- if err == nil {
- log.Trace("Repository migrated: %s/%s", ctxUser.Name, form.RepoName)
- ctx.JSON(201, repo.APIFormat(models.AccessModeAdmin))
+ if _, err = migrations.MigrateRepository(ctx.User, ctxUser.Name, opts); err != nil {
+ handleMigrateError(ctx, ctxUser, remoteAddr, err)
return
}
+ log.Trace("Repository migrated: %s/%s", ctxUser.Name, form.RepoName)
+ ctx.JSON(201, repo.APIFormat(models.AccessModeAdmin))
+}
+
+func handleMigrateError(ctx *context.APIContext, repoOwner *models.User, remoteAddr string, err error) {
switch {
case models.IsErrRepoAlreadyExist(err):
ctx.Error(409, "", "The repository with the same name already exists.")
@@ -471,7 +488,7 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
case migrations.IsTwoFactorAuthError(err):
ctx.Error(422, "", "Remote visit required two factors authentication.")
case models.IsErrReachLimitOfRepo(err):
- ctx.Error(422, "", fmt.Sprintf("You have already reached your limit of %d repositories.", ctxUser.MaxCreationLimit()))
+ ctx.Error(422, "", fmt.Sprintf("You have already reached your limit of %d repositories.", repoOwner.MaxCreationLimit()))
case models.IsErrNameReserved(err):
ctx.Error(422, "", fmt.Sprintf("The username '%s' is reserved.", err.(models.ErrNameReserved).Name))
case models.IsErrNamePatternNotAllowed(err):