diff options
Diffstat (limited to 'routers/private/repository.go')
-rw-r--r-- | routers/private/repository.go | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/routers/private/repository.go b/routers/private/repository.go new file mode 100644 index 0000000000..0769e1f250 --- /dev/null +++ b/routers/private/repository.go @@ -0,0 +1,84 @@ +// Copyright 2018 The Gitea 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 private + +import ( + "net/http" + "net/url" + + "code.gitea.io/gitea/models" + + macaron "gopkg.in/macaron.v1" +) + +// GetRepository return the default branch of a repository +func GetRepository(ctx *macaron.Context) { + repoID := ctx.ParamsInt64(":rid") + repository, err := models.GetRepositoryByID(repoID) + repository.MustOwnerName() + allowPulls := repository.AllowsPulls() + // put it back to nil because json unmarshal can't unmarshal it + repository.Units = nil + + if err != nil { + ctx.JSON(http.StatusInternalServerError, map[string]interface{}{ + "err": err.Error(), + }) + return + } + + if repository.IsFork { + repository.GetBaseRepo() + if err != nil { + ctx.JSON(http.StatusInternalServerError, map[string]interface{}{ + "err": err.Error(), + }) + return + } + repository.BaseRepo.MustOwnerName() + allowPulls = repository.BaseRepo.AllowsPulls() + // put it back to nil because json unmarshal can't unmarshal it + repository.BaseRepo.Units = nil + } + + ctx.JSON(http.StatusOK, struct { + Repository *models.Repository + AllowPullRequest bool + }{ + Repository: repository, + AllowPullRequest: allowPulls, + }) +} + +// GetActivePullRequest return an active pull request when it exists or an empty object +func GetActivePullRequest(ctx *macaron.Context) { + baseRepoID := ctx.QueryInt64("baseRepoID") + headRepoID := ctx.QueryInt64("headRepoID") + baseBranch, err := url.QueryUnescape(ctx.QueryTrim("baseBranch")) + if err != nil { + ctx.JSON(http.StatusInternalServerError, map[string]interface{}{ + "err": err.Error(), + }) + return + } + + headBranch, err := url.QueryUnescape(ctx.QueryTrim("headBranch")) + if err != nil { + ctx.JSON(http.StatusInternalServerError, map[string]interface{}{ + "err": err.Error(), + }) + return + } + + pr, err := models.GetUnmergedPullRequest(headRepoID, baseRepoID, headBranch, baseBranch) + if err != nil && !models.IsErrPullRequestNotExist(err) { + ctx.JSON(http.StatusInternalServerError, map[string]interface{}{ + "err": err.Error(), + }) + return + } + + ctx.JSON(http.StatusOK, pr) +} |