File "EnvironmentVariableDefinition.php"
Full Path: /home/capoeirajd/www/wp-content/plugins/wp-migrate-db/vendor/php-di/php-di/src/DI/Definition/EnvironmentVariableDefinition.php
File size: 3.28 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace DeliciousBrains\WPMDB\Container\DI\Definition;
use DeliciousBrains\WPMDB\Container\DI\Definition\Helper\DefinitionHelper;
use DeliciousBrains\WPMDB\Container\DI\Scope;
/**
* Defines a reference to an environment variable, with fallback to a default
* value if the environment variable is not defined.
*
* @author James Harris <james.harris@icecave.com.au>
*/
class EnvironmentVariableDefinition implements CacheableDefinition
{
/**
* Entry name.
* @var string
*/
private $name;
/**
* The name of the environment variable.
* @var string
*/
private $variableName;
/**
* Whether or not the environment variable definition is optional.
*
* If true and the environment variable given by $variableName has not been
* defined, $defaultValue is used.
*
* @var bool
*/
private $isOptional;
/**
* The default value to use if the environment variable is optional and not provided.
* @var mixed
*/
private $defaultValue;
/**
* @var string|null
*/
private $scope;
/**
* @param string $name Entry name
* @param string $variableName The name of the environment variable
* @param bool $isOptional Whether or not the environment variable definition is optional
* @param mixed $defaultValue The default value to use if the environment variable is optional and not provided
*/
public function __construct($name, $variableName, $isOptional = \false, $defaultValue = null)
{
$this->name = $name;
$this->variableName = $variableName;
$this->isOptional = $isOptional;
$this->defaultValue = $defaultValue;
}
/**
* @return string Entry name
*/
public function getName()
{
return $this->name;
}
/**
* @return string The name of the environment variable
*/
public function getVariableName()
{
return $this->variableName;
}
/**
* @return bool Whether or not the environment variable definition is optional
*/
public function isOptional()
{
return $this->isOptional;
}
/**
* @return mixed The default value to use if the environment variable is optional and not provided
*/
public function getDefaultValue()
{
return $this->defaultValue;
}
/**
* @param string $scope
*/
public function setScope($scope)
{
$this->scope = $scope;
}
/**
* {@inheritdoc}
*/
public function getScope()
{
return $this->scope ?: Scope::SINGLETON;
}
public function __toString()
{
$str = ' variable = ' . $this->variableName . \PHP_EOL . ' optional = ' . ($this->isOptional ? 'yes' : 'no');
if ($this->isOptional) {
if ($this->defaultValue instanceof DefinitionHelper) {
$nestedDefinition = (string) $this->defaultValue->getDefinition('');
$defaultValueStr = \str_replace(\PHP_EOL, \PHP_EOL . ' ', $nestedDefinition);
} else {
$defaultValueStr = \var_export($this->defaultValue, \true);
}
$str .= \PHP_EOL . ' default = ' . $defaultValueStr;
}
return \sprintf('Environment variable (' . \PHP_EOL . '%s' . \PHP_EOL . ')', $str);
}
}