/** * @test */ public function resolveInterceptorReturnsTheCorrectInterceptorForACompleteClassName() { $mockObjectManager = $this->getMockBuilder(ObjectManager::class)->disableOriginalConstructor()->getMock(); $mockObjectManager->expects($this->any())->method('getCaseSensitiveObjectName')->with('ExistingInterceptorClass')->will($this->returnValue('ExistingInterceptorClass')); $interceptorResolver = new Security\Authorization\InterceptorResolver($mockObjectManager); $interceptorClass = $interceptorResolver->resolveInterceptorClass('ExistingInterceptorClass'); $this->assertEquals('ExistingInterceptorClass', $interceptorClass, 'The wrong classname has been resolved'); }
/** * Sets the internal filters based on the given configuration. * * @param array $filterSettings The filter settings * @return void */ protected function buildFiltersFromSettings(array $filterSettings) { foreach ($filterSettings as $singleFilterSettings) { $patternType = isset($singleFilterSettings['pattern']) ? $singleFilterSettings['pattern'] : $singleFilterSettings['patternType']; $patternClassName = $this->requestPatternResolver->resolveRequestPatternClass($patternType); $patternOptions = isset($singleFilterSettings['patternOptions']) ? $singleFilterSettings['patternOptions'] : []; /** @var $requestPattern RequestPatternInterface */ $requestPattern = $this->objectManager->get($patternClassName, $patternOptions); // The following check needed for backwards compatibility: // Previously each pattern had only one option that was set via the setPattern() method. Now options are passed to the constructor. if (isset($singleFilterSettings['patternValue']) && is_callable([$requestPattern, 'setPattern'])) { $requestPattern->setPattern($singleFilterSettings['patternValue']); } $interceptor = $this->objectManager->get($this->interceptorResolver->resolveInterceptorClass($singleFilterSettings['interceptor'])); $this->filters[] = $this->objectManager->get(RequestFilter::class, $requestPattern, $interceptor); } }