XML element in the COPY/MOVE request body.
*
* An instance of this class represents the XML element,
* that may optionally be contained in the body of a COPY or MOVE request.
* Either of the properties $keepAlive or $omit may be set, but not both of
* them at once.
*
* The $keepAlive property may contain an array of URIs, indicating the
* properties that must be kept alive during the operation, the constant value
* ezcWebdavRequestPropertyBehaviourContent::ALL to indicate that all
* properties must be processed live or null, if the $omit property is set to
* true. Otherwise an ezcBaseValueException will be thrown.
*
* The $omit property may contain either true or false and must be false if the
* $keepAlive property is used. Otherwise an ezcBaseValueException will be
* thrown.
*
* @package Webdav
* @version 1.0
*
* @property array|int $keepAlive
* Represents the XML element.
* @property bool $omit
* Represents the XML element.
*/
class ezcWebdavRequestPropertyBehaviourContent extends ezcWebdavInfrastructureBase
{
/**
* Indicates that the XML element contained #PCDATA *.
*/
const ALL = 0;
/**
* Container to hold the properties
*
* @var array(string=>mixed)
*/
protected $properties = array();
/**
* Creates a new instance.
*
* @return void
*/
public function __construct()
{
$this->properties['keepAlive'] = null;
$this->properties['omit'] = false;
}
/**
* Sets a property.
*
* This method is called when an property is to be set.
*
* @param string $propertyName The name of the property to set.
* @param mixed $propertyValue The property value.
* @ignore
*
* @throws ezcBasePropertyNotFoundException
* if the given property does not exist.
* @throws ezcBaseValueException
* if the value to be assigned to a property is invalid.
* @throws ezcBasePropertyPermissionException
* if the property to be set is a read-only property.
*/
public function __set( $propertyName, $propertyValue )
{
switch ( $propertyName )
{
case 'keepAlive':
if ( is_array( $propertyValue ) === false && $propertyValue !== self::ALL && $propertyValue !== null )
{
throw new ezcBaseValueException(
$propertyName,
$propertyValue,
'array(string), self::ALL or null'
);
}
if ( $propertyValue !== null && $this->omit === true )
{
throw new ezcBaseValueException(
$propertyName,
$propertyValue,
'property $omit must be false'
);
}
break;
case 'omit':
if ( is_bool( $propertyValue ) === false )
{
throw new ezcBaseValueException( $propertyName, $propertyValue, 'bool' );
}
if ( $propertyValue !== null && $this->keepAlive !== null )
{
throw new ezcBaseValueException(
$propertyName,
$propertyValue,
'property $keepAlive must be null'
);
}
break;
default:
throw new ezcBasePropertyNotFoundException( $propertyName );
}
$this->properties[$propertyName] = $propertyValue;
}
/**
* Property get access.
*
* Simply returns a given property.
*
* @throws ezcBasePropertyNotFoundException
* If a the value for the property propertys is not an instance of
* @param string $propertyName The name of the property to get.
* @return mixed The property value.
*
* @ignore
*
* @throws ezcBasePropertyNotFoundException
* if the given property does not exist.
* @throws ezcBasePropertyPermissionException
* if the property to be set is a write-only property.
*/
public function __get( $propertyName )
{
if ( $this->__isset( $propertyName ) === true )
{
return $this->properties[$propertyName];
}
throw new ezcBasePropertyNotFoundException( $propertyName );
}
/**
* Returns if a property exists.
*
* Returns true if the property exists in the {@link $properties} array
* (even if it is null) and false otherwise.
*
* @param string $propertyName Option name to check for.
* @return void
* @ignore
*/
public function __isset( $propertyName )
{
return array_key_exists( $propertyName, $this->properties );
}
}
?>