create_configmap.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package namespace
  2. import (
  3. "fmt"
  4. "net/http"
  5. v1 "k8s.io/api/core/v1"
  6. "github.com/porter-dev/porter/api/server/authz"
  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/kubernetes"
  13. "github.com/porter-dev/porter/internal/models"
  14. )
  15. type CreateConfigMapHandler struct {
  16. handlers.PorterHandlerReadWriter
  17. authz.KubernetesAgentGetter
  18. }
  19. func NewCreateConfigMapHandler(
  20. config *config.Config,
  21. decoderValidator shared.RequestDecoderValidator,
  22. writer shared.ResultWriter,
  23. ) *CreateConfigMapHandler {
  24. return &CreateConfigMapHandler{
  25. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  26. KubernetesAgentGetter: authz.NewOutOfClusterAgentGetter(config),
  27. }
  28. }
  29. func (c *CreateConfigMapHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  30. request := &types.CreateConfigMapRequest{}
  31. if ok := c.DecodeAndValidate(w, r, request); !ok {
  32. return
  33. }
  34. namespace := r.Context().Value(types.NamespaceScope).(string)
  35. cluster, _ := r.Context().Value(types.ClusterScope).(*models.Cluster)
  36. agent, err := c.GetAgent(r, cluster)
  37. if err != nil {
  38. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  39. return
  40. }
  41. configMap, err := createConfigMap(agent, namespace, request)
  42. if err != nil {
  43. c.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  44. return
  45. }
  46. var res = types.CreateConfigMapResponse{
  47. ConfigMap: configMap,
  48. }
  49. c.WriteResult(w, r, res)
  50. }
  51. func createConfigMap(agent *kubernetes.Agent, namespace string, request *types.CreateConfigMapRequest) (*v1.ConfigMap, error) {
  52. secretData := make(map[string][]byte)
  53. for key, rawValue := range request.SecretVariables {
  54. // encodedValue := base64.StdEncoding.EncodeToString([]byte(rawValue))
  55. // if err != nil {
  56. // app.handleErrorInternal(err, w)
  57. // return
  58. // }
  59. secretData[key] = []byte(rawValue)
  60. }
  61. // create secret first
  62. if _, err := agent.CreateLinkedSecret(request.Name, namespace, request.Name, secretData); err != nil {
  63. return nil, err
  64. }
  65. // add all secret env variables to configmap with value PORTERSECRET_${configmap_name}
  66. for key := range request.SecretVariables {
  67. request.Variables[key] = fmt.Sprintf("PORTERSECRET_%s", request.Name)
  68. }
  69. return agent.CreateConfigMap(request.Name, namespace, request.Variables)
  70. }