diff options
author | Julien Tant <julien@craftyx.fr> | 2018-10-20 08:59:06 +0200 |
---|---|---|
committer | Lauris BH <lauris@nix.lv> | 2018-10-20 09:59:06 +0300 |
commit | dea3d849e1e21ccda6f272591cadcb6d1d338b56 (patch) | |
tree | 14302df694d167582f19fa0d0a1ae5a65cfbab98 /modules/private | |
parent | cabdf84f1f5e55e8b449bbd3b4d4ba0c69a87c87 (diff) | |
download | gitea-dea3d849e1e21ccda6f272591cadcb6d1d338b56.tar.gz gitea-dea3d849e1e21ccda6f272591cadcb6d1d338b56.zip |
Give user a link to create PR after push (#4716)
* Give user a link to create PR after push
* Forks now create PR in the base repository + make sure PR creation is allowed
* fix code style
Diffstat (limited to 'modules/private')
-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 +} |