create.go 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package policy
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "net/http"
  6. "strings"
  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/types"
  12. "github.com/porter-dev/porter/internal/encryption"
  13. "github.com/porter-dev/porter/internal/models"
  14. )
  15. type PolicyCreateHandler struct {
  16. handlers.PorterHandlerReadWriter
  17. }
  18. func NewPolicyCreateHandler(
  19. config *config.Config,
  20. decoderValidator shared.RequestDecoderValidator,
  21. writer shared.ResultWriter,
  22. ) *PolicyCreateHandler {
  23. return &PolicyCreateHandler{
  24. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  25. }
  26. }
  27. func (p *PolicyCreateHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  28. user, _ := r.Context().Value(types.UserScope).(*models.User)
  29. proj, _ := r.Context().Value(types.ProjectScope).(*models.Project)
  30. req := &types.CreatePolicy{}
  31. if ok := p.DecodeAndValidate(w, r, req); !ok {
  32. return
  33. }
  34. // policy can't be one of the preset policy names
  35. if name := strings.ToLower(req.Name); name == "admin" || name == "developer" || name == "viewer" {
  36. p.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(
  37. fmt.Errorf("name cannot be one of the preset policy names"),
  38. http.StatusBadRequest,
  39. ))
  40. return
  41. }
  42. uid, err := encryption.GenerateRandomBytes(16)
  43. if err != nil {
  44. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  45. return
  46. }
  47. policyBytes, err := json.Marshal(req.Policy)
  48. if err != nil {
  49. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  50. return
  51. }
  52. policy := &models.Policy{
  53. ProjectID: proj.ID,
  54. UniqueID: uid,
  55. CreatedByUserID: user.ID,
  56. Name: req.Name,
  57. PolicyBytes: policyBytes,
  58. }
  59. policy, err = p.Repo().Policy().CreatePolicy(policy)
  60. if err != nil {
  61. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  62. return
  63. }
  64. res, err := policy.ToAPIPolicyType()
  65. if err != nil {
  66. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  67. return
  68. }
  69. p.WriteResult(w, r, res)
  70. }