| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 | 
							- <?php
 - 
 - /*
 -  * Copyright 2010 Johannes M. Schmitt <schmittjoh@gmail.com>
 -  *
 -  * Licensed under the Apache License, Version 2.0 (the "License");
 -  * you may not use this file except in compliance with the License.
 -  * You may obtain a copy of the License at
 -  *
 -  * http://www.apache.org/licenses/LICENSE-2.0
 -  *
 -  * Unless required by applicable law or agreed to in writing, software
 -  * distributed under the License is distributed on an "AS IS" BASIS,
 -  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 -  * See the License for the specific language governing permissions and
 -  * limitations under the License.
 -  */
 - 
 - namespace JMS\SecurityExtraBundle\Security\Authorization;
 - 
 - use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
 - 
 - /**
 -  * RunAsManagerInterface
 -  *
 -  * @author Johannes M. Schmitt <schmittjoh@gmail.com>
 -  */
 - interface RunAsManagerInterface
 - {
 -     /**
 -      * Creates a temporary RunAsToken.
 -      *
 -      * The returned Token must have a complementing AuthenticationProvider implementation.
 -      *
 -      * @param TokenInterface $token the original Token
 -      * @param object $secureObject the secure object which caused this call
 -      * @param array $attributes an array of attributes to apply to the built token
 -      * @return TokenInterface
 -      */
 -     function buildRunAs(TokenInterface $token, $secureObject, array $attributes);
 - 
 -     /**
 -      * Whether this RunAsManager supports the given attribute
 -      *
 -      * @param string $attribute
 -      * @return Boolean
 -      */
 -     function supportsAttribute($attribute);
 - 
 -     /**
 -      * Whether this RunAsManager supports the given class.
 -      *
 -      * @param string $className The class of the secure object which requests RunAs capabilities
 -      * @return Boolean
 -      */
 -     function supportsClass($className);
 - }
 
 
  |