/** * @param Form $form */ public function configure(Form $form) { $form->addHidden('provider')->setValue($this->provider); $form['parameters'] = $this->securityManager->getLoginProviderByName($this->provider)->getFormContainer(); $form->addSaveButton('Sign in')->getControlPrototype()->class[] = 'btn-primary'; $form->addSubmit('cancel', 'Cancel')->setValidationScope(FALSE); }
public function handleConnect($service, $parameters = NULL) { $login = $this->securityManager->getLoginProviderByName($service); if ($parameters) { $login->setAuthenticationParameters(json_decode($parameters, TRUE)); } $login->connectWithUser($this->extendedUser->getUser()); $this->redirect('this', array('provider' => NULL, 'loginTable-id' => NULL, 'loginTable-formName' => NULL)); }
private function authenticate($provider, $parameters = NULL) { $login = $this->securityManager->getLoginProviderByName($provider); try { if ($parameters) { $login->setAuthenticationParameters($parameters); } $identity = $login->authenticate(array()); $this->presenter->user->login($identity); } catch (AuthenticationException $e) { $this->onError($this, $e->getMessage()); } $this->redirect('this'); }
public function handleLoad($name) { /** @var $loginProvider \CmsModule\Security\ILoginProvider */ $loginProvider = $this->securityManager->getLoginProviderByName($name); $identity = NULL; try { $identity = $loginProvider->authenticate(array()); } catch (AuthenticationException $e) { } if ($identity) { $this->onError($this, 'The user is already registered'); } $this->authorizatorFactory->clearPermissionSession(); $formFactory = $this->securityManager->getUserTypeByClass($this->userType)->getRegistrationFormFactory(); if (!$formFactory instanceof IRegistrationFormFactory) { throw new InvalidArgumentException("Form factory '" . get_class($formFactory) . "' is not istance of \\CmsModule\\Content\\IRegistrationFormFactory"); } $formFactory->connectWithLoginProvider($this['form'], $loginProvider); /** @var $form \Venne\Forms\Form */ $form = $this['form']; $form->onSuccess = NULL; if ($this->loginProviderMode === 'load&save') { $form->setSubmittedBy($form->getSaveButton()); $form->fireEvents(); if ($form->isValid()) { $loginProvider->connectWithUser($form->getData()->user); $identity = $loginProvider->authenticate(array()); if ($identity) { $this->presenter->user->login($identity); $this->redirect('this'); } } } else { if ($this->loginProviderMode === 'load') { $this->onLoad($this); } } }