user.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. package service
  2. import (
  3. "context"
  4. v1 "github.com/go-nunu/nunu-layout-advanced/api/v1"
  5. "github.com/go-nunu/nunu-layout-advanced/internal/model"
  6. "github.com/go-nunu/nunu-layout-advanced/internal/repository"
  7. "golang.org/x/crypto/bcrypt"
  8. "time"
  9. )
  10. type UserService interface {
  11. Register(ctx context.Context, req *v1.RegisterRequest) error
  12. Login(ctx context.Context, req *v1.LoginRequest) (string, error)
  13. GetProfile(ctx context.Context, userId string) (*v1.GetProfileResponseData, error)
  14. UpdateProfile(ctx context.Context, userId string, req *v1.UpdateProfileRequest) error
  15. }
  16. func NewUserService(
  17. service *Service,
  18. userRepo repository.UserRepository,
  19. ) UserService {
  20. return &userService{
  21. userRepo: userRepo,
  22. Service: service,
  23. }
  24. }
  25. type userService struct {
  26. userRepo repository.UserRepository
  27. *Service
  28. }
  29. func (s *userService) Register(ctx context.Context, req *v1.RegisterRequest) error {
  30. // check username
  31. user, err := s.userRepo.GetByEmail(ctx, req.Email)
  32. if err != nil {
  33. return v1.ErrInternalServerError
  34. }
  35. if err == nil && user != nil {
  36. return v1.ErrEmailAlreadyUse
  37. }
  38. hashedPassword, err := bcrypt.GenerateFromPassword([]byte(req.Password), bcrypt.DefaultCost)
  39. if err != nil {
  40. return err
  41. }
  42. // Generate user ID
  43. userId, err := s.sid.GenString()
  44. if err != nil {
  45. return err
  46. }
  47. user = &model.User{
  48. UserId: userId,
  49. Email: req.Email,
  50. Password: string(hashedPassword),
  51. }
  52. // Transaction demo
  53. err = s.tm.Transaction(ctx, func(ctx context.Context) error {
  54. // Create a user
  55. if err = s.userRepo.Create(ctx, user); err != nil {
  56. return err
  57. }
  58. // TODO: other repo
  59. return nil
  60. })
  61. return err
  62. }
  63. func (s *userService) Login(ctx context.Context, req *v1.LoginRequest) (string, error) {
  64. user, err := s.userRepo.GetByEmail(ctx, req.Email)
  65. if err != nil || user == nil {
  66. return "", v1.ErrUnauthorized
  67. }
  68. err = bcrypt.CompareHashAndPassword([]byte(user.Password), []byte(req.Password))
  69. if err != nil {
  70. return "", err
  71. }
  72. token, err := s.jwt.GenToken(user.UserId, time.Now().Add(time.Hour*24*90))
  73. if err != nil {
  74. return "", err
  75. }
  76. return token, nil
  77. }
  78. func (s *userService) GetProfile(ctx context.Context, userId string) (*v1.GetProfileResponseData, error) {
  79. user, err := s.userRepo.GetByID(ctx, userId)
  80. if err != nil {
  81. return nil, err
  82. }
  83. return &v1.GetProfileResponseData{
  84. UserId: user.UserId,
  85. Nickname: user.Nickname,
  86. }, nil
  87. }
  88. func (s *userService) UpdateProfile(ctx context.Context, userId string, req *v1.UpdateProfileRequest) error {
  89. user, err := s.userRepo.GetByID(ctx, userId)
  90. if err != nil {
  91. return err
  92. }
  93. user.Email = req.Email
  94. user.Nickname = req.Nickname
  95. if err = s.userRepo.Update(ctx, user); err != nil {
  96. return err
  97. }
  98. return nil
  99. }