// Copyright 2019 Drone.IO Inc. All rights reserved. // Use of this source code is governed by the Drone Non-Commercial License // that can be found in the LICENSE file. package repos 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/dchest/uniuri" "github.com/go-chi/chi" ) // HandleEnable returns an http.HandlerFunc that processes http // requests to enable a repository in the system. func HandleEnable( hooks core.HookService, repos core.RepositoryStore, sender core.WebhookSender, ) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { var ( owner = chi.URLParam(r, "owner") name = chi.URLParam(r, "name") ) user, _ := request.UserFrom(r.Context()) repo, err := repos.FindName(r.Context(), owner, name) if err != nil { render.NotFound(w, err) logger.FromRequest(r). WithError(err). WithField("namespace", owner). WithField("name", name). Debugln("api: repository not found") return } repo.Active = true repo.UserID = user.ID if repo.Config == "" { repo.Config = ".core.yml" } if repo.Signer == "" { repo.Signer = uniuri.NewLen(32) } if repo.Secret == "" { repo.Secret = uniuri.NewLen(32) } if repo.Timeout == 0 { repo.Timeout = 60 } err = hooks.Create(r.Context(), user, repo) if err != nil { render.InternalError(w, err) logger.FromRequest(r). WithError(err). WithField("namespace", owner). WithField("name", name). Debugln("api: cannot create or update hook") return } err = repos.Activate(r.Context(), repo) if err == core.ErrRepoLimit { render.ErrorCode(w, err, 402) logger.FromRequest(r). WithError(err). WithField("namespace", owner). WithField("name", name). Errorln("api: cannot activate repository") return } if err != nil { render.InternalError(w, err) logger.FromRequest(r). WithError(err). WithField("namespace", owner). WithField("name", name). Debugln("api: cannot activate repository") return } err = sender.Send(r.Context(), &core.WebhookData{ Event: core.WebhookEventRepo, Action: core.WebhookActionEnabled, User: user, Repo: repo, }) if err != nil { logger.FromRequest(r). WithError(err). WithField("namespace", owner). WithField("name", name). Warnln("api: cannot send webhook") } render.JSON(w, repo, 200) } }