mirror of
https://github.com/Combodo/iTop.git
synced 2026-02-27 06:04:12 +01:00
Package operations: 2 installs, 23 updates, 0 removals - Updating psr/log (1.1.0 => 1.1.2) - Updating symfony/debug (v3.4.30 => v3.4.35) - Updating symfony/console (v3.4.30 => v3.4.35) - Updating symfony/dotenv (v3.4.30 => v3.4.35) - Updating symfony/routing (v3.4.30 => v3.4.35) - Updating symfony/finder (v3.4.30 => v3.4.35) - Updating symfony/filesystem (v3.4.30 => v3.4.35) - Installing symfony/polyfill-util (v1.12.0) - Installing symfony/polyfill-php56 (v1.12.0) - Updating symfony/http-foundation (v3.4.30 => v3.4.35) - Updating symfony/event-dispatcher (v3.4.30 => v3.4.35) - Updating symfony/http-kernel (v3.4.30 => v3.4.35) - Updating symfony/config (v3.4.30 => v3.4.35) - Updating symfony/dependency-injection (v3.4.30 => v3.4.35) - Updating symfony/class-loader (v3.4.30 => v3.4.35) - Updating symfony/cache (v3.4.30 => v3.4.35) - Updating symfony/framework-bundle (v3.4.30 => v3.4.35) - Updating twig/twig (v1.42.2 => v1.42.4) - Updating symfony/twig-bridge (v3.4.30 => v3.4.35) - Updating symfony/twig-bundle (v3.4.30 => v3.4.35) - Updating symfony/yaml (v3.4.30 => v3.4.35) - Updating symfony/stopwatch (v3.4.30 => v3.4.35) - Updating symfony/var-dumper (v3.4.30 => v3.4.35) - Updating symfony/web-profiler-bundle (v3.4.30 => v3.4.35) - Updating symfony/css-selector (v3.4.30 => v3.4.35)
126 lines
3.6 KiB
PHP
126 lines
3.6 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the Symfony package.
|
|
*
|
|
* (c) Fabien Potencier <fabien@symfony.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Symfony\Component\DependencyInjection\Extension;
|
|
|
|
use Symfony\Component\Config\Definition\ConfigurationInterface;
|
|
use Symfony\Component\Config\Definition\Processor;
|
|
use Symfony\Component\DependencyInjection\Container;
|
|
use Symfony\Component\DependencyInjection\ContainerBuilder;
|
|
use Symfony\Component\DependencyInjection\Exception\BadMethodCallException;
|
|
use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
|
|
|
|
/**
|
|
* Provides useful features shared by many extensions.
|
|
*
|
|
* @author Fabien Potencier <fabien@symfony.com>
|
|
*/
|
|
abstract class Extension implements ExtensionInterface, ConfigurationExtensionInterface
|
|
{
|
|
private $processedConfigs = [];
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getXsdValidationBasePath()
|
|
{
|
|
return false;
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getNamespace()
|
|
{
|
|
return 'http://example.org/schema/dic/'.$this->getAlias();
|
|
}
|
|
|
|
/**
|
|
* Returns the recommended alias to use in XML.
|
|
*
|
|
* This alias is also the mandatory prefix to use when using YAML.
|
|
*
|
|
* This convention is to remove the "Extension" postfix from the class
|
|
* name and then lowercase and underscore the result. So:
|
|
*
|
|
* AcmeHelloExtension
|
|
*
|
|
* becomes
|
|
*
|
|
* acme_hello
|
|
*
|
|
* This can be overridden in a sub-class to specify the alias manually.
|
|
*
|
|
* @return string The alias
|
|
*
|
|
* @throws BadMethodCallException When the extension name does not follow conventions
|
|
*/
|
|
public function getAlias()
|
|
{
|
|
$className = \get_class($this);
|
|
if ('Extension' != substr($className, -9)) {
|
|
throw new BadMethodCallException('This extension does not follow the naming convention; you must overwrite the getAlias() method.');
|
|
}
|
|
$classBaseName = substr(strrchr($className, '\\'), 1, -9);
|
|
|
|
return Container::underscore($classBaseName);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
public function getConfiguration(array $config, ContainerBuilder $container)
|
|
{
|
|
$class = \get_class($this);
|
|
$class = substr_replace($class, '\Configuration', strrpos($class, '\\'));
|
|
$class = $container->getReflectionClass($class);
|
|
$constructor = $class ? $class->getConstructor() : null;
|
|
|
|
return $class && (!$constructor || !$constructor->getNumberOfRequiredParameters()) ? $class->newInstance() : null;
|
|
}
|
|
|
|
/**
|
|
* @return array
|
|
*/
|
|
final protected function processConfiguration(ConfigurationInterface $configuration, array $configs)
|
|
{
|
|
$processor = new Processor();
|
|
|
|
return $this->processedConfigs[] = $processor->processConfiguration($configuration, $configs);
|
|
}
|
|
|
|
/**
|
|
* @internal
|
|
*/
|
|
final public function getProcessedConfigs()
|
|
{
|
|
try {
|
|
return $this->processedConfigs;
|
|
} finally {
|
|
$this->processedConfigs = [];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @return bool Whether the configuration is enabled
|
|
*
|
|
* @throws InvalidArgumentException When the config is not enableable
|
|
*/
|
|
protected function isConfigEnabled(ContainerBuilder $container, array $config)
|
|
{
|
|
if (!\array_key_exists('enabled', $config)) {
|
|
throw new InvalidArgumentException("The config array has no 'enabled' key.");
|
|
}
|
|
|
|
return (bool) $container->getParameterBag()->resolveValue($config['enabled']);
|
|
}
|
|
}
|