aboutsummaryrefslogtreecommitdiffstats
path: root/routers
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2015-12-17 22:57:41 -0500
committerUnknwon <u@gogs.io>2015-12-17 22:57:41 -0500
commit1c9dd11ba71ff261f52bf1d31aba6812d0680179 (patch)
tree9862b1736199877f613200450c897ecec6a79f06 /routers
parent1e7e092992164acc243ec01859509eaa2207196d (diff)
downloadgitea-1c9dd11ba71ff261f52bf1d31aba6812d0680179.tar.gz
gitea-1c9dd11ba71ff261f52bf1d31aba6812d0680179.zip
#1692 API: admin create repo
Diffstat (limited to 'routers')
-rw-r--r--routers/api/v1/admin/repos.go23
-rw-r--r--routers/api/v1/api.go1
-rw-r--r--routers/api/v1/repo/repo.go6
3 files changed, 27 insertions, 3 deletions
diff --git a/routers/api/v1/admin/repos.go b/routers/api/v1/admin/repos.go
new file mode 100644
index 0000000000..7a6b2af20b
--- /dev/null
+++ b/routers/api/v1/admin/repos.go
@@ -0,0 +1,23 @@
+// Copyright 2015 The Gogs Authors. All rights reserved.
+// Use of this source code is governed by a MIT-style
+// license that can be found in the LICENSE file.
+
+package admin
+
+import (
+ api "github.com/gogits/go-gogs-client"
+
+ "github.com/gogits/gogs/modules/middleware"
+ "github.com/gogits/gogs/routers/api/v1/repo"
+ "github.com/gogits/gogs/routers/api/v1/user"
+)
+
+// https://github.com/gogits/go-gogs-client/wiki/Administration-Repositories#create-a-new-repository
+func CreateRepo(ctx *middleware.Context, form api.CreateRepoOption) {
+ owner := user.GetUserByParams(ctx)
+ if ctx.Written() {
+ return
+ }
+
+ repo.CreateUserRepo(ctx, owner, form)
+}
diff --git a/routers/api/v1/api.go b/routers/api/v1/api.go
index bc7c14006e..cc169f708d 100644
--- a/routers/api/v1/api.go
+++ b/routers/api/v1/api.go
@@ -198,6 +198,7 @@ func RegisterRoutes(m *macaron.Macaron) {
Delete(admin.DeleteUser)
m.Post("/keys", admin.CreatePublicKey)
m.Post("/orgs", bind(api.CreateOrgOption{}), admin.CreateOrg)
+ m.Post("/repos", bind(api.CreateRepoOption{}), admin.CreateRepo)
})
})
}, ReqAdmin())
diff --git a/routers/api/v1/repo/repo.go b/routers/api/v1/repo/repo.go
index 7790377910..eb00aa886f 100644
--- a/routers/api/v1/repo/repo.go
+++ b/routers/api/v1/repo/repo.go
@@ -113,7 +113,7 @@ func ListMyRepos(ctx *middleware.Context) {
ctx.JSON(200, &repos)
}
-func createRepo(ctx *middleware.Context, owner *models.User, opt api.CreateRepoOption) {
+func CreateUserRepo(ctx *middleware.Context, owner *models.User, opt api.CreateRepoOption) {
repo, err := models.CreateRepository(owner, models.CreateRepoOptions{
Name: opt.Name,
Description: opt.Description,
@@ -149,7 +149,7 @@ func Create(ctx *middleware.Context, opt api.CreateRepoOption) {
ctx.APIError(422, "", "not allowed creating repository for organization")
return
}
- createRepo(ctx, ctx.User, opt)
+ CreateUserRepo(ctx, ctx.User, opt)
}
func CreateOrgRepo(ctx *middleware.Context, opt api.CreateRepoOption) {
@@ -167,7 +167,7 @@ func CreateOrgRepo(ctx *middleware.Context, opt api.CreateRepoOption) {
ctx.APIError(403, "", "Given user is not owner of organization.")
return
}
- createRepo(ctx, org, opt)
+ CreateUserRepo(ctx, org, opt)
}
// https://github.com/gogits/go-gogs-client/wiki/Repositories#migrate