2008-10-08 20:42:09 +00:00
|
|
|
<?php
|
2016-06-15 16:03:16 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\ORM;
|
|
|
|
|
|
|
|
use Exception;
|
2016-11-23 18:09:10 +13:00
|
|
|
use InvalidArgumentException;
|
|
|
|
use SilverStripe\Core\Injector\Injectable;
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2008-10-08 20:42:09 +00:00
|
|
|
/**
|
|
|
|
* Exception thrown by {@link DataObject}::write if validation fails. By throwing an
|
|
|
|
* exception rather than a user error, the exception can be caught in unit tests and as such
|
|
|
|
* can be used as a successful test.
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class ValidationException extends Exception
|
|
|
|
{
|
2016-11-23 18:09:10 +13:00
|
|
|
use Injectable;
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
/**
|
|
|
|
* The contained ValidationResult related to this error
|
|
|
|
*
|
|
|
|
* @var ValidationResult
|
|
|
|
*/
|
|
|
|
protected $result;
|
2016-11-23 10:29:15 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
/**
|
|
|
|
* Construct a new ValidationException with an optional ValidationResult object
|
|
|
|
*
|
|
|
|
* @param ValidationResult|string $result The ValidationResult containing the
|
|
|
|
* failed result, or error message to build error from
|
|
|
|
* @param integer $code The error code number
|
|
|
|
*/
|
|
|
|
public function __construct($result = null, $code = 0)
|
|
|
|
{
|
|
|
|
// Catch legacy behaviour where second argument was not code
|
|
|
|
if ($code && !is_numeric($code)) {
|
|
|
|
throw new InvalidArgumentException("Code must be numeric");
|
|
|
|
}
|
2016-11-23 10:29:15 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
// Set default message and result
|
2017-04-20 13:15:24 +12:00
|
|
|
$exceptionMessage = _t("SilverStripe\\ORM\\ValidationException.DEFAULT_ERROR", "Validation error");
|
2016-11-23 18:09:10 +13:00
|
|
|
if (!$result) {
|
|
|
|
$result = $exceptionMessage;
|
|
|
|
}
|
2016-11-23 10:29:15 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
// Check result type
|
|
|
|
if ($result instanceof ValidationResult) {
|
|
|
|
$this->result = $result;
|
|
|
|
// Pick first message
|
|
|
|
foreach ($result->getMessages() as $message) {
|
|
|
|
$exceptionMessage = $message['message'];
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
} elseif (is_string($result)) {
|
|
|
|
$this->result = ValidationResult::create()->addError($result);
|
|
|
|
$exceptionMessage = $result;
|
|
|
|
} else {
|
|
|
|
throw new InvalidArgumentException(
|
|
|
|
"ValidationExceptions must be passed a ValdiationResult, a string, or nothing at all"
|
|
|
|
);
|
|
|
|
}
|
2016-11-23 10:29:15 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
parent::__construct($exceptionMessage, $code);
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 18:09:10 +13:00
|
|
|
/**
|
|
|
|
* Retrieves the ValidationResult related to this error
|
|
|
|
*
|
|
|
|
* @return ValidationResult
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function getResult()
|
|
|
|
{
|
2016-11-23 18:09:10 +13:00
|
|
|
return $this->result;
|
|
|
|
}
|
2008-10-08 20:42:09 +00:00
|
|
|
}
|