Skip to content

Commit cb3fe4c

Browse files
6543lunny
authored andcommitted
[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 <[email protected]>
1 parent c63a801 commit cb3fe4c

File tree

4 files changed

+31
-10
lines changed

4 files changed

+31
-10
lines changed

integrations/api_repo_test.go

+1-1
Original file line numberDiff line numberDiff line change
@@ -334,7 +334,7 @@ func testAPIRepoMigrateConflict(t *testing.T, u *url.URL) {
334334
resp := httpContext.Session.MakeRequest(t, req, http.StatusConflict)
335335
respJSON := map[string]string{}
336336
DecodeJSON(t, resp, &respJSON)
337-
assert.Equal(t, respJSON["message"], "The repository with the same name already exists.")
337+
assert.Equal(t, "The repository with the same name already exists.", respJSON["message"])
338338
})
339339
}
340340

models/repo.go

+6
Original file line numberDiff line numberDiff line change
@@ -2811,3 +2811,9 @@ func (repo *Repository) GetOriginalURLHostname() string {
28112811

28122812
return u.Host
28132813
}
2814+
2815+
// UpdateRepositoryCols updates repository's columns
2816+
func UpdateRepositoryCols(repo *Repository, cols ...string) error {
2817+
_, err := x.ID(repo.ID).Cols(cols...).Update(repo)
2818+
return err
2819+
}

modules/task/migrate.go

-2
Original file line numberDiff line numberDiff line change
@@ -97,8 +97,6 @@ func runMigrateTask(t *models.Task) (err error) {
9797
opts.MigrateToRepoID = t.RepoID
9898
repo, err := migrations.MigrateRepository(t.Doer, t.Owner.Name, *opts)
9999
if err == nil {
100-
notification.NotifyMigrateRepository(t.Doer, t.Owner, repo)
101-
102100
log.Trace("Repository migrated [%d]: %s/%s", repo.ID, t.Owner.Name, repo.Name)
103101
return nil
104102
}

routers/api/v1/repo/repo.go

+24-7
Original file line numberDiff line numberDiff line change
@@ -433,7 +433,21 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
433433
opts.Releases = false
434434
}
435435

436-
var repo *models.Repository
436+
repo, err := models.CreateRepository(ctx.User, ctxUser, models.CreateRepoOptions{
437+
Name: opts.RepoName,
438+
Description: opts.Description,
439+
OriginalURL: opts.CloneAddr,
440+
IsPrivate: opts.Private,
441+
IsMirror: opts.Mirror,
442+
Status: models.RepositoryBeingMigrated,
443+
})
444+
if err != nil {
445+
handleMigrateError(ctx, ctxUser, remoteAddr, err)
446+
return
447+
}
448+
449+
opts.MigrateToRepoID = repo.ID
450+
437451
defer func() {
438452
if e := recover(); e != nil {
439453
var buf bytes.Buffer
@@ -443,7 +457,7 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
443457

444458
if err == nil {
445459
repo.Status = models.RepositoryReady
446-
if err := models.UpdateRepositoryStatus(repo.ID, repo.Status); err == nil {
460+
if err := models.UpdateRepositoryCols(repo, "status"); err == nil {
447461
notification.NotifyMigrateRepository(ctx.User, ctxUser, repo)
448462
return
449463
}
@@ -456,13 +470,16 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
456470
}
457471
}()
458472

459-
repo, err = migrations.MigrateRepository(ctx.User, ctxUser.Name, opts)
460-
if err == nil {
461-
log.Trace("Repository migrated: %s/%s", ctxUser.Name, form.RepoName)
462-
ctx.JSON(201, repo.APIFormat(models.AccessModeAdmin))
473+
if _, err = migrations.MigrateRepository(ctx.User, ctxUser.Name, opts); err != nil {
474+
handleMigrateError(ctx, ctxUser, remoteAddr, err)
463475
return
464476
}
465477

478+
log.Trace("Repository migrated: %s/%s", ctxUser.Name, form.RepoName)
479+
ctx.JSON(201, repo.APIFormat(models.AccessModeAdmin))
480+
}
481+
482+
func handleMigrateError(ctx *context.APIContext, repoOwner *models.User, remoteAddr string, err error) {
466483
switch {
467484
case models.IsErrRepoAlreadyExist(err):
468485
ctx.Error(409, "", "The repository with the same name already exists.")
@@ -471,7 +488,7 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) {
471488
case migrations.IsTwoFactorAuthError(err):
472489
ctx.Error(422, "", "Remote visit required two factors authentication.")
473490
case models.IsErrReachLimitOfRepo(err):
474-
ctx.Error(422, "", fmt.Sprintf("You have already reached your limit of %d repositories.", ctxUser.MaxCreationLimit()))
491+
ctx.Error(422, "", fmt.Sprintf("You have already reached your limit of %d repositories.", repoOwner.MaxCreationLimit()))
475492
case models.IsErrNameReserved(err):
476493
ctx.Error(422, "", fmt.Sprintf("The username '%s' is reserved.", err.(models.ErrNameReserved).Name))
477494
case models.IsErrNamePatternNotAllowed(err):

0 commit comments

Comments
 (0)