344 lines
7.3 KiB
PHP
344 lines
7.3 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\Config\Definition\Builder;
|
||
|
|
||
|
use Symfony\Component\Config\Definition\NodeInterface;
|
||
|
use Symfony\Component\Config\Definition\Exception\InvalidDefinitionException;
|
||
|
|
||
|
/**
|
||
|
* This class provides a fluent interface for defining a node.
|
||
|
*
|
||
|
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||
|
*/
|
||
|
abstract class NodeDefinition implements NodeParentInterface
|
||
|
{
|
||
|
protected $name;
|
||
|
protected $normalization;
|
||
|
protected $validation;
|
||
|
protected $defaultValue;
|
||
|
protected $default = false;
|
||
|
protected $required = false;
|
||
|
protected $merge;
|
||
|
protected $allowEmptyValue = true;
|
||
|
protected $nullEquivalent;
|
||
|
protected $trueEquivalent = true;
|
||
|
protected $falseEquivalent = false;
|
||
|
|
||
|
/**
|
||
|
* @var NodeParentInterface|null
|
||
|
*/
|
||
|
protected $parent;
|
||
|
protected $attributes = array();
|
||
|
|
||
|
/**
|
||
|
* Constructor.
|
||
|
*
|
||
|
* @param string $name The name of the node
|
||
|
* @param NodeParentInterface|null $parent The parent
|
||
|
*/
|
||
|
public function __construct($name, NodeParentInterface $parent = null)
|
||
|
{
|
||
|
$this->parent = $parent;
|
||
|
$this->name = $name;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the parent node.
|
||
|
*
|
||
|
* @param NodeParentInterface $parent The parent
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function setParent(NodeParentInterface $parent)
|
||
|
{
|
||
|
$this->parent = $parent;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets info message.
|
||
|
*
|
||
|
* @param string $info The info text
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function info($info)
|
||
|
{
|
||
|
return $this->attribute('info', $info);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets example configuration.
|
||
|
*
|
||
|
* @param string|array $example
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function example($example)
|
||
|
{
|
||
|
return $this->attribute('example', $example);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets an attribute on the node.
|
||
|
*
|
||
|
* @param string $key
|
||
|
* @param mixed $value
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function attribute($key, $value)
|
||
|
{
|
||
|
$this->attributes[$key] = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the parent node.
|
||
|
*
|
||
|
* @return NodeParentInterface|null The builder of the parent node
|
||
|
*/
|
||
|
public function end()
|
||
|
{
|
||
|
return $this->parent;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Creates the node.
|
||
|
*
|
||
|
* @param bool $forceRootNode Whether to force this node as the root node
|
||
|
*
|
||
|
* @return NodeInterface
|
||
|
*/
|
||
|
public function getNode($forceRootNode = false)
|
||
|
{
|
||
|
if ($forceRootNode) {
|
||
|
$this->parent = null;
|
||
|
}
|
||
|
|
||
|
if (null !== $this->normalization) {
|
||
|
$this->normalization->before = ExprBuilder::buildExpressions($this->normalization->before);
|
||
|
}
|
||
|
|
||
|
if (null !== $this->validation) {
|
||
|
$this->validation->rules = ExprBuilder::buildExpressions($this->validation->rules);
|
||
|
}
|
||
|
|
||
|
$node = $this->createNode();
|
||
|
$node->setAttributes($this->attributes);
|
||
|
|
||
|
return $node;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the default value.
|
||
|
*
|
||
|
* @param mixed $value The default value
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function defaultValue($value)
|
||
|
{
|
||
|
$this->default = true;
|
||
|
$this->defaultValue = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the node as required.
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function isRequired()
|
||
|
{
|
||
|
$this->required = true;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the equivalent value used when the node contains null.
|
||
|
*
|
||
|
* @param mixed $value
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function treatNullLike($value)
|
||
|
{
|
||
|
$this->nullEquivalent = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the equivalent value used when the node contains true.
|
||
|
*
|
||
|
* @param mixed $value
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function treatTrueLike($value)
|
||
|
{
|
||
|
$this->trueEquivalent = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets the equivalent value used when the node contains false.
|
||
|
*
|
||
|
* @param mixed $value
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function treatFalseLike($value)
|
||
|
{
|
||
|
$this->falseEquivalent = $value;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets null as the default value.
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function defaultNull()
|
||
|
{
|
||
|
return $this->defaultValue(null);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets true as the default value.
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function defaultTrue()
|
||
|
{
|
||
|
return $this->defaultValue(true);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets false as the default value.
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function defaultFalse()
|
||
|
{
|
||
|
return $this->defaultValue(false);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets an expression to run before the normalization.
|
||
|
*
|
||
|
* @return ExprBuilder
|
||
|
*/
|
||
|
public function beforeNormalization()
|
||
|
{
|
||
|
return $this->normalization()->before();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Denies the node value being empty.
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function cannotBeEmpty()
|
||
|
{
|
||
|
$this->allowEmptyValue = false;
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets an expression to run for the validation.
|
||
|
*
|
||
|
* The expression receives the value of the node and must return it. It can
|
||
|
* modify it.
|
||
|
* An exception should be thrown when the node is not valid.
|
||
|
*
|
||
|
* @return ExprBuilder
|
||
|
*/
|
||
|
public function validate()
|
||
|
{
|
||
|
return $this->validation()->rule();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Sets whether the node can be overwritten.
|
||
|
*
|
||
|
* @param bool $deny Whether the overwriting is forbidden or not
|
||
|
*
|
||
|
* @return NodeDefinition|$this
|
||
|
*/
|
||
|
public function cannotBeOverwritten($deny = true)
|
||
|
{
|
||
|
$this->merge()->denyOverwrite($deny);
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets the builder for validation rules.
|
||
|
*
|
||
|
* @return ValidationBuilder
|
||
|
*/
|
||
|
protected function validation()
|
||
|
{
|
||
|
if (null === $this->validation) {
|
||
|
$this->validation = new ValidationBuilder($this);
|
||
|
}
|
||
|
|
||
|
return $this->validation;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets the builder for merging rules.
|
||
|
*
|
||
|
* @return MergeBuilder
|
||
|
*/
|
||
|
protected function merge()
|
||
|
{
|
||
|
if (null === $this->merge) {
|
||
|
$this->merge = new MergeBuilder($this);
|
||
|
}
|
||
|
|
||
|
return $this->merge;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Gets the builder for normalization rules.
|
||
|
*
|
||
|
* @return NormalizationBuilder
|
||
|
*/
|
||
|
protected function normalization()
|
||
|
{
|
||
|
if (null === $this->normalization) {
|
||
|
$this->normalization = new NormalizationBuilder($this);
|
||
|
}
|
||
|
|
||
|
return $this->normalization;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Instantiate and configure the node according to this definition.
|
||
|
*
|
||
|
* @return NodeInterface $node The node instance
|
||
|
*
|
||
|
* @throws InvalidDefinitionException When the definition is invalid
|
||
|
*/
|
||
|
abstract protected function createNode();
|
||
|
}
|