create_secret.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package doppler
  2. import (
  3. "net/http"
  4. "github.com/porter-dev/porter/api/server/authz"
  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. "github.com/porter-dev/porter/internal/telemetry"
  12. )
  13. type CreateDopplerSecretHandler struct {
  14. handlers.PorterHandlerReadWriter
  15. authz.KubernetesAgentGetter
  16. }
  17. func NewCreateDopplerSecretHandler(
  18. config *config.Config,
  19. decoderValidator shared.RequestDecoderValidator,
  20. writer shared.ResultWriter,
  21. ) *CreateDopplerSecretHandler {
  22. return &CreateDopplerSecretHandler{
  23. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  24. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  25. }
  26. }
  27. type CreateDopplerSecretHandlerRequest struct {
  28. // Name of the env group to create or update
  29. Name string `json:"name"`
  30. // Doppler ServiceToken. Assigned per environment on Doppler.
  31. ServiceToken string `json:"service_token"`
  32. }
  33. type CreateDopplerSecretHandlerResponse struct {
  34. // Name of the env group to create or update
  35. Name string `json:"name"`
  36. }
  37. func (c *CreateDopplerSecretHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  38. ctx, span := telemetry.NewSpan(r.Context(), "serve-create-doppler-secret")
  39. defer span.End()
  40. request := &CreateDopplerSecretHandlerRequest{}
  41. if ok := c.DecodeAndValidate(w, r, request); !ok {
  42. return
  43. }
  44. cluster, _ := ctx.Value(types.ClusterScope).(*models.Cluster)
  45. telemetry.WithAttributes(span,
  46. telemetry.AttributeKV{Key: "doppler-group-name", Value: request.Name},
  47. )
  48. agent, err := c.GetAgent(r, cluster, "")
  49. if err != nil {
  50. err := telemetry.Error(ctx, span, err, "unable to connect to kubernetes cluster")
  51. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  52. return
  53. }
  54. data := map[string]string{
  55. "serviceToken": request.ServiceToken,
  56. }
  57. secretData := EncodeSecrets(data)
  58. // create secret first
  59. if _, err := agent.CreateSecret(request.Name, "default", secretData); err != nil {
  60. err := telemetry.Error(ctx, span, err, "unable to create secret")
  61. c.HandleAPIError(w, r, apierrors.NewErrPassThroughToClient(err, http.StatusInternalServerError))
  62. return
  63. }
  64. // Install Doppler CRD
  65. dopplerSecretResponse := &CreateDopplerSecretHandlerResponse{
  66. Name: request.Name,
  67. }
  68. c.WriteResult(w, r, dopplerSecretResponse)
  69. }
  70. func EncodeSecrets(data map[string]string) map[string][]byte {
  71. res := make(map[string][]byte)
  72. for key, rawValue := range data {
  73. res[key] = []byte(rawValue)
  74. }
  75. return res
  76. }