/usr/share/php/Horde/Kolab/Format/Xml/Distributionlist.php is in php-horde-kolab-format 2.0.9-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 | <?php
/**
* Implementation for distributionlists in the Kolab XML format.
*
* PHP version 5
*
* @category Kolab
* @package Kolab_Format
* @author Thomas Jarosch <thomas.jarosch@intra2net.com>
* @author Gunnar Wrobel <wrobel@pardus.de>
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @link http://www.horde.org/libraries/Horde_Kolab_Format
*/
/**
* Kolab XML handler for distributionlist groupware objects
*
* Copyright 2007-2009 Klarälvdalens Datakonsult AB
*
* See the enclosed file COPYING for license information (LGPL). If you did not
* receive this file, see
* http://www.horde.org/licenses/lgpl21.
*
* @category Kolab
* @package Kolab_Format
* @author Thomas Jarosch <thomas.jarosch@intra2net.com>
* @author Gunnar Wrobel <wrobel@pardus.de>
* @license http://www.horde.org/licenses/lgpl21 LGPL 2.1
* @link http://www.horde.org/libraries/Horde_Kolab_Format
*/
class Horde_Kolab_Format_Xml_Distributionlist extends Horde_Kolab_Format_Xml
{
/**
* The name of the root element.
*
* @var string
*/
protected $_root_name = 'distribution-list';
/**
* Specific data fields for the contact object
*
* @var array
*/
protected $_fields_specific = array(
'display-name' => 'Horde_Kolab_Format_Xml_Type_String_NotEmpty',
'member' => 'Horde_Kolab_Format_Xml_Type_Multiple_SimplePerson',
);
/**
* Load the groupware object based on the specifc XML values.
*
* @param array &$children An array of XML nodes.
*
* @return array Array with data.
*
* @throws Horde_Kolab_Format_Exception If parsing the XML data failed.
*/
protected function _load(&$children)
{
$object = $this->_loadArray($children, $this->_fields_specific);
// Map the display-name of a kolab dist list to horde's lastname attribute
if (isset($object['display-name'])) {
$object['last-name'] = $object['display-name'];
unset($object['display-name']);
}
/**
* The mapping from $object['member'] as stored in XML back to
* Turba_Objects (contacts) must be performed in the
* Kolab_IMAP storage driver as we need access to the search
* facilities of the kolab storage driver.
*/
$object['__type'] = 'Group';
return $object;
}
/**
* Save the specifc XML values.
*
* @param array $root The XML document root.
* @param array $object The resulting data array.
*
* @return boolean True on success.
*
* @throws Horde_Kolab_Format_Exception If converting the data to XML failed.
*/
protected function _save(&$root, $object)
{
// Map the display-name of a kolab dist list to horde's lastname attribute
if (isset($object['last-name'])) {
$object['display-name'] = $object['last-name'];
unset($object['last-name']);
}
return $this->_saveArray($root, $object, $this->_fields_specific);
}
}
|