[SecurityBundle] only pass relevant user provider
This commit is contained in:
parent
22968cda3b
commit
d97e07fd6a
@ -214,16 +214,6 @@ class SecurityExtension extends Extension
|
|||||||
$firewalls = $config['firewalls'];
|
$firewalls = $config['firewalls'];
|
||||||
$providerIds = $this->createUserProviders($config, $container);
|
$providerIds = $this->createUserProviders($config, $container);
|
||||||
|
|
||||||
// make the ContextListener aware of the configured user providers
|
|
||||||
$definition = $container->getDefinition('security.context_listener');
|
|
||||||
$arguments = $definition->getArguments();
|
|
||||||
$userProviders = array();
|
|
||||||
foreach ($providerIds as $userProviderId) {
|
|
||||||
$userProviders[] = new Reference($userProviderId);
|
|
||||||
}
|
|
||||||
$arguments[1] = $userProviders;
|
|
||||||
$definition->setArguments($arguments);
|
|
||||||
|
|
||||||
// load firewall map
|
// load firewall map
|
||||||
$mapDef = $container->getDefinition('security.firewall.map');
|
$mapDef = $container->getDefinition('security.firewall.map');
|
||||||
$map = $authenticationProviders = array();
|
$map = $authenticationProviders = array();
|
||||||
@ -288,7 +278,7 @@ class SecurityExtension extends Extension
|
|||||||
$contextKey = $firewall['context'];
|
$contextKey = $firewall['context'];
|
||||||
}
|
}
|
||||||
|
|
||||||
$listeners[] = new Reference($this->createContextListener($container, $contextKey));
|
$listeners[] = new Reference($this->createContextListener($container, $contextKey, $defaultProvider));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Logout listener
|
// Logout listener
|
||||||
@ -371,7 +361,7 @@ class SecurityExtension extends Extension
|
|||||||
return array($matcher, $listeners, $exceptionListener);
|
return array($matcher, $listeners, $exceptionListener);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function createContextListener($container, $contextKey)
|
private function createContextListener($container, $contextKey, $providerId)
|
||||||
{
|
{
|
||||||
if (isset($this->contextListeners[$contextKey])) {
|
if (isset($this->contextListeners[$contextKey])) {
|
||||||
return $this->contextListeners[$contextKey];
|
return $this->contextListeners[$contextKey];
|
||||||
@ -379,6 +369,7 @@ class SecurityExtension extends Extension
|
|||||||
|
|
||||||
$listenerId = 'security.context_listener.'.count($this->contextListeners);
|
$listenerId = 'security.context_listener.'.count($this->contextListeners);
|
||||||
$listener = $container->setDefinition($listenerId, new DefinitionDecorator('security.context_listener'));
|
$listener = $container->setDefinition($listenerId, new DefinitionDecorator('security.context_listener'));
|
||||||
|
$listener->replaceArgument(1, array(new Reference($providerId)));
|
||||||
$listener->replaceArgument(2, $contextKey);
|
$listener->replaceArgument(2, $contextKey);
|
||||||
|
|
||||||
return $this->contextListeners[$contextKey] = $listenerId;
|
return $this->contextListeners[$contextKey] = $listenerId;
|
||||||
|
Reference in New Issue
Block a user