@ -1,9 +1,9 @@
<?php
<?php
/**
/**
* @file
* @file
* Fedora Item
* Fedora Item
*/
*/
define('RELS_EXT_URI', 'info:fedora/fedora-system:def/relations-external#');
define('RELS_EXT_URI', 'info:fedora/fedora-system:def/relations-external#');
define("FEDORA_MODEL_URI", 'info:fedora/fedora-system:def/model#');
define("FEDORA_MODEL_URI", 'info:fedora/fedora-system:def/model#');
define("ISLANDORA_PAGE_URI", 'info:islandora/islandora-system:def/pageinfo#');
define("ISLANDORA_PAGE_URI", 'info:islandora/islandora-system:def/pageinfo#');
@ -25,7 +25,6 @@ class Fedora_Item {
public $pid = NULL;
public $pid = NULL;
public $objectProfile = NULL;
public $objectProfile = NULL;
public $ownerId = NULL;
public $ownerId = NULL;
// A SimpleXML object to store a list of this item's datastreams.
// A SimpleXML object to store a list of this item's datastreams.
private $datastreams_list = NULL;
private $datastreams_list = NULL;
public $datastreams = NULL;
public $datastreams = NULL;
@ -338,7 +337,7 @@ RDF;
// Casting a string to an array gives an array containing the string, and
// Casting a string to an array gives an array containing the string, and
// casting an array to an array does nothing.
// casting an array to an array does nothing.
foreach ((array)$object as $obj) {
foreach ((array) $object as $obj) {
if ($literal_value == RELS_TYPE_URI & & strpos($obj, $f_prefix) !== 0) {
if ($literal_value == RELS_TYPE_URI & & strpos($obj, $f_prefix) !== 0) {
$obj = $f_prefix . $obj;
$obj = $f_prefix . $obj;
}
}
@ -399,7 +398,7 @@ RDF;
$relsxml->documentElement->appendChild($description);
$relsxml->documentElement->appendChild($description);
}
}
foreach ((array)$object as $obj) {
foreach ((array) $object as $obj) {
if ($literal_value == RELS_TYPE_URI & & strpos($obj, $f_prefix) !== 0) {
if ($literal_value == RELS_TYPE_URI & & strpos($obj, $f_prefix) !== 0) {
$obj = $f_prefix . $object;
$obj = $f_prefix . $object;
}
}
@ -494,8 +493,8 @@ RDF;
$rels = $desc->getElementsByTagNameNS($namespaceURI, $relationship);
$rels = $desc->getElementsByTagNameNS($namespaceURI, $relationship);
if (!empty($rels)) {
if (!empty($rels)) {
// Iterate backwards so if we delete something our pointer doesn't get out of sync.
// Iterate backwards so if we delete something our pointer doesn't get out of sync.
for ($i = $rels->length; $i>0; $i--) {
for ($i = $rels->length; $i > 0; $i--) {
$rel = $rels->item($i-1);
$rel = $rels->item($i - 1);
// foreach ($rels as $rel) { // moving forward like this caused iteration errors when something was deleted
// foreach ($rels as $rel) { // moving forward like this caused iteration errors when something was deleted
// If either no object is specified, or the object matches (in either the literal or URI case), remove this node from it's parent, and mark as changed.
// If either no object is specified, or the object matches (in either the literal or URI case), remove this node from it's parent, and mark as changed.
if (
if (
@ -1445,6 +1444,7 @@ RDF;
* The return value from the soap function if successful, NULL otherwise.
* The return value from the soap function if successful, NULL otherwise.
*/
*/
static function soap_call($function, $parameters, $quiet = FALSE) {
static function soap_call($function, $parameters, $quiet = FALSE) {
module_load_include('inc', 'fedora_repository', 'ObjectHelper');
if (!self::$connection_helper) {
if (!self::$connection_helper) {
module_load_include('inc', 'fedora_repository', 'ConnectionHelper');
module_load_include('inc', 'fedora_repository', 'ConnectionHelper');
self::$connection_helper = new ConnectionHelper();
self::$connection_helper = new ConnectionHelper();
@ -1467,7 +1467,7 @@ RDF;
return NULL;
return NULL;
}
}
} catch (Exception $e) {
} catch (Exception $e) {
if (!$quiet) {
if (!$quiet & & user_access($VIEW_FEDORA_SOAP_ERROR_MESSAGES) ) {
preg_match('/org\.fcrepo\.server\.security\.xacml\.pep\.AuthzDeniedException/', $e->getMessage()) ?
preg_match('/org\.fcrepo\.server\.security\.xacml\.pep\.AuthzDeniedException/', $e->getMessage()) ?
drupal_set_message(t('Insufficient permissions to call SOAP function "%func".', array('%func' => $function)), 'error') :
drupal_set_message(t('Insufficient permissions to call SOAP function "%func".', array('%func' => $function)), 'error') :
drupal_set_message(t('Error trying to call SOAP function "%func". Check watchdog logs for more information.', array('%func' => $function)), 'error');
drupal_set_message(t('Error trying to call SOAP function "%func". Check watchdog logs for more information.', array('%func' => $function)), 'error');
@ -1595,4 +1595,5 @@ RDF;
return $ownerId;
return $ownerId;
}
}
}
}