vendor/bundles/JMS/SecurityExtraBundle/DependencyInjection/Compiler/AddAfterInvocationProvidersPass.php
changeset 0 7f95f8617b0b
equal deleted inserted replaced
-1:000000000000 0:7f95f8617b0b
       
     1 <?php
       
     2 
       
     3 /*
       
     4  * Copyright 2010 Johannes M. Schmitt <schmittjoh@gmail.com>
       
     5  *
       
     6  * Licensed under the Apache License, Version 2.0 (the "License");
       
     7  * you may not use this file except in compliance with the License.
       
     8  * You may obtain a copy of the License at
       
     9  *
       
    10  * http://www.apache.org/licenses/LICENSE-2.0
       
    11  *
       
    12  * Unless required by applicable law or agreed to in writing, software
       
    13  * distributed under the License is distributed on an "AS IS" BASIS,
       
    14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
       
    15  * See the License for the specific language governing permissions and
       
    16  * limitations under the License.
       
    17  */
       
    18 
       
    19 namespace JMS\SecurityExtraBundle\DependencyInjection\Compiler;
       
    20 
       
    21 use Symfony\Component\DependencyInjection\Compiler\CompilerPassInterface;
       
    22 use Symfony\Component\DependencyInjection\ContainerBuilder;
       
    23 use Symfony\Component\DependencyInjection\Reference;
       
    24 
       
    25 /**
       
    26  * Collects after invocation providers.
       
    27  *
       
    28  * @author Johannes M. Schmitt <schmittjoh@gmail.com>
       
    29  */
       
    30 class AddAfterInvocationProvidersPass implements CompilerPassInterface
       
    31 {
       
    32     public function process(ContainerBuilder $container)
       
    33     {
       
    34         if (!$container->hasDefinition('security.access.after_invocation_manager')) {
       
    35             return;
       
    36         }
       
    37 
       
    38         $providers = array();
       
    39         foreach (array_keys($container->findTaggedServiceIds('security.after_invocation.provider')) as $id) {
       
    40             if ('security.access.after_invocation.acl_provider' === $id && !$container->has('security.acl.provider')) {
       
    41                 continue;
       
    42             }
       
    43 
       
    44             $providers[] = new Reference($id);
       
    45         }
       
    46 
       
    47         $container
       
    48             ->getDefinition('security.access.after_invocation_manager')
       
    49             ->setArguments(array($providers))
       
    50         ;
       
    51     }
       
    52 }