2009-11-01 11:42:23 +00:00
|
|
|
<?php
|
2012-06-05 13:13:21 +02:00
|
|
|
// This file is part of Moodle - http://moodle.org/
|
|
|
|
//
|
|
|
|
// Moodle is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// Moodle is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
|
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This class represent the XMLDB base class where all the common pieces are defined
|
|
|
|
*
|
|
|
|
* @package core_xmldb
|
|
|
|
* @copyright 1999 onwards Martin Dougiamas http://dougiamas.com
|
|
|
|
* 2001-3001 Eloy Lafuente (stronk7) http://contiento.com
|
|
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
|
|
*/
|
|
|
|
|
|
|
|
defined('MOODLE_INTERNAL') || die();
|
2006-08-15 09:14:31 +00:00
|
|
|
|
|
|
|
|
2008-05-20 17:06:26 +00:00
|
|
|
class xmldb_object {
|
2006-09-20 21:00:45 +00:00
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
/** @var string name of obejct */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $name;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var string comment on object */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $comment;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var xmldb_object */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $previous;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var xmldb_object */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $next;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var string hash of object */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $hash;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var bool is it loaded yet */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $loaded;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var bool was object changed */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $changed;
|
2012-06-05 13:13:21 +02:00
|
|
|
|
|
|
|
/** @var string error message */
|
2006-08-15 09:14:31 +00:00
|
|
|
var $errormsg;
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* Creates one new xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $name
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
2008-05-20 17:06:26 +00:00
|
|
|
function __construct($name) {
|
2006-08-15 09:14:31 +00:00
|
|
|
$this->name = $name;
|
|
|
|
$this->comment = NULL;
|
|
|
|
$this->previous = NULL;
|
|
|
|
$this->next = NULL;
|
|
|
|
$this->hash = NULL;
|
|
|
|
$this->loaded = false;
|
|
|
|
$this->changed = false;
|
|
|
|
$this->errormsg = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function returns true/false, if the xmldb_object has been loaded
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function isLoaded() {
|
|
|
|
return $this->loaded;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function returns true/false, if the xmldb_object has changed
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function hasChanged() {
|
|
|
|
return $this->changed;
|
|
|
|
}
|
|
|
|
|
2006-09-20 21:00:45 +00:00
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function returns the comment of one xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return string
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getComment() {
|
|
|
|
return $this->comment;
|
|
|
|
}
|
|
|
|
|
2006-09-20 21:00:45 +00:00
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function returns the hash of one xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return string
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getHash() {
|
|
|
|
return $this->hash;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will return the name of the previous xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return xmldb_object
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getPrevious() {
|
|
|
|
return $this->previous;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will return the name of the next xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return xmldb_object
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getNext() {
|
|
|
|
return $this->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will return the name of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return string
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getName() {
|
|
|
|
return $this->name;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will return the error detected in the object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return string
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function getError() {
|
|
|
|
return $this->errormsg;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the comment of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $comment
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setComment($comment) {
|
|
|
|
$this->comment = $comment;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the previous of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param xmldb_object $previous
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setPrevious($previous) {
|
|
|
|
$this->previous = $previous;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the next of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param xmldb_object $next
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setNext($next) {
|
|
|
|
$this->next = $next;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the hash of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $hash
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setHash($hash) {
|
|
|
|
$this->hash = $hash;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the loaded field of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param bool $loaded
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setLoaded($loaded = true) {
|
|
|
|
$this->loaded = $loaded;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the changed field of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param bool $changed
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setChanged($changed = true) {
|
|
|
|
$this->changed = $changed;
|
|
|
|
}
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will set the name field of the xmldb_object
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $name
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function setName($name) {
|
|
|
|
$this->name = $name;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will check if one key name is ok or no (true/false)
|
|
|
|
* only lowercase a-z, 0-9 and _ are allowed
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function checkName () {
|
|
|
|
$result = true;
|
|
|
|
|
2009-11-17 01:36:35 +00:00
|
|
|
if ($this->name != preg_replace('/[^a-z0-9_ -]/i', '', $this->name)) {
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will check that all the elements in one array
|
|
|
|
* have a correct name [a-z0-9_]
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param array $arr
|
|
|
|
* @return bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function checkNameValues(&$arr) {
|
|
|
|
$result = true;
|
2012-06-05 13:13:21 +02:00
|
|
|
// TODO: Perhaps, add support for reserved words
|
2006-08-15 09:14:31 +00:00
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check the name only contains valid chars
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($arr) {
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (!$element->checkName()) {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check there aren't duplicate names
|
2009-05-26 17:24:52 +00:00
|
|
|
if ($arr) {
|
|
|
|
$existing_fields = array();
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (in_array($element->getName(), $existing_fields)) {
|
|
|
|
debugging('Object ' . $element->getName() . ' is duplicated!', DEBUG_DEVELOPER);
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
$existing_fields[] = $element->getName();
|
|
|
|
}
|
|
|
|
}
|
2006-08-15 09:14:31 +00:00
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
2007-07-05 16:24:24 +00:00
|
|
|
/**
|
|
|
|
* Reconstruct previous/next attributes.
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param array $arr
|
|
|
|
* @return bool
|
2007-07-05 16:24:24 +00:00
|
|
|
*/
|
|
|
|
function fixPrevNext(&$arr) {
|
|
|
|
global $CFG;
|
|
|
|
|
|
|
|
if (empty($CFG->xmldbreconstructprevnext)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
$tweaked = false;
|
|
|
|
|
|
|
|
$prev = null;
|
|
|
|
foreach ($arr as $key=>$el) {
|
|
|
|
$prev_value = $arr[$key]->previous;
|
|
|
|
$next_value = $arr[$key]->next;
|
|
|
|
|
|
|
|
$arr[$key]->next = null;
|
|
|
|
$arr[$key]->previous = null;
|
|
|
|
if ($prev !== null) {
|
|
|
|
$arr[$prev]->next = $arr[$key]->name;
|
|
|
|
$arr[$key]->previous = $arr[$prev]->name;
|
|
|
|
}
|
|
|
|
$prev = $key;
|
|
|
|
|
|
|
|
if ($prev_value != $arr[$key]->previous or $next_value != $arr[$key]->next) {
|
|
|
|
$tweaked = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tweaked;
|
|
|
|
}
|
|
|
|
|
2006-09-20 21:00:45 +00:00
|
|
|
/**
|
2006-08-15 09:14:31 +00:00
|
|
|
* This function will check that all the elements in one array
|
|
|
|
* have a consistent info in their previous/next fields
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param array $arr
|
|
|
|
* @return bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function checkPreviousNextValues(&$arr) {
|
2007-04-20 00:10:52 +00:00
|
|
|
global $CFG;
|
|
|
|
if (!empty($CFG->xmldbdisablenextprevchecking)) {
|
|
|
|
return true;
|
|
|
|
}
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = true;
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that only one element has the previous not set
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($arr) {
|
|
|
|
$counter = 0;
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (!$element->getPrevious()) {
|
|
|
|
$counter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($counter != 1) {
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('The number of objects with previous not set is different from 1', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that only one element has the next not set
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
$counter = 0;
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (!$element->getNext()) {
|
|
|
|
$counter++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($counter != 1) {
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('The number of objects with next not set is different from 1', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that all the previous elements are existing elements
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if ($element->getPrevious()) {
|
|
|
|
$i = $this->findObjectInArray($element->getPrevious(), $arr);
|
|
|
|
if ($i === NULL) {
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('Object ' . $element->getName() . ' says PREVIOUS="' . $element->getPrevious() . '" but that other object does not exist.', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that all the next elements are existing elements
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if ($element->getNext()) {
|
|
|
|
$i = $this->findObjectInArray($element->getNext(), $arr);
|
|
|
|
if ($i === NULL) {
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('Object ' . $element->getName() . ' says NEXT="' . $element->getNext() . '" but that other object does not exist.', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that there aren't duplicates in the previous values
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
$existarr = array();
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (in_array($element->getPrevious(), $existarr)) {
|
|
|
|
$result = false;
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('Object ' . $element->getName() . ' says PREVIOUS="' . $element->getPrevious() . '" but another object has already said that!', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
} else {
|
|
|
|
$existarr[] = $element->getPrevious();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that there aren't duplicates in the next values
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
$existarr = array();
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if (in_array($element->getNext(), $existarr)) {
|
|
|
|
$result = false;
|
2009-05-26 17:24:52 +00:00
|
|
|
debugging('Object ' . $element->getName() . ' says NEXT="' . $element->getNext() . '" but another object has already said that!', DEBUG_DEVELOPER);
|
2006-08-15 09:14:31 +00:00
|
|
|
} else {
|
|
|
|
$existarr[] = $element->getNext();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that there aren't next values pointing to themselves
|
2009-05-26 17:24:52 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if ($element->getNext() == $element->getName()) {
|
|
|
|
$result = false;
|
|
|
|
debugging('Object ' . $element->getName() . ' says NEXT="' . $element->getNext() . '" and that is wrongly recursive!', DEBUG_DEVELOPER);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that there aren't prev values pointing to themselves
|
2009-05-26 17:24:52 +00:00
|
|
|
if ($result && $arr) {
|
|
|
|
foreach($arr as $element) {
|
|
|
|
if ($element->getPrevious() == $element->getName()) {
|
|
|
|
$result = false;
|
|
|
|
debugging('Object ' . $element->getName() . ' says PREVIOUS="' . $element->getPrevious() . '" and that is wrongly recursive!', DEBUG_DEVELOPER);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2006-08-15 09:14:31 +00:00
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This function will order all the elements in one array, following
|
|
|
|
* the previous/next rules
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param array $arr
|
|
|
|
* @return array|bool
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function orderElements($arr) {
|
2007-04-20 00:10:52 +00:00
|
|
|
global $CFG;
|
2006-08-15 09:14:31 +00:00
|
|
|
$result = true;
|
2007-04-20 00:10:52 +00:00
|
|
|
if (!empty($CFG->xmldbdisablenextprevchecking)) {
|
|
|
|
return $arr;
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Create a new array
|
2006-08-15 09:14:31 +00:00
|
|
|
$newarr = array();
|
|
|
|
if (!empty($arr)) {
|
|
|
|
$currentelement = NULL;
|
2012-06-05 13:13:21 +02:00
|
|
|
// Get the element without previous
|
2006-08-15 09:14:31 +00:00
|
|
|
foreach($arr as $key => $element) {
|
|
|
|
if (!$element->getPrevious()) {
|
|
|
|
$currentelement = $arr[$key];
|
|
|
|
$newarr[0] = $arr[$key];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!$currentelement) {
|
|
|
|
$result = false;
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Follow the next rules
|
2006-08-15 09:14:31 +00:00
|
|
|
$counter = 1;
|
|
|
|
while ($result && $currentelement->getNext()) {
|
|
|
|
$i = $this->findObjectInArray($currentelement->getNext(), $arr);
|
|
|
|
$currentelement = $arr[$i];
|
|
|
|
$newarr[$counter] = $arr[$i];
|
|
|
|
$counter++;
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Compare number of elements between original and new array
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($result && count($arr) != count($newarr)) {
|
|
|
|
$result = false;
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check that previous/next is ok (redundant but...)
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($this->checkPreviousNextValues($newarr)) {
|
|
|
|
$result = $newarr;
|
|
|
|
} else {
|
|
|
|
$result = false;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$result = array();
|
|
|
|
}
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the position of one object in the array.
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $objectname
|
|
|
|
* @param array $arr
|
|
|
|
* @return mixed
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function &findObjectInArray($objectname, $arr) {
|
|
|
|
foreach ($arr as $i => $object) {
|
|
|
|
if ($objectname == $object->getName()) {
|
2006-09-20 21:00:45 +00:00
|
|
|
return $i;
|
|
|
|
}
|
|
|
|
}
|
2006-08-15 09:14:31 +00:00
|
|
|
$null = NULL;
|
|
|
|
return $null;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2008-05-20 17:06:26 +00:00
|
|
|
* This function will display a readable info about the xmldb_object
|
2006-08-15 09:14:31 +00:00
|
|
|
* (should be implemented inside each XMLDBxxx object)
|
2012-06-05 13:13:21 +02:00
|
|
|
* @return string
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function readableInfo() {
|
|
|
|
return get_class($this);
|
|
|
|
}
|
|
|
|
|
2006-10-28 15:18:40 +00:00
|
|
|
/**
|
|
|
|
* This function will perform the central debug of all the XMLDB classes
|
2009-11-01 11:42:23 +00:00
|
|
|
* being called automatically every time one error is found. Apart from
|
2006-10-28 15:18:40 +00:00
|
|
|
* the main actions performed in it (XMLDB agnostic) it looks for one
|
|
|
|
* function called xmldb_debug() and invokes it, passing both the
|
2009-11-01 11:42:23 +00:00
|
|
|
* message code and the whole object.
|
2006-10-28 15:18:40 +00:00
|
|
|
* So, to perform custom debugging just add such function to your libs.
|
2009-11-01 11:42:23 +00:00
|
|
|
*
|
2006-10-28 15:18:40 +00:00
|
|
|
* Call to the external hook function can be disabled by request by
|
|
|
|
* defining XMLDB_SKIP_DEBUG_HOOK
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $message
|
2006-10-28 15:18:40 +00:00
|
|
|
*/
|
|
|
|
function debug($message) {
|
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Check for xmldb_debug($message, $xmldb_object)
|
2006-10-28 15:18:40 +00:00
|
|
|
$funcname = 'xmldb_debug';
|
2012-06-05 13:13:21 +02:00
|
|
|
// If exists and XMLDB_SKIP_DEBUG_HOOK is undefined
|
2006-10-28 15:18:40 +00:00
|
|
|
if (function_exists($funcname) && !defined('XMLDB_SKIP_DEBUG_HOOK')) {
|
|
|
|
$funcname($message, $this);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-08-15 09:14:31 +00:00
|
|
|
/**
|
2006-09-20 21:00:45 +00:00
|
|
|
* Returns one array of elements from one comma separated string,
|
2006-08-15 09:14:31 +00:00
|
|
|
* supporting quoted strings containing commas and concat function calls
|
2012-06-05 13:13:21 +02:00
|
|
|
* @param string $string
|
|
|
|
* @return array
|
2006-08-15 09:14:31 +00:00
|
|
|
*/
|
|
|
|
function comma2array($string) {
|
|
|
|
|
|
|
|
$foundquotes = array();
|
|
|
|
$foundconcats = array();
|
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Extract all the concat elements from the string
|
2006-08-15 09:14:31 +00:00
|
|
|
preg_match_all("/(CONCAT\(.*?\))/is", $string, $matches);
|
|
|
|
foreach (array_unique($matches[0]) as $key=>$value) {
|
|
|
|
$foundconcats['<#'.$key.'#>'] = $value;
|
|
|
|
}
|
|
|
|
if (!empty($foundconcats)) {
|
|
|
|
$string = str_replace($foundconcats,array_keys($foundconcats),$string);
|
|
|
|
}
|
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Extract all the quoted elements from the string (skipping
|
|
|
|
// backslashed quotes that are part of the content.
|
2008-07-13 10:52:45 +00:00
|
|
|
preg_match_all("/(''|'.*?[^\\\\]')/is", $string, $matches);
|
2006-08-15 09:14:31 +00:00
|
|
|
foreach (array_unique($matches[0]) as $key=>$value) {
|
|
|
|
$foundquotes['<%'.$key.'%>'] = $value;
|
|
|
|
}
|
|
|
|
if (!empty($foundquotes)) {
|
|
|
|
$string = str_replace($foundquotes,array_keys($foundquotes),$string);
|
|
|
|
}
|
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Explode safely the string
|
2006-08-15 09:14:31 +00:00
|
|
|
$arr = explode (',', $string);
|
|
|
|
|
2012-06-05 13:13:21 +02:00
|
|
|
// Put the concat and quoted elements back again, trimming every element
|
2006-08-15 09:14:31 +00:00
|
|
|
if ($arr) {
|
|
|
|
foreach ($arr as $key => $element) {
|
2012-06-05 13:13:21 +02:00
|
|
|
// Clear some spaces
|
2006-08-15 09:14:31 +00:00
|
|
|
$element = trim($element);
|
2012-06-05 13:13:21 +02:00
|
|
|
// Replace the quoted elements if exists
|
2006-08-15 09:14:31 +00:00
|
|
|
if (!empty($foundquotes)) {
|
|
|
|
$element = str_replace(array_keys($foundquotes), $foundquotes, $element);
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Replace the concat elements if exists
|
2006-08-15 09:14:31 +00:00
|
|
|
if (!empty($foundconcats)) {
|
|
|
|
$element = str_replace(array_keys($foundconcats), $foundconcats, $element);
|
|
|
|
}
|
2012-06-05 13:13:21 +02:00
|
|
|
// Delete any backslash used for quotes. XMLDB stuff will add them before insert
|
2007-03-27 20:31:18 +00:00
|
|
|
$arr[$key] = str_replace("\\'", "'", $element);
|
2006-08-15 09:14:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $arr;
|
|
|
|
}
|
2011-09-12 11:49:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Validates the definition of objects and returns error message.
|
|
|
|
*
|
|
|
|
* The error message should not be localised because it is intended for developers,
|
|
|
|
* end users and admins should never see these problems!
|
|
|
|
*
|
|
|
|
* @param xmldb_table $xmldb_table optional when object is table
|
|
|
|
* @return string null if ok, error message if problem found
|
|
|
|
*/
|
|
|
|
function validateDefinition(xmldb_table $xmldb_table=null) {
|
|
|
|
return null;
|
|
|
|
}
|
2006-08-15 09:14:31 +00:00
|
|
|
}
|