99 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			99 lines
		
	
	
		
			3.2 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\Loader;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use Symfony\Component\Config\Util\XmlUtils;
							 | 
						||
| 
								 | 
							
								use Symfony\Component\DependencyInjection\Exception\InvalidArgumentException;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * IniFileLoader loads parameters from INI files.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @author Fabien Potencier <fabien@symfony.com>
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								class IniFileLoader extends FileLoader
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    public function load(mixed $resource, ?string $type = null): mixed
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $path = $this->locator->locate($resource);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        $this->container->fileExists($path);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        // first pass to catch parsing errors
							 | 
						||
| 
								 | 
							
								        $result = parse_ini_file($path, true);
							 | 
						||
| 
								 | 
							
								        if (false === $result || [] === $result) {
							 | 
						||
| 
								 | 
							
								            throw new InvalidArgumentException(\sprintf('The "%s" file is not valid.', $resource));
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        // real raw parsing
							 | 
						||
| 
								 | 
							
								        $result = parse_ini_file($path, true, \INI_SCANNER_RAW);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (isset($result['parameters']) && \is_array($result['parameters'])) {
							 | 
						||
| 
								 | 
							
								            foreach ($result['parameters'] as $key => $value) {
							 | 
						||
| 
								 | 
							
								                if (\is_array($value)) {
							 | 
						||
| 
								 | 
							
								                    $this->container->setParameter($key, array_map($this->phpize(...), $value));
							 | 
						||
| 
								 | 
							
								                } else {
							 | 
						||
| 
								 | 
							
								                    $this->container->setParameter($key, $this->phpize($value));
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if ($this->env && \is_array($result['parameters@'.$this->env] ?? null)) {
							 | 
						||
| 
								 | 
							
								            foreach ($result['parameters@'.$this->env] as $key => $value) {
							 | 
						||
| 
								 | 
							
								                $this->container->setParameter($key, $this->phpize($value));
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return null;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    public function supports(mixed $resource, ?string $type = null): bool
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        if (!\is_string($resource)) {
							 | 
						||
| 
								 | 
							
								            return false;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (null === $type && 'ini' === pathinfo($resource, \PATHINFO_EXTENSION)) {
							 | 
						||
| 
								 | 
							
								            return true;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return 'ini' === $type;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Note that the following features are not supported:
							 | 
						||
| 
								 | 
							
								     *  * strings with escaped quotes are not supported "foo\"bar";
							 | 
						||
| 
								 | 
							
								     *  * string concatenation ("foo" "bar").
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    private function phpize(string $value): mixed
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        // trim on the right as comments removal keep whitespaces
							 | 
						||
| 
								 | 
							
								        if ($value !== $v = rtrim($value)) {
							 | 
						||
| 
								 | 
							
								            $value = '""' === substr_replace($v, '', 1, -1) ? substr($v, 1, -1) : $v;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        $lowercaseValue = strtolower($value);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return match (true) {
							 | 
						||
| 
								 | 
							
								            \defined($value) => \constant($value),
							 | 
						||
| 
								 | 
							
								            'yes' === $lowercaseValue,
							 | 
						||
| 
								 | 
							
								            'on' === $lowercaseValue => true,
							 | 
						||
| 
								 | 
							
								            'no' === $lowercaseValue,
							 | 
						||
| 
								 | 
							
								            'off' === $lowercaseValue,
							 | 
						||
| 
								 | 
							
								            'none' === $lowercaseValue => false,
							 | 
						||
| 
								 | 
							
								            isset($value[1]) && (
							 | 
						||
| 
								 | 
							
								                ("'" === $value[0] && "'" === $value[\strlen($value) - 1])
							 | 
						||
| 
								 | 
							
								                || ('"' === $value[0] && '"' === $value[\strlen($value) - 1])
							 | 
						||
| 
								 | 
							
								            ) => substr($value, 1, -1), // quoted string
							 | 
						||
| 
								 | 
							
								            default => XmlUtils::phpize($value),
							 | 
						||
| 
								 | 
							
								        };
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |