user.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. package forms
  2. import (
  3. "github.com/porter-dev/porter/internal/kubernetes"
  4. "github.com/porter-dev/porter/internal/models"
  5. "github.com/porter-dev/porter/internal/repository"
  6. "golang.org/x/crypto/bcrypt"
  7. "gorm.io/gorm"
  8. )
  9. // WriteUserForm is a generic form for write operations to the User model
  10. type WriteUserForm interface {
  11. ToUser(repo repository.UserRepository) (*models.User, error)
  12. }
  13. // CreateUserForm represents the accepted values for creating a user
  14. type CreateUserForm struct {
  15. WriteUserForm
  16. Email string `json:"email" form:"required,max=255,email"`
  17. Password string `json:"password" form:"required,max=255"`
  18. }
  19. // ToUser converts a CreateUserForm to models.User
  20. func (cuf *CreateUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  21. hashed, err := bcrypt.GenerateFromPassword([]byte(cuf.Password), 8)
  22. if err != nil {
  23. return nil, err
  24. }
  25. return &models.User{
  26. Email: cuf.Email,
  27. Password: string(hashed),
  28. }, nil
  29. }
  30. // LoginUserForm represents the accepted values for logging a user in
  31. type LoginUserForm struct {
  32. WriteUserForm
  33. ID uint `form:"required"`
  34. Email string `json:"email" form:"required,max=255,email"`
  35. Password string `json:"password" form:"required,max=255"`
  36. }
  37. // ToUser converts a LoginUserForm to models.User
  38. func (luf *LoginUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  39. hashed, err := bcrypt.GenerateFromPassword([]byte(luf.Password), 8)
  40. if err != nil {
  41. return nil, err
  42. }
  43. return &models.User{
  44. Email: luf.Email,
  45. Password: string(hashed),
  46. }, nil
  47. }
  48. // UpdateUserForm represents the accepted values for updating a user
  49. //
  50. // ID is a query parameter, the other two are sent in JSON body
  51. type UpdateUserForm struct {
  52. WriteUserForm
  53. ID uint `form:"required"`
  54. RawKubeConfig string `json:"rawKubeConfig,omitempty"`
  55. AllowedContexts []string `json:"allowedContexts,omitempty"`
  56. }
  57. // ToUser converts an UpdateUserForm to models.User by parsing the kubeconfig
  58. // and the allowed clusters to generate a list of ClusterConfigs.
  59. func (uuf *UpdateUserForm) ToUser(repo repository.UserRepository) (*models.User, error) {
  60. rawBytes := []byte(uuf.RawKubeConfig)
  61. contexts := uuf.AllowedContexts
  62. savedUser, err := repo.ReadUser(uuf.ID)
  63. if err != nil {
  64. return nil, err
  65. }
  66. // if the rawKubeConfig is empty, query the DB for a non-empty one
  67. if uuf.RawKubeConfig == "" {
  68. rawBytes = savedUser.RawKubeConfig
  69. }
  70. // if the allowedContexts is nil, query the DB for a non-nil one
  71. if uuf.AllowedContexts == nil {
  72. contexts = savedUser.Contexts
  73. }
  74. if len(rawBytes) > 0 {
  75. // validate the kubeconfig
  76. _contexts, err := kubernetes.GetContextsFromBytes(rawBytes, contexts)
  77. if err != nil {
  78. return nil, err
  79. }
  80. contexts = make([]string, 0)
  81. // ensure only joined contexts get written
  82. for _, context := range _contexts {
  83. if context.Selected {
  84. contexts = append(contexts, context.Name)
  85. }
  86. }
  87. }
  88. return &models.User{
  89. Model: gorm.Model{
  90. ID: uuf.ID,
  91. },
  92. Contexts: contexts,
  93. RawKubeConfig: rawBytes,
  94. }, nil
  95. }
  96. // DeleteUserForm represents the accepted values for deleting a user
  97. type DeleteUserForm struct {
  98. WriteUserForm
  99. ID uint `form:"required"`
  100. Password string `json:"password" form:"required,max=255"`
  101. }
  102. // ToUser converts a DeleteUserForm to models.User using the user ID
  103. func (uuf *DeleteUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  104. return &models.User{
  105. Model: gorm.Model{
  106. ID: uuf.ID,
  107. },
  108. }, nil
  109. }