From 7afe81f28e530c1c5aed1583654b3d772c368fa5 Mon Sep 17 00:00:00 2001 From: Lunny Xiao Date: Tue, 26 Feb 2019 22:28:56 +0800 Subject: [PATCH] fix bug when migrate repository 500 when repo is existed (#6188) * fix bug when migrate repository 500 when repo is existed * use 409 but not 422 for error status code when not exist * translation fix --- routers/api/v1/repo/repo.go | 5 +++++ routers/repo/repo.go | 5 +++++ 2 files changed, 10 insertions(+) diff --git a/routers/api/v1/repo/repo.go b/routers/api/v1/repo/repo.go index 4156775286c..c6a7803acba 100644 --- a/routers/api/v1/repo/repo.go +++ b/routers/api/v1/repo/repo.go @@ -408,6 +408,11 @@ func Migrate(ctx *context.APIContext, form auth.MigrateRepoForm) { RemoteAddr: remoteAddr, }) if err != nil { + if models.IsErrRepoAlreadyExist(err) { + ctx.Error(409, "", "The repository with the same name already exists.") + return + } + err = util.URLSanitizedError(err, remoteAddr) if repo != nil { if errDelete := models.DeleteRepository(ctx.User, ctxUser.ID, repo.ID); errDelete != nil { diff --git a/routers/repo/repo.go b/routers/repo/repo.go index 960961a5e56..42dfd562686 100644 --- a/routers/repo/repo.go +++ b/routers/repo/repo.go @@ -256,6 +256,11 @@ func MigratePost(ctx *context.Context, form auth.MigrateRepoForm) { return } + if models.IsErrRepoAlreadyExist(err) { + ctx.RenderWithErr(ctx.Tr("form.repo_name_been_taken"), tplMigrate, &form) + return + } + // remoteAddr may contain credentials, so we sanitize it err = util.URLSanitizedError(err, remoteAddr)