Symfony - How to get username and IP address in authentication failure listener?

I need to get:

  • Username
  • IP address

for every user trying to log in to my site. There is no problem to get this information if the user has logged in successfully, but I do not know how to get the IP address for failed attempts.

Its my code:

app.listener.interactive_login_listener:
    class: AppBundle\EventListener\LogonListener
    arguments: ['@security.token_storage', '@doctrine.orm.entity_manager', '@security.authorization_checker', '@router', '@manager.settings']
    tags:
        - { name: kernel.event_listener, event: security.interactive_login, method: onAuthenticationSuccess }

# authentication failure event listener
app.listener.authentication_failure_event_listener:
    class: AppBundle\EventListener\LogonListener
    arguments: ['@security.token_storage', '@doctrine.orm.entity_manager', '@security.authorization_checker', '@router', '@manager.settings']
    tags:
        - { name: kernel.event_listener, event: security.authentication.failure, method: onAuthenticationFailure }

and listener :

class LogonListener implements EventSubscriberInterface
{

    private $_tokenStorage;
    private $_em;
    private $_authorizationChecker;
    private $_router;
    private $_settings;

    public function __construct(
        TokenStorage $tokenStorage,
        EntityManager $em,
        AuthorizationCheckerInterface $authorizationChecker,
        Router $router,
        $settings)
    {
        $this->_tokenStorage = $tokenStorage;
        $this->_em = $em;
        $this->_authorizationChecker = $authorizationChecker;
        $this->_router = $router;
        $this->_settings = $settings;
    }

    /**
     * getSubscribedEvents
     *
     * @return    array
     */
    public static function getSubscribedEvents()
    {
        return array(
            AuthenticationEvents::AUTHENTICATION_SUCCESS => 'onAuthenticationSuccess',
            AuthenticationEvents::AUTHENTICATION_FAILURE => 'onAuthenticationFailure',
        );
    }

    /**
     * onAuthenticationSuccess
     *
     * @param    InteractiveLoginEvent $event
     */
    public function onAuthenticationSuccess(InteractiveLoginEvent $event)
    {
        var_dump( $event->getAuthenticationToken()->getUser() );
        var_dump( $event->getRequest()->getClientIp() );
        die();
    }

    public function onAuthenticationFailure(AuthenticationFailureEvent $event)
    {
        $userName = $event->getAuthenticationToken()->getUsername();
        $user = $this->_em->getRepository('AppBundle:User')->findOneByUsername($userName);

        var_dump( $user );
        // how to get IP?
        die();
    }
+4
source share
2 answers

Bring RequestStackto the listener and receive Requestfrom him. You can get the IP address fromgetClientIp()

/**
 * @var RequestStack
 */
protected $requestStack;

/**
 * @return string
 */
protected function resolveClientIp()
{
    return $this->requestStack->getMasterRequest()->getClientIp();
}
+4
source

Did you try to introduce RequestStackyour listener?

//in your service

# authentication failure event listener
app.listener.authentication_failure_event_listener:
    class: AppBundle\EventListener\LogonListener
    arguments: ['@security.token_storage', '@doctrine.orm.entity_manager', '@security.authorization_checker', '@router', '@manager.settings', '@request_stack']
    tags:
        - { name: kernel.event_listener, event: security.authentication.failure, method: onAuthenticationFailure }


//in your listener

class LogonListener implements EventSubscriberInterface
{

    private $_tokenStorage;
    private $_em;
    private $_authorizationChecker;
    private $_router;
    private $_settings;
    private $_request

    public function __construct(TokenStorage $tokenStorage, EntityManager $em, AuthorizationCheckerInterface $authorizationChecker, Router $router, $settings, $request)
    {
        $this->_tokenStorage = $tokenStorage;
        $this->_em = $em;
        $this->_authorizationChecker = $authorizationChecker;
        $this->_router = $router;
        $this->_settings = $settings;
        $this->_request = $request
    }

    public function onAuthenticationFailure(AuthenticationFailureEvent $event)
    {
        $userName = $event->getAuthenticationToken()->getUsername();
        $user = $this->_em->getRepository('AppBundle:User')->findOneByUsername($userName);

        var_dump( $this->request->getCurrentRequest()->getClientIp() );
        die();
    }
}
+1
source

Source: https://habr.com/ru/post/1649750/


All Articles