From 144663a3cfcdebf16755e4d65e1e50ac91593eca Mon Sep 17 00:00:00 2001 From: Unknwon Date: Wed, 25 Nov 2015 00:55:37 -0500 Subject: allow admin to migrate for any user/org --- routers/api/v1/repo.go | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'routers/api/v1/repo.go') diff --git a/routers/api/v1/repo.go b/routers/api/v1/repo.go index b4da4c6f..234673a9 100644 --- a/routers/api/v1/repo.go +++ b/routers/api/v1/repo.go @@ -189,7 +189,8 @@ func CreateOrgRepo(ctx *middleware.Context, opt api.CreateRepoOption) { func MigrateRepo(ctx *middleware.Context, form auth.MigrateRepoForm) { ctxUser := ctx.User - // Not equal means current user is an organization. + // Not equal means context user is an organization, + // or is another user/organization if current user is admin. if form.Uid != ctxUser.Id { org, err := models.GetUserByID(form.Uid) if err != nil { @@ -208,7 +209,7 @@ func MigrateRepo(ctx *middleware.Context, form auth.MigrateRepoForm) { return } - if ctxUser.IsOrganization() { + if ctxUser.IsOrganization() && !ctx.User.IsAdmin { // Check ownership of organization. if !ctxUser.IsOwnedBy(ctx.User.Id) { ctx.APIError(403, "", "Given user is not owner of organization.") -- cgit v1.2.3