get.go 1.9 KB

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