user.go 2.9 KB

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