package sql import ( "context" "errors" "gorm.io/gorm" "tercul/internal/domain" ) type userRepository struct { domain.BaseRepository[domain.User] db *gorm.DB } // NewUserRepository creates a new UserRepository. func NewUserRepository(db *gorm.DB) domain.UserRepository { return &userRepository{ BaseRepository: NewBaseRepositoryImpl[domain.User](db), db: db, } } // FindByUsername finds a user by username func (r *userRepository) FindByUsername(ctx context.Context, username string) (*domain.User, error) { var user domain.User if err := r.db.WithContext(ctx).Where("username = ?", username).First(&user).Error; err != nil { if errors.Is(err, gorm.ErrRecordNotFound) { return nil, ErrEntityNotFound } return nil, err } return &user, nil } // FindByEmail finds a user by email func (r *userRepository) FindByEmail(ctx context.Context, email string) (*domain.User, error) { var user domain.User if err := r.db.WithContext(ctx).Where("email = ?", email).First(&user).Error; err != nil { if errors.Is(err, gorm.ErrRecordNotFound) { return nil, ErrEntityNotFound } return nil, err } return &user, nil } // ListByRole lists users by role func (r *userRepository) ListByRole(ctx context.Context, role domain.UserRole) ([]domain.User, error) { var users []domain.User if err := r.db.WithContext(ctx).Where("role = ?", role).Find(&users).Error; err != nil { return nil, err } return users, nil }