user.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  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. }
  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. // DeleteUserForm represents the accepted values for deleting a user
  49. type DeleteUserForm struct {
  50. WriteUserForm
  51. ID uint `form:"required"`
  52. Password string `json:"password" form:"required,max=255"`
  53. }
  54. // ToUser converts a DeleteUserForm to models.User using the user ID
  55. func (uuf *DeleteUserForm) ToUser(_ repository.UserRepository) (*models.User, error) {
  56. return &models.User{
  57. Model: gorm.Model{
  58. ID: uuf.ID,
  59. },
  60. }, nil
  61. }
  62. // InitiateResetUserPasswordForm represents the accepted values for resetting a user's password
  63. type InitiateResetUserPasswordForm struct {
  64. Email string `json:"email" form:"required"`
  65. }
  66. func (ruf *InitiateResetUserPasswordForm) ToPWResetToken() (*models.PWResetToken, string, error) {
  67. expiry := time.Now().Add(30 * time.Minute)
  68. rawToken := stringWithCharset(32, randCharset)
  69. hashedToken, err := bcrypt.GenerateFromPassword([]byte(rawToken), 8)
  70. if err != nil {
  71. return nil, "", err
  72. }
  73. return &models.PWResetToken{
  74. Email: ruf.Email,
  75. IsValid: true,
  76. Expiry: &expiry,
  77. Token: string(hashedToken),
  78. }, rawToken, nil
  79. }
  80. type VerifyResetUserPasswordForm struct {
  81. Email string `json:"email" form:"required,max=255,email"`
  82. PWResetTokenID uint `json:"token_id" form:"required"`
  83. Token string `json:"token" form:"required"`
  84. }
  85. type FinalizeResetUserPasswordForm struct {
  86. Email string `json:"email" form:"required,max=255,email"`
  87. PWResetTokenID uint `json:"token_id" form:"required"`
  88. Token string `json:"token" form:"required"`
  89. NewPassword string `json:"new_password" form:"required,max=255"`
  90. }
  91. type FinalizeVerifyEmailForm struct {
  92. TokenID uint `json:"token_id" form:"required"`
  93. Token string `json:"token" form:"required"`
  94. }