mirror of
https://git.code.sf.net/p/seeddms/code
synced 2025-05-12 12:41:30 +00:00
better error checking when setting a custom attribute
This commit is contained in:
parent
2317c092d6
commit
63d4ee9460
|
@ -904,6 +904,9 @@ class HTTP_WebDAV_Server_SeedDMS extends HTTP_WebDAV_Server
|
||||||
} else {
|
} else {
|
||||||
$this->logger->log('PROPPATCH: set '.$prop["ns"].''.$prop["val"].' to '.$prop["val"], PEAR_LOG_INFO);
|
$this->logger->log('PROPPATCH: set '.$prop["ns"].''.$prop["val"].' to '.$prop["val"], PEAR_LOG_INFO);
|
||||||
if($prop["ns"] == "SeedDMS:") {
|
if($prop["ns"] == "SeedDMS:") {
|
||||||
|
if(in_array($prop['name'], array('id', 'version', 'status', 'status-comment', 'status-date'))) {
|
||||||
|
$options["props"][$key]['status'] = "403 Forbidden";
|
||||||
|
} else {
|
||||||
if (isset($prop["val"]))
|
if (isset($prop["val"]))
|
||||||
$val = $prop["val"];
|
$val = $prop["val"];
|
||||||
else
|
else
|
||||||
|
@ -917,31 +920,13 @@ class HTTP_WebDAV_Server_SeedDMS extends HTTP_WebDAV_Server
|
||||||
$valueset = $attrdef->getValueSetAsArray();
|
$valueset = $attrdef->getValueSetAsArray();
|
||||||
switch($attrdef->getType()) {
|
switch($attrdef->getType()) {
|
||||||
case SeedDMS_Core_AttributeDefinition::type_string:
|
case SeedDMS_Core_AttributeDefinition::type_string:
|
||||||
if($valueset) {
|
|
||||||
if(in_array($val, $valueset)) {
|
|
||||||
$obj->setAttributeValue($attrdef, $val);
|
$obj->setAttributeValue($attrdef, $val);
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$obj->setAttributeValue($attrdef, $val);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case SeedDMS_Core_AttributeDefinition::type_int:
|
case SeedDMS_Core_AttributeDefinition::type_int:
|
||||||
if($valueset) {
|
|
||||||
if(in_array($val, $valueset)) {
|
|
||||||
$obj->setAttributeValue($attrdef, (int) $val);
|
$obj->setAttributeValue($attrdef, (int) $val);
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$obj->setAttributeValue($attrdef, (int) $val);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case SeedDMS_Core_AttributeDefinition::type_float:
|
case SeedDMS_Core_AttributeDefinition::type_float:
|
||||||
if($valueset) {
|
|
||||||
if(in_array($val, $valueset)) {
|
|
||||||
$obj->setAttributeValue($attrdef, (float) $val);
|
$obj->setAttributeValue($attrdef, (float) $val);
|
||||||
}
|
|
||||||
} else {
|
|
||||||
$obj->setAttributeValue($attrdef, (float) $val);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
case SeedDMS_Core_AttributeDefinition::type_boolean:
|
case SeedDMS_Core_AttributeDefinition::type_boolean:
|
||||||
$obj->setAttributeValue($attrdef, $val == 1 ? true : false);
|
$obj->setAttributeValue($attrdef, $val == 1 ? true : false);
|
||||||
|
@ -952,6 +937,7 @@ class HTTP_WebDAV_Server_SeedDMS extends HTTP_WebDAV_Server
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return "";
|
return "";
|
||||||
} /* }}} */
|
} /* }}} */
|
||||||
|
|
Loading…
Reference in New Issue
Block a user