diff --git a/app/presenters/SignPresenter.php b/app/presenters/SignPresenter.php index 9e0b84bba..55351f5c0 100644 --- a/app/presenters/SignPresenter.php +++ b/app/presenters/SignPresenter.php @@ -1,194 +1,211 @@ -signInFactory->create(function (Form $form, $values) { - try { - $this->tapiAuthenticator->setTapiService($this->tapiService); - $this->user->setExpiration('20 minutes'); - $r = $this->user->login($values->name, $values->password); - } catch (APIException $exc) { - switch ($exc->getMessage()) { - case "Login not approved": - $this->flashMessage($this->translator->translate("common.alerts.loginNotApproved"), "danger"); - break; - default: - $this->flashMessage($this->translator->translate("common.alerts.loginNotSuccesfull") . ' (' . $exc->getMessage() . ")", "danger"); - break; - } - } - if(!is_null($this->user->getIdentity())) - Debugger::log($this->user->getIdentity()->data["callName"] . "@" . $this->supplier->getTym () . " logged in"); - $this->redirect('Homepage:'); - }); - - return $form; - } - - /** - * Sign-up form factory. - * @return Nette\Application\UI\Form - */ - protected function createComponentSignUpForm() { - return $this->signUpFactory->create(function () { - $this->flashMessage($this->translator->translate("common.alerts.registrationSuccesfull"), 'success'); - $this->redirect('Sign:In'); - }); - } - - /** - * PWD Lost form factory. - * @return Nette\Application\UI\Form - */ - protected function createComponentPwdLostForm() { - $form = $this->pwdLostFactory->create(); - $form->onSuccess[] = function (Nette\Application\UI\Form $form, stdClass $values) { - try { - $this->pwdLost->init() - ->setCallbackUri($this->link('//Sign:pwdreset') . "?code=%2s") - ->setHostname($this->getHttpRequest()->getRemoteHost()) - ->setMail($values->email) - ->getData(); - } catch (APIException $ex) { - $this->flashMessage($this->translator->translate("common.alerts.userNotFound")); - $this->redirect('Sign:pwdlost'); - } - - $this->flashMessage($this->translator->translate("common.alerts.resetCodeSent")); - - $this->redirect('Sign:pwdreset'); - }; - return $form; - } - - /** - * PWD Reset form factory. - * @return Nette\Application\UI\Form - */ - protected function createComponentPwdResetForm() { - $form = $this->pwdResetFactory->create(); - $form->onSuccess[] = function (Nette\Application\UI\Form $form, stdClass $values) { - $data = $this->resetPwd($values->code); - $this->flashMessage($this->translator->translate("common.alerts.resetCodeSent")); - $this->redirect('Sign:pwdnew', ["pwd" => $data]); - }; - return $form; - } - - public function actionOut() { - if (!is_null($this->getUser()->getIdentity())) { - $this->logout->init()->perform(); - $this->getUser()->logout(); - } - $this->flashMessage($this->translator->translate("common.alerts.logoutSuccesfull")); - $this->redirect('Sign:In'); - } - - public function renderPwdNew() { - $this->template->pwdNew = $this->getRequest()->getParameter("pwd"); - } - - public function renderPwdReset() { - if(($resetCode = $this->getRequest()->getParameter("code")) != null){ - $data = $this->resetPwd($resetCode); - $this->flashMessage($this->translator->translate("common.alerts.pwdResetSuccesfull")); - $this->redirect('Sign:pwdnew', ["pwd" => $data]); - } - } - - public function renderIn() { - $this->template->multiple = $this->supplier->getTapi_config()["multiple_team"]; - $is = $this->is->getData(); - $this->template->teamName = strtoupper($is->teamName); - $this->translator->setLocale(self::LOCALES[$is->defaultLanguageCode]); - - if ($tk = $this->getRequest()->getParameter("tk")) { - try { - $this->tapiAuthenticator->setTapiService($this->tapiService); - $this->tkLogin($tk); - } catch (APIException $exc) { - switch ($exc->getMessage()) { - case "Login not approved": - $this->flashMessage($this->translator->translate("common.alerts.loginNotApproved"), "danger"); - break; - default: - $this->flashMessage($this->translator->translate("common.alerts.loginNotSuccesfull") . ' (' . $exc->getMessage() . ")", "danger"); - break; - } - } - if (!is_null($this->user->getIdentity())) - Debugger::log($this->user->getIdentity()->data["callName"] . "@" . $this->supplier->getTym() . " logged in using transfer key"); - $this->redirect('Homepage:'); - } - } - - private function tkLogin($tk){ - $this->user->logout(true); - $this->user->login($this->tapiAuthenticator->tkAuthenticate($tk)); - } - - private function resetPwd($code){ - return $this->pwdReset->init() - ->setCode($code) - ->getData(); - } - -} +signInFactory->create(function (Form $form, $values) { + try { + $this->tapiAuthenticator->setTapiService($this->tapiService); + $this->user->setExpiration('20 minutes'); + $r = $this->user->login($values->name, $values->password); + } catch (APIException $exc) { + switch ($exc->getMessage()) { + case "Login not approved": + $this->flashMessage($this->translator->translate("common.alerts.loginNotApproved"), "danger"); + break; + default: + $this->flashMessage($this->translator->translate("common.alerts.loginNotSuccesfull") . ' (' . $exc->getMessage() . ")", "danger"); + break; + } + } + if(!is_null($this->user->getIdentity())) + Debugger::log($this->user->getIdentity()->data["callName"] . "@" . $this->supplier->getTym () . " logged in"); + $this->redirect('Homepage:'); + }); + + return $form; + } + + /** + * Sign-up form factory. + * @return Nette\Application\UI\Form + */ + protected function createComponentSignUpForm() { + return $this->signUpFactory->create(function () { + $this->flashMessage($this->translator->translate("common.alerts.registrationSuccesfull"), 'success'); + $this->redirect('Sign:In'); + }); + } + + /** + * PWD Lost form factory. + * @return Nette\Application\UI\Form + */ + protected function createComponentPwdLostForm() { + $form = $this->pwdLostFactory->create(); + $form->onSuccess[] = function (Nette\Application\UI\Form $form, stdClass $values) { + try { + $this->pwdLost->init() + ->setCallbackUri($this->link('//Sign:pwdreset') . "?code=%2s") + ->setHostname($this->getHttpRequest()->getRemoteHost()) + ->setMail($values->email) + ->getData(); + } catch (APIException $ex) { + $this->flashMessage($this->translator->translate("common.alerts.userNotFound")); + $this->redirect('Sign:pwdlost'); + } + + $this->flashMessage($this->translator->translate("common.alerts.resetCodeSent")); + + $this->redirect('Sign:pwdreset'); + }; + return $form; + } + + /** + * PWD Reset form factory. + * @return Nette\Application\UI\Form + */ + protected function createComponentPwdResetForm() { + $form = $this->pwdResetFactory->create(); + $form->onSuccess[] = function (Nette\Application\UI\Form $form, stdClass $values) { + $data = $this->resetPwd($values->code); + $this->flashMessage($this->translator->translate("common.alerts.resetCodeSent")); + $this->redirect('Sign:pwdnew', ["pwd" => $data]); + }; + return $form; + } + + public function actionOut() { + if (!is_null($this->getUser()->getIdentity())) { + $this->logout->init()->perform(); + $this->getUser()->logout(); + } + $this->flashMessage($this->translator->translate("common.alerts.logoutSuccesfull")); + $this->redirect('Sign:In'); + } + + public function renderPwdNew() { + $this->template->pwdNew = $this->getRequest()->getParameter("pwd"); + } + + public function renderPwdReset() { + if(($resetCode = $this->getRequest()->getParameter("code")) != null){ + $data = $this->resetPwd($resetCode); + $this->flashMessage($this->translator->translate("common.alerts.pwdResetSuccesfull")); + $this->redirect('Sign:pwdnew', ["pwd" => $data]); + } + } + + public function renderIn() { + $this->template->multiple = $this->supplier->getTapi_config()["multiple_team"]; + $this->template->forbidden = FALSE; + + try { + $is = $this->is->getData(); + } catch (APIException $exc) { + switch ($exc->getMessage()) { + case "API disabled": + $this->template->teamName = strtoupper($this->supplier->getTym()); + $this->template->forbidden = TRUE; + break; + default: + throw $exc; + } + return FALSE; + } + + + + $this->template->teamName = strtoupper($is->teamName); + $this->translator->setLocale(self::LOCALES[$is->defaultLanguageCode]); + + if ($tk = $this->getRequest()->getParameter("tk")) { + try { + $this->tapiAuthenticator->setTapiService($this->tapiService); + $this->tkLogin($tk); + } catch (APIException $exc) { + switch ($exc->getMessage()) { + case "Login not approved": + $this->flashMessage($this->translator->translate("common.alerts.loginNotApproved"), "danger"); + break; + default: + $this->flashMessage($this->translator->translate("common.alerts.loginNotSuccesfull") . ' (' . $exc->getMessage() . ")", "danger"); + break; + } + } + if (!is_null($this->user->getIdentity())) + Debugger::log($this->user->getIdentity()->data["callName"] . "@" . $this->supplier->getTym() . " logged in using transfer key"); + $this->redirect('Homepage:'); + } + } + + private function tkLogin($tk){ + $this->user->logout(true); + $this->user->login($this->tapiAuthenticator->tkAuthenticate($tk)); + } + + private function resetPwd($code){ + return $this->pwdReset->init() + ->setCode($code) + ->getData(); + } + +} diff --git a/app/presenters/templates/Sign/in.latte b/app/presenters/templates/Sign/in.latte index 6325563a4..0e00a410f 100644 --- a/app/presenters/templates/Sign/in.latte +++ b/app/presenters/templates/Sign/in.latte @@ -1,29 +1,41 @@ -{import '../components/unsecured.latte'} -{var $title = 'Login'} -{block content} -