users.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. package dbstore
  2. import (
  3. "context"
  4. "fmt"
  5. "git.linuxforward.com/byop/byop-engine/models"
  6. "golang.org/x/crypto/bcrypt"
  7. "gorm.io/gorm"
  8. )
  9. // CreateUser creates a new user using GORM
  10. func (s *SQLiteStore) CreateUser(ctx context.Context, user *models.User) error {
  11. result := s.db.WithContext(ctx).Create(user)
  12. if result.Error != nil {
  13. return fmt.Errorf("failed to create user: %w", result.Error)
  14. }
  15. return nil
  16. }
  17. // GetUserByEmail retrieves a user by email using GORM
  18. func (s *SQLiteStore) GetUserByEmail(ctx context.Context, email string) (*models.User, error) {
  19. var user models.User
  20. result := s.db.WithContext(ctx).Where("email = ?", email).First(&user)
  21. if result.Error != nil {
  22. if result.Error == gorm.ErrRecordNotFound {
  23. return nil, models.NewErrNotFound(fmt.Sprintf("user with email %s not found", email), result.Error)
  24. }
  25. return nil, fmt.Errorf("failed to get user by email: %w", result.Error)
  26. }
  27. return &user, nil
  28. }
  29. // GetUsers retrieves all users using GORM
  30. func (s *SQLiteStore) GetUsers(ctx context.Context) ([]*models.User, error) {
  31. var users []*models.User
  32. result := s.db.WithContext(ctx).Find(&users)
  33. if result.Error != nil {
  34. return nil, fmt.Errorf("failed to get users: %w", result.Error)
  35. }
  36. return users, nil
  37. }
  38. // GetUserByID retrieves a user by ID using GORM
  39. func (s *SQLiteStore) GetUserByID(ctx context.Context, id uint) (*models.User, error) {
  40. var user models.User
  41. result := s.db.WithContext(ctx).First(&user, id)
  42. if result.Error != nil {
  43. if result.Error == gorm.ErrRecordNotFound {
  44. return nil, models.NewErrNotFound(fmt.Sprintf("user with ID %d not found", id), result.Error)
  45. }
  46. return nil, fmt.Errorf("failed to get user by ID: %w", result.Error)
  47. }
  48. return &user, nil
  49. }
  50. // GetByUsername retrieves a user by username (assuming username is email)
  51. func (s *SQLiteStore) GetByUsername(ctx context.Context, username string) (*models.User, error) {
  52. return s.GetUserByEmail(ctx, username)
  53. }
  54. // UpdateUser updates an existing user using GORM
  55. func (s *SQLiteStore) UpdateUser(ctx context.Context, user *models.User) error {
  56. result := s.db.WithContext(ctx).Save(user)
  57. if result.Error != nil {
  58. return fmt.Errorf("failed to update user: %w", result.Error)
  59. }
  60. if result.RowsAffected == 0 {
  61. return models.NewErrNotFound(fmt.Sprintf("user with ID %d not found for update", user.ID), nil)
  62. }
  63. return nil
  64. }
  65. // CreateDefaultAdmin creates a default admin user if none exists
  66. func (s *SQLiteStore) CreateDefaultAdmin(ctx context.Context) error {
  67. _, err := s.GetUserByEmail(ctx, "admin@byop.local")
  68. if err == nil {
  69. // Admin user already exists
  70. return nil
  71. }
  72. if !models.IsErrNotFound(err) {
  73. return err
  74. }
  75. hashedPassword, hashErr := bcrypt.GenerateFromPassword([]byte("admin123"), bcrypt.DefaultCost)
  76. if hashErr != nil {
  77. return hashErr
  78. }
  79. admin := &models.User{
  80. Email: "admin@byop.local",
  81. Password: string(hashedPassword),
  82. Name: "Administrator",
  83. Role: "admin",
  84. Active: true,
  85. }
  86. return s.CreateUser(ctx, admin)
  87. }
  88. // DeleteUser deletes a user by ID using GORM
  89. func (s *SQLiteStore) DeleteUser(ctx context.Context, id uint) error {
  90. result := s.db.WithContext(ctx).Delete(&models.User{}, id)
  91. if result.Error != nil {
  92. return fmt.Errorf("failed to delete user: %w", result.Error)
  93. }
  94. if result.RowsAffected == 0 {
  95. return models.NewErrNotFound(fmt.Sprintf("user with ID %d not found for deletion", id), nil)
  96. }
  97. return nil
  98. }