can_create_project.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package user
  2. import (
  3. "fmt"
  4. "net/http"
  5. "github.com/porter-dev/porter/api/server/handlers"
  6. "github.com/porter-dev/porter/api/server/shared"
  7. "github.com/porter-dev/porter/api/server/shared/apierrors"
  8. "github.com/porter-dev/porter/api/server/shared/config"
  9. "github.com/porter-dev/porter/api/types"
  10. "github.com/porter-dev/porter/internal/models"
  11. )
  12. type CanCreateProject struct {
  13. handlers.PorterHandlerWriter
  14. }
  15. func NewCanCreateProjectHandler(
  16. config *config.Config,
  17. decoderValidator shared.RequestDecoderValidator,
  18. writer shared.ResultWriter,
  19. ) *CanCreateProject {
  20. return &CanCreateProject{
  21. PorterHandlerWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  22. }
  23. }
  24. func (c *CanCreateProject) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  25. if c.Config().ServerConf.DisableAllowlist {
  26. c.WriteResult(w, r, "")
  27. return
  28. }
  29. user, _ := r.Context().Value(types.UserScope).(*models.User)
  30. exists, err := c.Repo().Allowlist().UserEmailExists(user.Email)
  31. if err != nil {
  32. err = fmt.Errorf("couldn't retrieve user: %s", err.Error())
  33. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  34. return
  35. }
  36. if !exists {
  37. err = fmt.Errorf("user is not authorized")
  38. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, 403))
  39. return
  40. }
  41. c.WriteResult(w, r, "")
  42. }