2021-02-26 16:16:17 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Assert
|
|
|
|
*
|
|
|
|
* LICENSE
|
|
|
|
*
|
|
|
|
* This source file is subject to the MIT license that is bundled
|
|
|
|
* with this package in the file LICENSE.txt.
|
|
|
|
* If you did not receive a copy of the license and are unable to
|
|
|
|
* obtain it through the world-wide-web, please send an email
|
|
|
|
* to kontakt@beberlei.de so I can send you a copy immediately.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Assert;
|
|
|
|
|
|
|
|
class InvalidArgumentException extends \InvalidArgumentException implements AssertionFailedException
|
|
|
|
{
|
|
|
|
private $propertyPath;
|
|
|
|
private $value;
|
|
|
|
private $constraints;
|
|
|
|
|
2021-11-15 15:33:35 +00:00
|
|
|
public function __construct($message, $code, $propertyPath, $value, array $constraints = [])
|
2021-02-26 16:16:17 +00:00
|
|
|
{
|
|
|
|
parent::__construct($message, $code);
|
|
|
|
|
|
|
|
$this->propertyPath = $propertyPath;
|
|
|
|
$this->value = $value;
|
|
|
|
$this->constraints = $constraints;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* User controlled way to define a sub-property causing
|
|
|
|
* the failure of a currently asserted objects.
|
|
|
|
*
|
|
|
|
* Useful to transport information about the nature of the error
|
|
|
|
* back to higher layers.
|
|
|
|
*
|
2021-11-15 15:33:35 +00:00
|
|
|
* @return string
|
2021-02-26 16:16:17 +00:00
|
|
|
*/
|
|
|
|
public function getPropertyPath()
|
|
|
|
{
|
|
|
|
return $this->propertyPath;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the value that caused the assertion to fail.
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function getValue()
|
|
|
|
{
|
|
|
|
return $this->value;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the constraints that applied to the failed assertion.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2021-11-15 15:33:35 +00:00
|
|
|
public function getConstraints()
|
2021-02-26 16:16:17 +00:00
|
|
|
{
|
|
|
|
return $this->constraints;
|
|
|
|
}
|
|
|
|
}
|