From 66219bd83d09d0aacc848c2d92acf82c06ab64a0 Mon Sep 17 00:00:00 2001 From: Brad Rydzewski Date: Fri, 6 Sep 2019 15:20:41 -0700 Subject: [PATCH] added remote repo endpoint --- handler/api/api.go | 1 + handler/api/user/remote/repo.go | 60 +++++++++++++++++++++++++++++++++ 2 files changed, 61 insertions(+) create mode 100644 handler/api/user/remote/repo.go diff --git a/handler/api/api.go b/handler/api/api.go index d3e2332e..f9ebb1c9 100644 --- a/handler/api/api.go +++ b/handler/api/api.go @@ -278,6 +278,7 @@ func (s Server) Handler() http.Handler { // expose remote endpoints (e.g. to github) r.Get("/remote/repos", remote.HandleRepos(s.Repoz)) + r.Get("/remote/repos/{owner}/{name}", remote.HandleRepo(s.Repoz)) }) r.Route("/users", func(r chi.Router) { diff --git a/handler/api/user/remote/repo.go b/handler/api/user/remote/repo.go new file mode 100644 index 00000000..a932f7c7 --- /dev/null +++ b/handler/api/user/remote/repo.go @@ -0,0 +1,60 @@ +// Copyright 2019 Drone IO, Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +package remote + +import ( + "net/http" + + "github.com/drone/drone/core" + "github.com/drone/drone/handler/api/render" + "github.com/drone/drone/handler/api/request" + "github.com/drone/drone/logger" + "github.com/drone/go-scm/scm" + + "github.com/go-chi/chi" +) + +// HandleRepo returns an http.HandlerFunc that writes a json-encoded +// repository to the response body. +func HandleRepo(repos core.RepositoryService) http.HandlerFunc { + return func(w http.ResponseWriter, r *http.Request) { + var ( + viewer, _ = request.UserFrom(r.Context()) + + owner = chi.URLParam(r, "owner") + name = chi.URLParam(r, "name") + slug = scm.Join(owner, name) + ) + + repo, err := repos.Find(r.Context(), viewer, slug) + if err != nil { + render.InternalError(w, err) + logger.FromRequest(r).WithError(err). + Debugln("api: cannot get remote repository") + return + } + + perms, err := repos.FindPerm(r.Context(), viewer, slug) + if err != nil { + render.InternalError(w, err) + logger.FromRequest(r).WithError(err). + Debugln("api: cannot get remote repository permissions") + } else { + repo.Perms = perms + } + + render.JSON(w, repo, 200) + } +}