| | <?php |
| |
|
| | namespace Kanboard\Controller; |
| |
|
| | use Kanboard\Core\Security\OAuthAuthenticationProviderInterface; |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | class OAuthController extends BaseController |
| | { |
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function step1($provider) |
| | { |
| | $code = $this->request->getStringParam('code'); |
| | $state = $this->request->getStringParam('state'); |
| |
|
| | if (! empty($code)) { |
| | $this->step2($provider, $code, $state); |
| | } else { |
| | $this->response->redirect($this->authenticationManager->getProvider($provider)->getService()->getAuthorizationUrl()); |
| | } |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function step2($providerName, $code, $state) |
| | { |
| | $provider = $this->authenticationManager->getProvider($providerName); |
| | $provider->setCode($code); |
| | $hasValidState = $provider->getService()->isValidateState($state); |
| |
|
| | if ($this->userSession->isLogged()) { |
| | if ($hasValidState) { |
| | $this->link($provider); |
| | } else { |
| | $this->flash->failure(t('The OAuth2 state parameter is invalid')); |
| | $this->response->redirect($this->helper->url->to('UserViewController', 'external', array('user_id' => $this->userSession->getId()))); |
| | } |
| | } else { |
| | if ($hasValidState) { |
| | $this->authenticate($providerName); |
| | } else { |
| | $this->authenticationFailure(t('The OAuth2 state parameter is invalid')); |
| | } |
| | } |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function link(OAuthAuthenticationProviderInterface $provider) |
| | { |
| | if (! $provider->authenticate()) { |
| | $this->flash->failure(t('External authentication failed')); |
| | } else { |
| | $this->userProfile->assign($this->userSession->getId(), $provider->getUser()); |
| | $this->flash->success(t('Your external account is linked to your profile successfully.')); |
| | } |
| |
|
| | $this->response->redirect($this->helper->url->to('UserViewController', 'external', array('user_id' => $this->userSession->getId()))); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | public function unlink() |
| | { |
| | $backend = $this->request->getStringParam('backend'); |
| | $this->checkCSRFParam(); |
| |
|
| | if ($this->authenticationManager->getProvider($backend)->unlink($this->userSession->getId())) { |
| | $this->flash->success(t('Your external account is not linked anymore to your profile.')); |
| | } else { |
| | $this->flash->failure(t('Unable to unlink your external account.')); |
| | } |
| |
|
| | $this->response->redirect($this->helper->url->to('UserViewController', 'external', array('user_id' => $this->userSession->getId()))); |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function authenticate($providerName) |
| | { |
| | if ($this->authenticationManager->oauthAuthentication($providerName)) { |
| | $this->redirectAfterLogin(); |
| | } else { |
| | $this->authenticationFailure(t('External authentication failed')); |
| | } |
| | } |
| |
|
| | |
| | |
| | |
| | |
| | |
| | |
| | protected function authenticationFailure($message) |
| | { |
| | $this->response->html($this->helper->layout->app('auth/index', array( |
| | 'errors' => array('login' => $message), |
| | 'values' => array(), |
| | 'no_layout' => true, |
| | 'title' => t('Login') |
| | ))); |
| | } |
| | } |
| |
|