get_token.go 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. package billing
  2. import (
  3. "fmt"
  4. "net/http"
  5. "github.com/porter-dev/porter/api/server/authz"
  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/types"
  11. "github.com/porter-dev/porter/internal/models"
  12. )
  13. type BillingGetTokenHandler struct {
  14. handlers.PorterHandlerReadWriter
  15. authz.KubernetesAgentGetter
  16. }
  17. func NewBillingGetTokenHandler(
  18. config *config.Config,
  19. decoderValidator shared.RequestDecoderValidator,
  20. writer shared.ResultWriter,
  21. ) http.Handler {
  22. return &BillingGetTokenHandler{
  23. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  24. }
  25. }
  26. func (c *BillingGetTokenHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  27. user, _ := r.Context().Value(types.UserScope).(*models.User)
  28. proj, _ := r.Context().Value(types.ProjectScope).(*models.Project)
  29. // we double-check that the user is an admin the project
  30. roles, err := c.Repo().Project().ListProjectRoles(proj.ID)
  31. if err != nil {
  32. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  33. return
  34. }
  35. for _, role := range roles {
  36. if role.UserID != 0 && role.UserID == user.ID {
  37. if role.Kind != types.RoleAdmin {
  38. c.HandleAPIError(w, r, apierrors.NewErrForbidden(
  39. fmt.Errorf("user %d is not an admin in project %d", user.ID, proj.ID),
  40. ))
  41. return
  42. }
  43. }
  44. }
  45. token, teamID, err := c.Config().BillingManager.GetIDToken(proj, user)
  46. if err != nil {
  47. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  48. return
  49. }
  50. c.WriteResult(w, r, &types.GetBillingTokenResponse{
  51. Token: token,
  52. TeamID: teamID,
  53. })
  54. }