revoke.go 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. package api_token
  2. import (
  3. "errors"
  4. "fmt"
  5. "net/http"
  6. "github.com/porter-dev/porter/api/server/handlers"
  7. "github.com/porter-dev/porter/api/server/shared"
  8. "github.com/porter-dev/porter/api/server/shared/apierrors"
  9. "github.com/porter-dev/porter/api/server/shared/config"
  10. "github.com/porter-dev/porter/api/server/shared/requestutils"
  11. "github.com/porter-dev/porter/api/types"
  12. "github.com/porter-dev/porter/internal/models"
  13. "gorm.io/gorm"
  14. )
  15. type APITokenRevokeHandler struct {
  16. handlers.PorterHandlerReadWriter
  17. }
  18. func NewAPITokenRevokeHandler(
  19. config *config.Config,
  20. decoderValidator shared.RequestDecoderValidator,
  21. writer shared.ResultWriter,
  22. ) *APITokenRevokeHandler {
  23. return &APITokenRevokeHandler{
  24. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  25. }
  26. }
  27. func (p *APITokenRevokeHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  28. proj, _ := r.Context().Value(types.ProjectScope).(*models.Project)
  29. if !proj.GetFeatureFlag(models.APITokensEnabled, p.Config().LaunchDarklyClient) {
  30. p.HandleAPIError(w, r, apierrors.NewErrForbidden(fmt.Errorf("api token endpoints are not enabled for this project")))
  31. return
  32. }
  33. // get the token id from the request
  34. tokenID, reqErr := requestutils.GetURLParamString(r, types.URLParamTokenID)
  35. if reqErr != nil {
  36. p.HandleAPIError(w, r, reqErr)
  37. return
  38. }
  39. token, err := p.Repo().APIToken().ReadAPIToken(proj.ID, tokenID)
  40. if err != nil {
  41. if errors.Is(err, gorm.ErrRecordNotFound) {
  42. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  43. fmt.Errorf("token with id %s not found in project", tokenID),
  44. http.StatusNotFound,
  45. ))
  46. return
  47. }
  48. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  49. return
  50. }
  51. token.Revoked = true
  52. token, err = p.Repo().APIToken().UpdateAPIToken(token)
  53. if err != nil {
  54. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  55. return
  56. }
  57. p.WriteResult(w, r, token.ToAPITokenMetaType())
  58. }