summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLauris BH <lauris@nix.lv>2018-07-05 02:51:02 +0300
committerJonas Franz <info@jonasfranz.software>2018-07-05 01:51:02 +0200
commit69e2ab161109eef667cd22a96711e4a8ee9d01d2 (patch)
treec69499946dfb2e61390fb1c57a4afe42d9c362f0
parent4eae810d63cb48977d7c0b96c90877592ec3d7b2 (diff)
downloadgitea-69e2ab161109eef667cd22a96711e4a8ee9d01d2.tar.gz
gitea-69e2ab161109eef667cd22a96711e4a8ee9d01d2.zip
Allow administrator to create repository for any organization (#4368)
-rw-r--r--integrations/api_repo_test.go23
-rw-r--r--routers/api/v1/repo/repo.go16
2 files changed, 32 insertions, 7 deletions
diff --git a/integrations/api_repo_test.go b/integrations/api_repo_test.go
index c789cc9ee4..aec8c8f81b 100644
--- a/integrations/api_repo_test.go
+++ b/integrations/api_repo_test.go
@@ -262,3 +262,26 @@ func TestAPIRepoMigrate(t *testing.T) {
session.MakeRequest(t, req, testCase.expectedStatus)
}
}
+
+func TestAPIOrgRepoCreate(t *testing.T) {
+ testCases := []struct {
+ ctxUserID int64
+ orgName, repoName string
+ expectedStatus int
+ }{
+ {ctxUserID: 1, orgName: "user3", repoName: "repo-admin", expectedStatus: http.StatusCreated},
+ {ctxUserID: 2, orgName: "user3", repoName: "repo-own", expectedStatus: http.StatusCreated},
+ {ctxUserID: 2, orgName: "user6", repoName: "repo-bad-org", expectedStatus: http.StatusForbidden},
+ }
+
+ prepareTestEnv(t)
+ for _, testCase := range testCases {
+ user := models.AssertExistsAndLoadBean(t, &models.User{ID: testCase.ctxUserID}).(*models.User)
+ session := loginUser(t, user.Name)
+
+ req := NewRequestWithJSON(t, "POST", fmt.Sprintf("/api/v1/org/%s/repos", testCase.orgName), &api.CreateRepoOption{
+ Name: testCase.repoName,
+ })
+ session.MakeRequest(t, req, testCase.expectedStatus)
+ }
+}
diff --git a/routers/api/v1/repo/repo.go b/routers/api/v1/repo/repo.go
index c6c5d4aec3..044b1e9c18 100644
--- a/routers/api/v1/repo/repo.go
+++ b/routers/api/v1/repo/repo.go
@@ -257,13 +257,15 @@ func CreateOrgRepo(ctx *context.APIContext, opt api.CreateRepoOption) {
return
}
- isOwner, err := org.IsOwnedBy(ctx.User.ID)
- if err != nil {
- ctx.ServerError("IsOwnedBy", err)
- return
- } else if !isOwner {
- ctx.Error(403, "", "Given user is not owner of organization.")
- return
+ if !ctx.User.IsAdmin {
+ isOwner, err := org.IsOwnedBy(ctx.User.ID)
+ if err != nil {
+ ctx.ServerError("IsOwnedBy", err)
+ return
+ } else if !isOwner {
+ ctx.Error(403, "", "Given user is not owner of organization.")
+ return
+ }
}
CreateUserRepo(ctx, org, opt)
}