summaryrefslogtreecommitdiffstats
path: root/routers/api/v1/repo
diff options
context:
space:
mode:
author6543 <6543@obermui.de>2021-05-08 14:11:36 +0200
committerGitHub <noreply@github.com>2021-05-08 14:11:36 +0200
commite2786147539909eaef2bc39fb728a10b88277d31 (patch)
treef6670b39eb552a094c0882b8c954c0d65f16c398 /routers/api/v1/repo
parent272bbb200d77ca520e335588c771301f9439f393 (diff)
downloadgitea-e2786147539909eaef2bc39fb728a10b88277d31.tar.gz
gitea-e2786147539909eaef2bc39fb728a10b88277d31.zip
[API] make change repo settings work on empty repos (#15778)
* API: Fix #15602 * Add TEST
Diffstat (limited to 'routers/api/v1/repo')
-rw-r--r--routers/api/v1/repo/repo.go16
1 files changed, 8 insertions, 8 deletions
diff --git a/routers/api/v1/repo/repo.go b/routers/api/v1/repo/repo.go
index c422feb043..d8600c0fcd 100644
--- a/routers/api/v1/repo/repo.go
+++ b/routers/api/v1/repo/repo.go
@@ -578,7 +578,7 @@ func updateBasicProperties(ctx *context.APIContext, opts api.EditRepoOption) err
repo.IsTemplate = *opts.Template
}
- if ctx.Repo.GitRepo == nil {
+ if ctx.Repo.GitRepo == nil && !repo.IsEmpty {
var err error
ctx.Repo.GitRepo, err = git.OpenRepository(ctx.Repo.Repository.RepoPath())
if err != nil {
@@ -589,13 +589,13 @@ func updateBasicProperties(ctx *context.APIContext, opts api.EditRepoOption) err
}
// Default branch only updated if changed and exist or the repository is empty
- if opts.DefaultBranch != nil &&
- repo.DefaultBranch != *opts.DefaultBranch &&
- (ctx.Repo.Repository.IsEmpty || ctx.Repo.GitRepo.IsBranchExist(*opts.DefaultBranch)) {
- if err := ctx.Repo.GitRepo.SetDefaultBranch(*opts.DefaultBranch); err != nil {
- if !git.IsErrUnsupportedVersion(err) {
- ctx.Error(http.StatusInternalServerError, "SetDefaultBranch", err)
- return err
+ if opts.DefaultBranch != nil && repo.DefaultBranch != *opts.DefaultBranch && (repo.IsEmpty || ctx.Repo.GitRepo.IsBranchExist(*opts.DefaultBranch)) {
+ if !repo.IsEmpty {
+ if err := ctx.Repo.GitRepo.SetDefaultBranch(*opts.DefaultBranch); err != nil {
+ if !git.IsErrUnsupportedVersion(err) {
+ ctx.Error(http.StatusInternalServerError, "SetDefaultBranch", err)
+ return err
+ }
}
}
repo.DefaultBranch = *opts.DefaultBranch