diff options
Diffstat (limited to 'modules/private/repository.go')
-rw-r--r-- | modules/private/repository.go | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/modules/private/repository.go b/modules/private/repository.go new file mode 100644 index 0000000000..cf8ae68409 --- /dev/null +++ b/modules/private/repository.go @@ -0,0 +1,68 @@ +// 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 ( + "encoding/json" + "fmt" + "net/url" + + "code.gitea.io/gitea/models" + "code.gitea.io/gitea/modules/log" + "code.gitea.io/gitea/modules/setting" +) + +// GetRepository return the repository by its ID and a bool about if it's allowed to have PR +func GetRepository(repoID int64) (*models.Repository, bool, error) { + reqURL := setting.LocalURL + fmt.Sprintf("api/internal/repository/%d", repoID) + log.GitLogger.Trace("GetRepository: %s", reqURL) + + resp, err := newInternalRequest(reqURL, "GET").Response() + if err != nil { + return nil, false, err + } + + var repoInfo struct { + Repository *models.Repository + AllowPullRequest bool + } + if err := json.NewDecoder(resp.Body).Decode(&repoInfo); err != nil { + return nil, false, err + } + + defer resp.Body.Close() + + // All 2XX status codes are accepted and others will return an error + if resp.StatusCode/100 != 2 { + return nil, false, fmt.Errorf("failed to retrieve repository: %s", decodeJSONError(resp).Err) + } + + return repoInfo.Repository, repoInfo.AllowPullRequest, nil +} + +// ActivePullRequest returns an active pull request if it exists +func ActivePullRequest(baseRepoID int64, headRepoID int64, baseBranch, headBranch string) (*models.PullRequest, error) { + reqURL := setting.LocalURL + fmt.Sprintf("api/internal/active-pull-request?baseRepoID=%d&headRepoID=%d&baseBranch=%s&headBranch=%s", baseRepoID, headRepoID, url.QueryEscape(baseBranch), url.QueryEscape(headBranch)) + log.GitLogger.Trace("ActivePullRequest: %s", reqURL) + + resp, err := newInternalRequest(reqURL, "GET").Response() + if err != nil { + return nil, err + } + + var pr *models.PullRequest + if err := json.NewDecoder(resp.Body).Decode(&pr); err != nil { + return nil, err + } + + defer resp.Body.Close() + + // All 2XX status codes are accepted and others will return an error + if resp.StatusCode/100 != 2 { + return nil, fmt.Errorf("failed to retrieve pull request: %s", decodeJSONError(resp).Err) + } + + return pr, nil +} |