package user import ( "Yimaru-Backend/internal/domain" "context" ) func (s *Service) UpdateUserKnowledgeLevel(ctx context.Context, userID int64, knowledgeLevel string) error { return s.userStore.UpdateUserKnowledgeLevel(ctx, userID, knowledgeLevel) } func (s *Service) CreateUser( ctx context.Context, req domain.CreateUserReq, isCompany bool, ) (domain.User, error) { // Hash the password hashedPassword, err := hashPassword(req.Password) if err != nil { return domain.User{}, err } // Create the user return s.userStore.CreateUserWithoutOtp(ctx, domain.User{ FirstName: req.FirstName, LastName: req.LastName, UserName: req.UserName, Email: req.Email, PhoneNumber: req.PhoneNumber, Password: hashedPassword, Role: domain.Role(req.Role), EmailVerified: true, // assuming auto-verified on creation PhoneVerified: true, Status: domain.UserStatusActive, Age: req.Age, EducationLevel: req.EducationLevel, Country: req.Country, Region: req.Region, ProfileCompleted: false, }) } func (s *Service) DeleteUser(ctx context.Context, id int64) error { // Delete User return s.userStore.DeleteUser(ctx, id) } func (s *Service) GetAllUsers(ctx context.Context, filter domain.UserFilter) ([]domain.User, int64, error) { // Get all Users return s.userStore.GetAllUsers(ctx, &filter.Role, &filter.Query.Value, &filter.CreatedBefore.Value, &filter.CreatedAfter.Value, int32(filter.PageSize.Value), int32(filter.Page.Value)) } func (s *Service) GetUserById(ctx context.Context, id int64) (domain.User, error) { return s.userStore.GetUserByID(ctx, id) }