/** * Formulář pro registraci uživatele * @return Form */ public function createComponentRegistrationForm() { $form = new Form(); $form->addText('name', 'Jméno a příjmení:')->setRequired('Je nutné zadat jméno.'); $form->addText('email', 'E-mail:')->setRequired('Je nutné zadat e-mail')->addRule(Form::EMAIL, 'Je nutné zadat platnou e-mailovou adresu.')->addRule(function (TextInput $input) { return !$this->usersModel->findByEmail($input->value); }, 'Uživatel s daným e-mailem již existuje.'); $password = $form->addPassword('password', 'Heslo:')->setRequired('Je nutné zadat heslo.')->addRule(Form::MIN_LENGTH, 'Heslo musí mít minumálně 4 znaky.', 4); $form->addPassword('password2', 'Potvrzení hesla:')->addRule(Form::EQUAL, 'Zadaná hesla se neshodují.', $password); $form->addSubmit('ok', 'registrovat se')->onClick[] = function (SubmitButton $button) { //funkce pro vytvoření nového uživatelského účtu a automatick přihlášení uživatele $data = $button->form->getValues(true); $user = new User(); $user->active = true; $user->name = $data['name']; $user->email = $data['email']; $user->password = User::encodePassword($data['password']); $user->role = User::DEFAULT_REGISTERED_ROLE; if ($this->usersModel->save($user)) { $this->flashMessage('Registrace byla úspěšně dokončena.'); $this->usersModel->sendRegistrationMail($user); } $this->user->login($data['email'], $data['password']); $this->redirect('Homepage:default'); }; return $form; }
/** * Funkce pro ověření, jestli má uživatel přístup ke konkrétní části aplikace */ public function hasAccess($controller, $action = '') { //FIXME /** @var UsersModel $usersModel */ $usersModel = UsersModel::getInstance(); /** @var AclModel $aclModel */ $aclModel = AclModel::getInstance(); $user = $usersModel->findById($this->id); if ($user && $user->id != 0) { $role = $user->role; } else { $role = 'guest'; } return $aclModel->isAllowed($role, $controller, $action); }
public function __construct() { parent::__construct(); $this->usersModel = UsersModel::getInstance(); }