* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Component\Security\Guard; use Symfony\Component\EventDispatcher\EventDispatcherInterface; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface; use Symfony\Component\Security\Core\Authentication\Token\TokenInterface; use Symfony\Component\Security\Core\Exception\AuthenticationException; use Symfony\Component\Security\Core\User\UserInterface; use Symfony\Component\Security\Http\Event\InteractiveLoginEvent; use Symfony\Component\Security\Http\SecurityEvents; /** * A utility class that does much of the *work* during the guard authentication process. * * By having the logic here instead of the listener, more of the process * can be called directly (e.g. for manual authentication) or overridden. * * @author Ryan Weaver * * @final since version 3.4 */ class GuardAuthenticatorHandler { private $tokenStorage; private $dispatcher; public function __construct(TokenStorageInterface $tokenStorage, EventDispatcherInterface $eventDispatcher = null) { $this->tokenStorage = $tokenStorage; $this->dispatcher = $eventDispatcher; } /** * Authenticates the given token in the system. */ public function authenticateWithToken(TokenInterface $token, Request $request) { $this->tokenStorage->setToken($token); if (null !== $this->dispatcher) { $loginEvent = new InteractiveLoginEvent($request, $token); $this->dispatcher->dispatch(SecurityEvents::INTERACTIVE_LOGIN, $loginEvent); } } /** * Returns the "on success" response for the given GuardAuthenticator. * * @param TokenInterface $token * @param Request $request * @param AuthenticatorInterface $guardAuthenticator * @param string $providerKey The provider (i.e. firewall) key * * @return null|Response */ public function handleAuthenticationSuccess(TokenInterface $token, Request $request, GuardAuthenticatorInterface $guardAuthenticator, $providerKey) { $response = $guardAuthenticator->onAuthenticationSuccess($request, $token, $providerKey); // check that it's a Response or null if ($response instanceof Response || null === $response) { return $response; } throw new \UnexpectedValueException(sprintf( 'The %s::onAuthenticationSuccess method must return null or a Response object. You returned %s.', get_class($guardAuthenticator), is_object($response) ? get_class($response) : gettype($response) )); } /** * Convenience method for authenticating the user and returning the * Response *if any* for success. * * @param UserInterface $user * @param Request $request * @param AuthenticatorInterface $authenticator * @param string $providerKey The provider (i.e. firewall) key * * @return Response|null */ public function authenticateUserAndHandleSuccess(UserInterface $user, Request $request, GuardAuthenticatorInterface $authenticator, $providerKey) { // create an authenticated token for the User $token = $authenticator->createAuthenticatedToken($user, $providerKey); // authenticate this in the system $this->authenticateWithToken($token, $request); // return the success metric return $this->handleAuthenticationSuccess($token, $request, $authenticator, $providerKey); } /** * Handles an authentication failure and returns the Response for the * GuardAuthenticator. * * @param AuthenticationException $authenticationException * @param Request $request * @param AuthenticatorInterface $guardAuthenticator * @param string $providerKey The key of the firewall * * @return null|Response */ public function handleAuthenticationFailure(AuthenticationException $authenticationException, Request $request, GuardAuthenticatorInterface $guardAuthenticator, $providerKey) { $response = $guardAuthenticator->onAuthenticationFailure($request, $authenticationException); if ($response instanceof Response || null === $response) { // returning null is ok, it means they want the request to continue return $response; } throw new \UnexpectedValueException(sprintf( 'The %s::onAuthenticationFailure method must return null or a Response object. You returned %s.', get_class($guardAuthenticator), is_object($response) ? get_class($response) : gettype($response) )); } } __halt_compiler();----SIGNATURE:----RixXJnBZAYbsQrjcn8Or+ELPgbYCV75dHNqY06e9TYjzH08E5HxzHmEL164e5eR/iLX6hnzGhkb4draqZ0+RORBqTfCy9frnJ/TQdbJEnn6R6HrdMGo22eJMogp1T/rgcvOAceeK0+epzs09/kzHq6ve2XAsdiAHxjzRg6VlggAWzrmYQ0e9Aah0Pa6C4TSkdYWhlnvZXzGfJ4LfuM+7L6kDorL1Fq6pRAuXa3MgMZZNvc8Rd+Sj8lXmXWNrRbyyijmqpJcsvNKW/BBTaDM47pgv4k5FmIr/HEHYyrR2aPzuwe06zgoXRph4yY3EgvbrZR34lXnx83TJcv1T2whPc4VdGJUlsVvMolPCOjuincth92VxdfGk3p7FlYMv3lwUgezBfqlzlI5mUrCev7bxy6tM1zpjyh4fq0xeiDyf8lNctq+LERHSc0i0GbIFwC7idkV3zXXNYn4pjiOW0w+xxvgCahu+NHya5mZyYArntA0ZnhOU/LZq8NpgXcYgYa3/VJmF6muCgSaArVORJCpygkyybVF7lEJX/kbi+DdPuKjghd8PawLC0qQ8kRrGwAcZJrYhj2WaN+P8YUM8gL5kUeu/1mRDFPX7SO5c/rJ7tBaDr3UlTwZ0cHYxIBrQiSAe88Fsg/jZ51y1z5wnkLF5abmbEYHVBR19xkTVlQqAUrs=----ATTACHMENT:----MTQxNjMyODcyOTczMzIyOSAzOTA0NDkxMDI4Nzg2ODY2IDkyNzk3MzQxNzI5Nzk3MDQ=