Skip to content

Commit

Permalink
Fix creation of Organization repos by Users with max created personal…
Browse files Browse the repository at this point in the history
… repos (#11183)

* Fix creation of Org repos

Fix #9269

* Change variable name to appease linter

* Update PR with suggestions

Add a note for user.CanCreateRepo() about failure assumptions
Change repo.create help message

Co-authored-by: guillep2k <[email protected]>
  • Loading branch information
AndrewBezold and guillep2k committed Apr 30, 2020
1 parent 28e5e7f commit 3dc6af3
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 6 deletions.
1 change: 1 addition & 0 deletions models/user.go
Original file line number Diff line number Diff line change
Expand Up @@ -279,6 +279,7 @@ func (u *User) MaxCreationLimit() int {
}

// CanCreateRepo returns if user login can create a repository
// NOTE: functions calling this assume a failure due to repository count limit; if new checks are added, those functions should be revised
func (u *User) CanCreateRepo() bool {
if u.IsAdmin {
return true
Expand Down
21 changes: 15 additions & 6 deletions routers/repo/repo.go
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,6 @@ func checkContextUser(ctx *context.Context, uid int64) *models.User {
ctx.ServerError("GetOrgsCanCreateRepoByUserID", err)
return nil
}
ctx.Data["Orgs"] = orgs

// Not equal means current user is an organization.
if uid == ctx.User.ID || uid == 0 {
Expand All @@ -84,6 +83,14 @@ func checkContextUser(ctx *context.Context, uid int64) *models.User {
return nil
}
if !ctx.User.IsAdmin {
orgsAvailable := []*models.User{}
for i := 0; i < len(orgs); i++ {
if orgs[i].CanCreateRepo() {
orgsAvailable = append(orgsAvailable, orgs[i])
}
}
ctx.Data["Orgs"] = orgsAvailable

canCreate, err := org.CanCreateOrgRepo(ctx.User.ID)
if err != nil {
ctx.ServerError("CanCreateOrgRepo", err)
Expand All @@ -92,6 +99,8 @@ func checkContextUser(ctx *context.Context, uid int64) *models.User {
ctx.Error(403)
return nil
}
} else {
ctx.Data["Orgs"] = orgs
}
return org
}
Expand All @@ -111,10 +120,6 @@ func getRepoPrivate(ctx *context.Context) bool {

// Create render creating repository page
func Create(ctx *context.Context) {
if !ctx.User.CanCreateRepo() {
ctx.RenderWithErr(ctx.Tr("repo.form.reach_limit_of_creation", ctx.User.MaxCreationLimit()), tplCreate, nil)
}

ctx.Data["Title"] = ctx.Tr("new_repo")

// Give default value for template to render.
Expand Down Expand Up @@ -142,7 +147,11 @@ func Create(ctx *context.Context) {
}
}

ctx.HTML(200, tplCreate)
if !ctx.User.CanCreateRepo() {
ctx.RenderWithErr(ctx.Tr("repo.form.reach_limit_of_creation", ctx.User.MaxCreationLimit()), tplCreate, nil)
} else {
ctx.HTML(200, tplCreate)
}
}

func handleCreateError(ctx *context.Context, owner *models.User, err error, name string, tpl base.TplName, form interface{}) {
Expand Down
1 change: 1 addition & 0 deletions templates/repo/create.tmpl
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,7 @@
{{end}}
</div>
</div>
<span class="help">Some organizations may not show up in the dropdown due to a maximum repository count limit</span>
</div>

<div class="inline required field {{if .Err_RepoName}}error{{end}}">
Expand Down

0 comments on commit 3dc6af3

Please sign in to comment.