setup/includes/error/modinstallerror.class.php
<?php
/*
* This file is part of MODX Revolution.
*
* Copyright (c) MODX, LLC. All Rights Reserved.
*
* For complete copyright and license information, see the COPYRIGHT and LICENSE
* files found in the top-level directory of this distribution.
*/
/**
* Abstract error handler for request processing.
*
* @package modx
* @subpackage error
*/
/**
* Abstract class for error handling and validation for requests.
*
* @abstract Implement a derivative of this class for error handling and
* validation of any kind of MODX request.
* @package modx
* @subpackage error
*/
abstract class modInstallError {
/**
* @var array The array of errors
*/
public $errors;
/**
* @var string The error message to output.
*/
public $message;
/**
* @var modX A reference to the $modx object.
*/
public $modx;
/**
* @var integer The total number of errors.
*/
public $total = 0;
/**
* @var boolean Indicates failure or success.
*/
public $status = false;
protected $_objects = array();
function __construct(&$modx, $message = '') {
$this->modx =& $modx;
$this->message = $message;
$this->errors = array ();
}
/**
* Adds an object to the validation queue.
* @access public
* @param xPDOObject $obj An xPDOObject to validate.
*/
public function addObjectToValidate(&$obj) {
if (is_object($obj) && $obj instanceof xPDOObject) {
$this->_objects[]= $obj;
}
}
/**
* Checks validation, and if any errors are found, returns them. Error
* handlers that derive from this can determine their own behaviour should
* errors be found.
* @access public
* @param xPDOObject/array $objs An xPDOObject or array of xPDOObjects to
* add to the validation queue.
* @return string The validation message returned.
*/
public function checkValidation($objs= array()) {
if (is_object($objs)) {
$this->addObjectToValidate($objs);
}
else if (is_array($objs) && !empty($objs)) {
foreach ($objs as $obj) {
$this->addObjectToValidate($obj);
}
}
return $this->_validate();
}
/**
* Grabs formatted validation messages for all objects in the validation
* queue.
* @access private
* @return string The compiled validation message returned.
*/
protected function _validate() {
$s = '';
foreach ($this->_objects as $obj) {
if ($validator= $obj->getValidator()) {
$messages= $validator->getMessages();
if (!empty($messages)) {
foreach ($messages as $message) {
$s .= $message['message'].'<br />'."\n";
}
}
}
}
return $s;
}
/**
* Process errors and return a proper output value.
*
* @param string $message The error message to output.
* @param boolean $status Whether or not the action is a success or failure.
* @param object|array $object The object to send back to output.
* @return string|object|array The transformed object data array.
*/
public function process($message = '', $status = false, $object = null) {
if ($status === true) {
$s = $this->_validate();
if ($s !== '') {
$status = false;
$message = $s;
}
}
$this->status = (boolean) $status;
if ($message != '') {
$this->message = $message;
}
$objarray = array ();
if (is_array($object)) {
$obj = reset($object);
if (is_object($obj) && $obj instanceof xPDOObject) {
$this->total = count($object);
}
unset ($obj);
}
$objarray = $this->toArray($object);
return $objarray;
}
/**
* Add a specific field error to the error queue.
*
* @param string $name The id of the field.
* @param string $error The error message.
*/
public function addField($name, $error) {
$this->errors[] = array (
'id' => $name,
'msg' => $error
);
}
/**
* Return the fields added as errors.
*
* @return array An array of errors for specific fields.
*/
public function getFields() {
$f = array ();
foreach ($this->errors as $fi)
$f[] = $fi['msg'];
return $f;
}
/**
* Check to see if there is any errors on the queue.
*
* @return boolean True if there are errors or a message has been specified.
*/
public function hasError() {
return count($this->errors) > 0 || $this->message != '';
}
/**
* Send a failure error message.
*
* @abstract Redeclare in your modError implementation.
* @param string $message The error message to send.
* @param object|array|string $object An object to send back to the output.
*/
abstract public function failure($message = '', $object = null);
/**
* Send a success error message.
*
* @abstract Redeclare in your modError implementation.
* @param string $message The error message to send.
* @param object|array|string $object An object to send back to the output.
* @param boolean $notxpdo If $object is not an xPDOObject, then set to true.
*/
abstract public function success($message = '', $object = null);
/**
* Converts an object or objects embedded in an array, to arrays.
*
* This function also makes sure that any members of the array are not PHP
* resource types (e.g. database connections, file handles, etc.).
*
* @param array|object $object An array or object to process.
* @return array Returns an array representation of the object(s).
*/
public function toArray($object) {
$array = array ();
if (is_array($object)) {
foreach ($object as $key => $value) {
if (!is_resource($value)) {
if (is_object($value) || is_array($value)) {
$array[$key] = $this->toArray($value);
} else {
$array[$key] = $value;
}
}
}
}
elseif (is_object($object)) {
if ($object instanceof xPDOObject) {
$array = $this->toArray($object->toArray());
} else {
$array = $this->toArray(get_object_vars($object));
}
}
return $array;
}
}