diff options
author | Sandro Santilli <strk@kbt.io> | 2018-01-05 11:56:52 +0100 |
---|---|---|
committer | Lauris BH <lauris@nix.lv> | 2018-01-05 12:56:52 +0200 |
commit | a192f3052ed9b59d1404fdcebf2b5c156d6d6969 (patch) | |
tree | d955279b81ab5de792158f0f131a23a7837c1e57 /routers/repo/pull.go | |
parent | ce7ae17b81220434af13fd048e44899bbd7d9e72 (diff) | |
download | gitea-a192f3052ed9b59d1404fdcebf2b5c156d6d6969.tar.gz gitea-a192f3052ed9b59d1404fdcebf2b5c156d6d6969.zip |
Serve pull request .diff files (#3293)
* Serve pull request .diff files
Closes #3259
* Add test for pull request redirection and .diff access
* Typo
* There's no need to test for pr.BaseRepo being nil after calling GetBaseRepo
Diffstat (limited to 'routers/repo/pull.go')
-rw-r--r-- | routers/repo/pull.go | 38 |
1 files changed, 37 insertions, 1 deletions
diff --git a/routers/repo/pull.go b/routers/repo/pull.go index 5575009af4..6162df9651 100644 --- a/routers/repo/pull.go +++ b/routers/repo/pull.go @@ -1,4 +1,6 @@ -// Copyright 2014 The Gogs Authors. All rights reserved. +// Copyright 2018 The Gitea Authors. +// Copyright 2014 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. @@ -991,3 +993,37 @@ func CleanUpPullRequest(ctx *context.Context) { ctx.Flash.Success(ctx.Tr("repo.branch.deletion_success", fullBranchName)) } + +// DownloadPullDiff render a pull's raw diff +func DownloadPullDiff(ctx *context.Context) { + issue, err := models.GetIssueByIndex(ctx.Repo.Repository.ID, ctx.ParamsInt64(":index")) + if err != nil { + if models.IsErrIssueNotExist(err) { + ctx.Handle(404, "GetIssueByIndex", err) + } else { + ctx.Handle(500, "GetIssueByIndex", err) + } + return + } + + // Redirect elsewhere if it's not a pull request + if !issue.IsPull { + ctx.Handle(404, "DownloadPullDiff", + fmt.Errorf("Issue is not a pull request")) + return + } + + pr := issue.PullRequest + + if err = pr.GetBaseRepo(); err != nil { + ctx.Handle(500, "GetBaseRepo", err) + return + } + patch, err := pr.BaseRepo.PatchPath(pr.Index) + if err != nil { + ctx.Handle(500, "PatchPath", err) + return + } + + ctx.ServeFileContent(patch) +} |