// 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 users import ( "encoding/json" "net/http" "github.com/drone/drone/handler/api/render" "github.com/drone/drone/logger" "github.com/drone/drone/core" "github.com/go-chi/chi" ) type userInput struct { Admin *bool `json:"admin"` Active *bool `json:"active"` } // HandleUpdate returns an http.HandlerFunc that processes an http.Request // to update a user account. func HandleUpdate(users core.UserStore) http.HandlerFunc { return func(w http.ResponseWriter, r *http.Request) { login := chi.URLParam(r, "user") in := new(userInput) err := json.NewDecoder(r.Body).Decode(in) if err != nil { render.BadRequest(w, err) logger.FromRequest(r).WithError(err). Debugln("api: cannot unmarshal request body") return } user, err := users.FindLogin(r.Context(), login) if err != nil { render.NotFound(w, err) logger.FromRequest(r).WithError(err). Debugln("api: cannot find user") return } if in.Admin != nil { user.Admin = *in.Admin } if in.Active != nil { user.Active = *in.Active // if the user is inactive we should always // disable administrative privileges since // the user may still have some API access. if user.Active == false { user.Admin = false } } err = users.Update(r.Context(), user) if err != nil { render.InternalError(w, err) logger.FromRequest(r).WithError(err). Warnln("api: cannot update user") } else { render.JSON(w, user, 200) } } }