user.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. package forms
  2. import (
  3. "time"
  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. // ignore this field from the json
  19. EmailVerified bool `json:"-"`
  20. }
  21. // ToUser converts a CreateUserForm to models.User
  22. func (cuf *CreateUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  23. hashed, err := bcrypt.GenerateFromPassword([]byte(cuf.Password), 8)
  24. if err != nil {
  25. return nil, err
  26. }
  27. return &models.User{
  28. Email: cuf.Email,
  29. Password: string(hashed),
  30. EmailVerified: cuf.EmailVerified,
  31. }, nil
  32. }
  33. // LoginUserForm represents the accepted values for logging a user in
  34. type LoginUserForm struct {
  35. WriteUserForm
  36. ID uint `form:"required"`
  37. Email string `json:"email" form:"required,max=255,email"`
  38. Password string `json:"password" form:"required,max=255"`
  39. }
  40. // ToUser converts a LoginUserForm to models.User
  41. func (luf *LoginUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  42. hashed, err := bcrypt.GenerateFromPassword([]byte(luf.Password), 8)
  43. if err != nil {
  44. return nil, err
  45. }
  46. return &models.User{
  47. Email: luf.Email,
  48. Password: string(hashed),
  49. }, nil
  50. }
  51. // DeleteUserForm represents the accepted values for deleting a user
  52. type DeleteUserForm struct {
  53. WriteUserForm
  54. ID uint `form:"required"`
  55. Password string `json:"password" form:"required,max=255"`
  56. }
  57. // ToUser converts a DeleteUserForm to models.User using the user ID
  58. func (uuf *DeleteUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  59. return &models.User{
  60. Model: gorm.Model{
  61. ID: uuf.ID,
  62. },
  63. }, nil
  64. }
  65. // InitiateResetUserPasswordForm represents the accepted values for resetting a user's password
  66. type InitiateResetUserPasswordForm struct {
  67. Email string `json:"email" form:"required"`
  68. }
  69. func (ruf *InitiateResetUserPasswordForm) ToPWResetToken() (*models.PWResetToken, string, error) {
  70. expiry := time.Now().Add(30 * time.Minute)
  71. rawToken := stringWithCharset(32, randCharset)
  72. hashedToken, err := bcrypt.GenerateFromPassword([]byte(rawToken), 8)
  73. if err != nil {
  74. return nil, "", err
  75. }
  76. return &models.PWResetToken{
  77. Email: ruf.Email,
  78. IsValid: true,
  79. Expiry: &expiry,
  80. Token: string(hashedToken),
  81. }, rawToken, nil
  82. }
  83. type VerifyResetUserPasswordForm struct {
  84. Email string `json:"email" form:"required,max=255,email"`
  85. PWResetTokenID uint `json:"token_id" form:"required"`
  86. Token string `json:"token" form:"required"`
  87. }
  88. type FinalizeResetUserPasswordForm struct {
  89. Email string `json:"email" form:"required,max=255,email"`
  90. PWResetTokenID uint `json:"token_id" form:"required"`
  91. Token string `json:"token" form:"required"`
  92. NewPassword string `json:"new_password" form:"required,max=255"`
  93. }
  94. type FinalizeVerifyEmailForm struct {
  95. TokenID uint `json:"token_id" form:"required"`
  96. Token string `json:"token" form:"required"`
  97. }