|
@@ -0,0 +1,93 @@
|
|
|
+<?php
|
|
|
+
|
|
|
+/*
|
|
|
+ * This file is part of the FOSUserBundle package.
|
|
|
+ *
|
|
|
+ * (c) FriendsOfSymfony <http://friendsofsymfony.github.com/>
|
|
|
+ *
|
|
|
+ * For the full copyright and license information, please view the LICENSE
|
|
|
+ * file that was distributed with this source code.
|
|
|
+ */
|
|
|
+
|
|
|
+namespace Base\OAuthBundle\Controller;
|
|
|
+
|
|
|
+use Symfony\Bundle\FrameworkBundle\Controller\Controller;
|
|
|
+use Symfony\Component\HttpFoundation\Request;
|
|
|
+use Symfony\Component\HttpFoundation\Response;
|
|
|
+use Symfony\Component\Security\Core\Exception\AuthenticationException;
|
|
|
+use Symfony\Component\Security\Core\Security;
|
|
|
+use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
|
|
|
+
|
|
|
+class SecurityController extends Controller
|
|
|
+{
|
|
|
+ /**
|
|
|
+ * @Route("/oauth/v2/auth/login", name="oauth_login")
|
|
|
+ * @param Request $request
|
|
|
+ *
|
|
|
+ * @return Response
|
|
|
+ */
|
|
|
+ public function loginAction(Request $request)
|
|
|
+ {
|
|
|
+ /** @var $session \Symfony\Component\HttpFoundation\Session\Session */
|
|
|
+ $session = $request->getSession();
|
|
|
+
|
|
|
+ $authErrorKey = Security::AUTHENTICATION_ERROR;
|
|
|
+ $lastUsernameKey = Security::LAST_USERNAME;
|
|
|
+
|
|
|
+ // get the error if any (works with forward and redirect -- see below)
|
|
|
+ if ($request->attributes->has($authErrorKey)) {
|
|
|
+ $error = $request->attributes->get($authErrorKey);
|
|
|
+ } elseif (null !== $session && $session->has($authErrorKey)) {
|
|
|
+ $error = $session->get($authErrorKey);
|
|
|
+ $session->remove($authErrorKey);
|
|
|
+ } else {
|
|
|
+ $error = null;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!$error instanceof AuthenticationException) {
|
|
|
+ $error = null; // The value does not come from the security component.
|
|
|
+ }
|
|
|
+
|
|
|
+ // last username entered by the user
|
|
|
+ $lastUsername = (null === $session) ? '' : $session->get($lastUsernameKey);
|
|
|
+
|
|
|
+ $csrfToken = $this->has('security.csrf.token_manager')
|
|
|
+ ? $this->get('security.csrf.token_manager')->getToken('authenticate')->getValue()
|
|
|
+ : null;
|
|
|
+
|
|
|
+ return $this->renderLogin(array(
|
|
|
+ 'last_username' => $lastUsername,
|
|
|
+ 'error' => $error,
|
|
|
+ 'csrf_token' => $csrfToken,
|
|
|
+ ));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Renders the login template with the given parameters. Overwrite this function in
|
|
|
+ * an extended controller to provide additional data for the login template.
|
|
|
+ *
|
|
|
+ * @param array $data
|
|
|
+ *
|
|
|
+ * @return Response
|
|
|
+ */
|
|
|
+ protected function renderLogin(array $data)
|
|
|
+ {
|
|
|
+ return $this->render('@BaseOAuthBundle/Security/login.html.twig', $data);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Route("/oauth/v2/auth/login_check", name="oauth_login_check")
|
|
|
+ */
|
|
|
+ public function checkAction()
|
|
|
+ {
|
|
|
+ throw new \RuntimeException('You must configure the check path to be handled by the firewall using form_login in your security firewall configuration.');
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * @Route("/oauth/v2/auth/logout", name="oauth_logout")
|
|
|
+ */
|
|
|
+ public function logoutAction()
|
|
|
+ {
|
|
|
+ throw new \RuntimeException('You must activate the logout in your security firewall configuration.');
|
|
|
+ }
|
|
|
+}
|