/** * @param \Application\Controller\AbstractActionController $controller * @return bool */ public function validate($controller, $lang) { $entityManager = $controller->getEntityManager(); $translator = $controller->getTranslator(); $data = $this->getData(); $email = $data['email']; $password = $data['password']; $user = $entityManager->getRepository('\\User\\Entity\\User')->findOneBy(array('email' => $email)); if ($user && $user->checkPassword($password)) { if ($user->isActivated()) { $user->authenticate(); $user->lastLogin($entityManager); return true; } else { if ($user->getLastLogin() == null) { $msg = $translator->translate('You must confirm your email to be able to login'); $controller->flashMessenger()->addErrorMessage($msg); $controller->redirect()->toUrl('/' . $lang . "/user/register/confirm?email=" . $email . '&type=needConfirm'); return false; } else { $msg = $translator->translate('Your account has been blocked, Please contact your Admin'); $controller->flashMessenger()->addErrorMessage($msg); $controller->redirect()->toUrl('/' . $lang . "/user/register/confirm?email=" . $email . '&type=accBlook'); return false; } } } else { $this->addNonElementMessage('danger', $translator->translate('Wrong username or password')); } return False; }
/** * @param \Application\Controller\AbstractActionController $controller * @param $type * @param $sendTo * @param $variables */ public static function sendMail($controller, $type, $sendTo, $variables) { $entityManager = $controller->getEntityManager(); /** * @var $templateType \Admin\Entity\TemplateType */ $templateType = $entityManager->getRepository('Admin\\Entity\\TemplateType')->findOneBy(array('code' => $type)); /** * @var $emailTemplate \Admin\Entity\EmailTemplates */ $emailTemplate = $entityManager->getRepository('Admin\\Entity\\EmailTemplates')->findOneBy(array('type' => $templateType, 'language' => 0)); if (!$emailTemplate) { throw new \Exception("Missing email template for type {$type}"); } $emailTemplate->send($controller, $sendTo, $variables); }
/** * @param \Application\Controller\AbstractActionController $controller */ function process($controller) { $entityManager = $controller->getEntityManager(); $email = $this->getData()['email']; $user = $controller->getUser(array('email' => $email)); if ($user) { $user->generateToken(); $entityManager->persist($user); $entityManager->flush(); $lang_code = $controller->params()->fromRoute('lang'); $user->sendForgotPasswordEmail($controller, $lang_code); return true; } else { return false; } }
/** * @param \Application\Controller\AbstractActionController $controller * @param $userType */ public function save($controller, $data, $userType, $lang_code = '') { /** * @var $user \User\Entity\User */ $user = $this->getObject(); $entityManager = $controller->getEntityManager(); $data = (array) $data; $data['createdTime'] = new \DateTime('now'); //$data['lastLogin'] = new \DateTime('now'); $user->setData($data); $user->setGroupByName($userType, $entityManager); // Create password hash $user->encodePassword(); $user->generateToken(); $user->save($entityManager); if ($userType == 'freelancer') { $user->createFreelancer($controller, $data, $entityManager, $lang_code); } else { //$data['contracted'] = 0; $user->createEmployer($controller, $data, $entityManager, $lang_code); } //$user->sendConfirmationEmail($controller); }