From 0834e492c06e30d30c2bc8eec4fcb6c499a62ced Mon Sep 17 00:00:00 2001 From: Ethan Koenig Date: Mon, 14 Nov 2016 17:33:58 -0500 Subject: API endpoints for stars --- modules/context/api.go | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) (limited to 'modules/context') diff --git a/modules/context/api.go b/modules/context/api.go index 197fbd6df1..0da1823797 100644 --- a/modules/context/api.go +++ b/modules/context/api.go @@ -8,6 +8,7 @@ import ( "fmt" "strings" + "code.gitea.io/gitea/models" "code.gitea.io/gitea/modules/base" "code.gitea.io/gitea/modules/log" "code.gitea.io/gitea/modules/setting" @@ -70,3 +71,33 @@ func APIContexter() macaron.Handler { c.Map(ctx) } } + +// ExtractOwnerAndRepo returns a handler that populates the `Repo.Owner` and +// `Repo.Repository` fields of an APIContext +func ExtractOwnerAndRepo() macaron.Handler { + return func(ctx *APIContext) { + owner, err := models.GetUserByName(ctx.Params(":username")) + if err != nil { + if models.IsErrUserNotExist(err) { + ctx.Error(422, "", err) + } else { + ctx.Error(500, "GetUserByName", err) + } + return + } + + repo, err := models.GetRepositoryByName(owner.ID, ctx.Params(":reponame")) + if err != nil { + if models.IsErrRepoNotExist(err) { + ctx.Status(404) + } else { + ctx.Error(500, "GetRepositoryByName", err) + } + return + } + ctx.Repo.Owner = owner + ctx.Data["Owner"] = owner + ctx.Repo.Repository = repo + ctx.Data["Repository"] = repo + } +} -- cgit v1.2.3