2008-04-26 06:31:52 +00:00
|
|
|
<?php
|
|
|
|
|
2016-06-15 16:03:16 +12:00
|
|
|
namespace SilverStripe\ORM;
|
|
|
|
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Core\Object;
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2008-04-26 06:31:52 +00:00
|
|
|
/**
|
|
|
|
* A class that combined as a boolean result with an optional list of error messages.
|
|
|
|
* This is used for returning validation results from validators
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
class ValidationResult extends Object
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* @var bool - is the result valid or not
|
|
|
|
*/
|
|
|
|
protected $isValid = true;
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @var array of errors
|
|
|
|
*/
|
|
|
|
protected $errorList = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new ValidationResult.
|
|
|
|
* By default, it is a successful result. Call $this->error() to record errors.
|
|
|
|
*
|
|
|
|
* @param void $valid @deprecated
|
|
|
|
* @param void $message @deprecated
|
|
|
|
*/
|
|
|
|
public function __construct($valid = null, $message = null) {
|
|
|
|
if ($message !== null) {
|
|
|
|
Deprecation::notice('3.2', '$message parameter is deprecated please use addMessage or addError instead', false);
|
|
|
|
$this->addError($message);
|
|
|
|
}
|
|
|
|
if ($valid !== null) {
|
|
|
|
Deprecation::notice('3.2', '$valid parameter is deprecated please addError to mark the result as invalid', false);
|
|
|
|
$this->isValid = $valid;
|
2016-11-29 12:31:16 +13:00
|
|
|
if ($message) {
|
|
|
|
$this->errorList[] = $message;
|
|
|
|
}
|
2016-11-23 10:29:15 +13:00
|
|
|
parent::__construct();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the full error meta-data, suitable for combining with another ValidationResult.
|
|
|
|
*/
|
|
|
|
function getErrorMetaData() {
|
|
|
|
return $this->errorList;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Record a
|
|
|
|
* against this validation result.
|
|
|
|
*
|
|
|
|
* It's better to use addError, addFeildError, addMessage, or addFieldMessage instead.
|
|
|
|
*
|
|
|
|
* @param string $message The message string.
|
|
|
|
* @param string $code A codename for this error. Only one message per codename will be added.
|
|
|
|
* This can be usedful for ensuring no duplicate messages
|
|
|
|
* @param string $fieldName The field to link the message to. If omitted; a form-wide message is assumed.
|
|
|
|
* @param string $messageType The type of message: e.g. "bad", "warning", "good", or "required". Passed as a CSS
|
|
|
|
* class to the form, so other values can be used if desired.
|
|
|
|
* @param bool $escapeHtml Automatically sanitize the message. Set to FALSE if the message contains HTML.
|
|
|
|
* In that case, you might want to use {@link Convert::raw2xml()} to escape any
|
|
|
|
* user supplied data in the message.
|
|
|
|
*
|
|
|
|
* @deprecated 3.2
|
|
|
|
*/
|
|
|
|
public function error($message, $code = null, $fieldName = null, $messageType = "bad", $escapeHtml = true) {
|
|
|
|
Deprecation::notice('3.2', 'Use addError or addFieldError instead.');
|
|
|
|
|
|
|
|
return $this->addFieldError($fieldName, $message, $messageType, $code, $escapeHtml);
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* Record an error against this validation result,
|
|
|
|
*
|
|
|
|
* @param string $message The message string.
|
|
|
|
* @param string $messageType The type of message: e.g. "bad", "warning", "good", or "required". Passed as a CSS
|
|
|
|
* class to the form, so other values can be used if desired.
|
|
|
|
* @param string $code A codename for this error. Only one message per codename will be added.
|
|
|
|
* This can be usedful for ensuring no duplicate messages
|
|
|
|
* @param bool $escapeHtml Automatically sanitize the message. Set to FALSE if the message contains HTML.
|
|
|
|
* In that case, you might want to use {@link Convert::raw2xml()} to escape any
|
|
|
|
* user supplied data in the message.
|
|
|
|
*/
|
|
|
|
public function addError($message, $messageType = "bad", $code = null, $escapeHtml = true) {
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
return $this->addFieldError(null, $message, $messageType, $code, $escapeHtml);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Record an error against this validation result,
|
|
|
|
*
|
|
|
|
* @param string $fieldName The field to link the message to. If omitted; a form-wide message is assumed.
|
|
|
|
* @param string $message The message string.
|
|
|
|
* @param string $messageType The type of message: e.g. "bad", "warning", "good", or "required". Passed as a CSS
|
|
|
|
* class to the form, so other values can be used if desired.
|
|
|
|
* @param string $code A codename for this error. Only one message per codename will be added.
|
|
|
|
* This can be usedful for ensuring no duplicate messages
|
|
|
|
* @param bool $escapeHtml Automatically sanitize the message. Set to FALSE if the message contains HTML.
|
|
|
|
* In that case, you might want to use {@link Convert::raw2xml()} to escape any
|
|
|
|
* user supplied data in the message.
|
|
|
|
*/
|
|
|
|
public function addFieldError($fieldName = null, $message, $messageType = "bad", $code = null, $escapeHtml = true) {
|
|
|
|
$this->isValid = false;
|
|
|
|
|
|
|
|
return $this->addFieldMessage($fieldName, $message, $messageType, $code, $escapeHtml);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a message to this ValidationResult without necessarily marking it as an error
|
|
|
|
*
|
|
|
|
* @param string $message The message string.
|
|
|
|
* @param string $messageType The type of message: e.g. "bad", "warning", "good", or "required". Passed as a CSS
|
|
|
|
* class to the form, so other values can be used if desired.
|
|
|
|
* @param string $code A codename for this error. Only one message per codename will be added.
|
|
|
|
* This can be usedful for ensuring no duplicate messages
|
|
|
|
* @param bool $escapeHtml Automatically sanitize the message. Set to FALSE if the message contains HTML.
|
|
|
|
* In that case, you might want to use {@link Convert::raw2xml()} to escape any
|
|
|
|
* user supplied data in the message.
|
|
|
|
*/
|
|
|
|
public function addMessage($message, $messageType = "bad", $code = null, $escapeHtml = true) {
|
|
|
|
return $this->addFieldMessage(null, $message, $messageType, $code, $escapeHtml);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a message to this ValidationResult without necessarily marking it as an error
|
|
|
|
*
|
|
|
|
* @param string $fieldName The field to link the message to. If omitted; a form-wide message is assumed.
|
|
|
|
* @param string $message The message string.
|
|
|
|
* @param string $messageType The type of message: e.g. "bad", "warning", "good", or "required". Passed as a CSS
|
|
|
|
* class to the form, so other values can be used if desired.
|
|
|
|
* @param string $code A codename for this error. Only one message per codename will be added.
|
|
|
|
* This can be usedful for ensuring no duplicate messages
|
|
|
|
* @param bool $escapeHtml Automatically sanitize the message. Set to FALSE if the message contains HTML.
|
|
|
|
* In that case, you might want to use {@link Convert::raw2xml()} to escape any
|
|
|
|
* user supplied data in the message.
|
|
|
|
*/
|
|
|
|
public function addFieldMessage($fieldName, $message, $messageType = "bad", $code = null, $escapeHtml = true) {
|
|
|
|
$metadata = array(
|
|
|
|
'message' => $escapeHtml ? Convert::raw2xml($message) : $message,
|
|
|
|
'fieldName' => $fieldName,
|
|
|
|
'messageType' => $messageType,
|
|
|
|
);
|
|
|
|
|
|
|
|
if($code) {
|
|
|
|
if(!is_numeric($code)) {
|
|
|
|
$this->errorList[$code] = $metadata;
|
|
|
|
} else {
|
|
|
|
throw new InvalidArgumentException(
|
|
|
|
"ValidationResult::error() - Don't use a numeric code '$code'. Use a string.");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$this->errorList[] = $metadata;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns true if the result is valid.
|
|
|
|
* @return boolean
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function valid()
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
return $this->isValid;
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* Get an array of errors
|
|
|
|
* @return array
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function messageList()
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
$list = array();
|
|
|
|
foreach($this->errorList as $key => $item) {
|
|
|
|
if(is_numeric($key)) $list[] = $item['message'];
|
|
|
|
else $list[$key] = $item['message'];
|
|
|
|
}
|
|
|
|
return $list;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the field-specific messages as a map.
|
|
|
|
* Keys will be field names, and values will be a 2 element map with keys 'messsage', and 'messageType'
|
|
|
|
*/
|
|
|
|
public function fieldErrors() {
|
|
|
|
$output = array();
|
|
|
|
foreach($this->errorList as $key => $item) {
|
|
|
|
if($item['fieldName']) {
|
|
|
|
$output[$item['fieldName']] = array(
|
|
|
|
'message' => $item['message'],
|
|
|
|
'messageType' => $item['messageType']
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $output;
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* Get an array of error codes
|
|
|
|
* @return array
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function codeList()
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
$codeList = array();
|
2016-11-29 12:31:16 +13:00
|
|
|
foreach ($this->errorList as $k => $v) {
|
|
|
|
if (!is_numeric($k)) {
|
|
|
|
$codeList[] = $k;
|
|
|
|
}
|
|
|
|
}
|
2016-11-23 10:29:15 +13:00
|
|
|
return $codeList;
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* Get the error message as a string.
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function message()
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
return implode("; ", $this->messageList());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The the error message that's not related to a field as a string
|
|
|
|
*/
|
|
|
|
public function overallMessage() {
|
|
|
|
$messages = array();
|
|
|
|
foreach($this->errorList as $item) {
|
|
|
|
if(!$item['fieldName']) $messages[] = $item['message'];
|
|
|
|
}
|
|
|
|
return implode("; ", $messages);
|
|
|
|
}
|
2016-11-29 12:31:16 +13:00
|
|
|
|
2016-11-23 10:29:15 +13:00
|
|
|
/**
|
|
|
|
* Get a starred list of all messages
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function starredList()
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
return " * " . implode("\n * ", $this->messageList());
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Combine this Validation Result with the ValidationResult given in other.
|
|
|
|
* It will be valid if both this and the other result are valid.
|
|
|
|
* This object will be modified to contain the new validation information.
|
|
|
|
*
|
|
|
|
* @param ValidationResult $other the validation result object to combine
|
|
|
|
* @return $this
|
|
|
|
*/
|
2016-11-29 12:31:16 +13:00
|
|
|
public function combineAnd(ValidationResult $other)
|
|
|
|
{
|
2016-11-23 10:29:15 +13:00
|
|
|
$this->isValid = $this->isValid && $other->valid();
|
|
|
|
$this->errorList = array_merge($this->errorList, $other->getErrorMetaData());
|
|
|
|
return $this;
|
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|