2012-03-06 09:58:01 +01:00
|
|
|
<?php
|
|
|
|
|
2012-03-14 19:48:54 +01:00
|
|
|
/**
|
|
|
|
* Kolab Distribution List model class
|
|
|
|
*
|
|
|
|
* @version @package_version@
|
|
|
|
* @author Thomas Bruederli <bruederli@kolabsys.com>
|
|
|
|
*
|
|
|
|
* Copyright (C) 2012, Kolab Systems AG <contact@kolabsys.com>
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program 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 Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
2012-03-06 09:58:01 +01:00
|
|
|
|
|
|
|
class kolab_format_distributionlist extends kolab_format
|
|
|
|
{
|
|
|
|
public $CTYPE = 'application/vcard+xml';
|
2012-11-06 19:03:12 +01:00
|
|
|
public $CTYPEv2 = 'application/x-vnd.kolab.distribution-list';
|
2012-03-06 09:58:01 +01:00
|
|
|
|
2012-11-01 20:06:09 +01:00
|
|
|
protected $objclass = 'DistList';
|
|
|
|
protected $read_func = 'readDistlist';
|
|
|
|
protected $write_func = 'writeDistlist';
|
2012-05-22 10:14:56 +02:00
|
|
|
|
|
|
|
|
2012-03-06 09:58:01 +01:00
|
|
|
/**
|
2012-05-22 10:14:56 +02:00
|
|
|
* Set properties to the kolabformat object
|
2012-03-06 09:58:01 +01:00
|
|
|
*
|
2024-01-26 14:38:48 +01:00
|
|
|
* @param array $object Object data as hash array
|
2012-03-06 09:58:01 +01:00
|
|
|
*/
|
|
|
|
public function set(&$object)
|
|
|
|
{
|
2013-02-21 16:28:12 +01:00
|
|
|
// set common object properties
|
|
|
|
parent::set($object);
|
2012-06-26 16:31:42 +02:00
|
|
|
|
2012-03-08 21:22:09 +01:00
|
|
|
$this->obj->setName($object['name']);
|
|
|
|
|
2024-01-24 11:24:41 +01:00
|
|
|
$seen = [];
|
|
|
|
$members = new vectorcontactref();
|
2014-03-13 18:35:27 +01:00
|
|
|
foreach ((array)$object['member'] as $i => $member) {
|
|
|
|
if ($member['uid']) {
|
|
|
|
$key = 'uid:' . $member['uid'];
|
2012-03-20 23:51:43 +01:00
|
|
|
$m = new ContactReference(ContactReference::UidReference, $member['uid']);
|
2024-01-24 11:24:41 +01:00
|
|
|
} elseif ($member['email']) {
|
2014-03-13 18:35:27 +01:00
|
|
|
$key = 'mailto:' . $member['email'];
|
2012-03-20 23:51:43 +01:00
|
|
|
$m = new ContactReference(ContactReference::EmailReference, $member['email']);
|
2014-03-13 18:35:27 +01:00
|
|
|
$m->setName($member['name']);
|
2024-01-24 11:24:41 +01:00
|
|
|
} else {
|
2012-03-20 23:51:43 +01:00
|
|
|
continue;
|
2014-03-13 18:35:27 +01:00
|
|
|
}
|
2012-03-20 23:51:43 +01:00
|
|
|
|
2023-06-06 14:52:01 +02:00
|
|
|
if (empty($seen[$key])) {
|
2014-03-13 18:35:27 +01:00
|
|
|
$members->push($m);
|
2023-06-06 14:52:01 +02:00
|
|
|
$seen[$key] = true;
|
2024-01-24 11:24:41 +01:00
|
|
|
} else {
|
2014-03-13 18:35:27 +01:00
|
|
|
// remove dupes for caching
|
|
|
|
unset($object['member'][$i]);
|
|
|
|
}
|
2012-03-08 21:22:09 +01:00
|
|
|
}
|
2012-03-20 23:51:43 +01:00
|
|
|
|
2012-03-08 21:22:09 +01:00
|
|
|
$this->obj->setMembers($members);
|
2012-03-30 19:07:56 +02:00
|
|
|
|
2012-09-26 17:49:32 +02:00
|
|
|
// set type property for proper caching
|
|
|
|
$object['_type'] = 'distribution-list';
|
|
|
|
|
2012-03-30 19:07:56 +02:00
|
|
|
// cache this data
|
|
|
|
$this->data = $object;
|
2012-05-02 17:41:02 +02:00
|
|
|
unset($this->data['_formatobj']);
|
2012-03-06 09:58:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function is_valid()
|
|
|
|
{
|
2013-10-16 15:30:51 +02:00
|
|
|
return !$this->formaterror && ($this->data || (is_object($this->obj) && $this->obj->isValid()));
|
2012-03-06 09:58:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert the Distlist object into a hash array data structure
|
|
|
|
*
|
2024-01-26 14:38:48 +01:00
|
|
|
* @param array $data Additional data for merge
|
2013-01-16 09:27:34 +01:00
|
|
|
*
|
2024-01-26 14:38:48 +01:00
|
|
|
* @return array Distribution list data as hash array
|
2012-03-06 09:58:01 +01:00
|
|
|
*/
|
2024-01-24 11:24:41 +01:00
|
|
|
public function to_array($data = [])
|
2012-03-06 09:58:01 +01:00
|
|
|
{
|
|
|
|
// return cached result
|
2024-01-24 11:24:41 +01:00
|
|
|
if (!empty($this->data)) {
|
2012-03-06 09:58:01 +01:00
|
|
|
return $this->data;
|
2024-01-24 11:24:41 +01:00
|
|
|
}
|
2012-03-06 09:58:01 +01:00
|
|
|
|
2013-02-21 16:28:12 +01:00
|
|
|
// read common object props into local data object
|
2013-04-19 14:20:55 +02:00
|
|
|
$object = parent::to_array($data);
|
2012-05-02 17:41:02 +02:00
|
|
|
|
2013-02-21 16:28:12 +01:00
|
|
|
// add object properties
|
2024-01-24 11:24:41 +01:00
|
|
|
$object += [
|
2012-03-06 09:58:01 +01:00
|
|
|
'name' => $this->obj->name(),
|
2024-01-24 11:24:41 +01:00
|
|
|
'member' => [],
|
2012-09-26 17:49:32 +02:00
|
|
|
'_type' => 'distribution-list',
|
2024-01-24 11:24:41 +01:00
|
|
|
];
|
2012-03-06 09:58:01 +01:00
|
|
|
|
|
|
|
$members = $this->obj->members();
|
2024-01-24 11:24:41 +01:00
|
|
|
for ($i = 0; $i < $members->size(); $i++) {
|
2012-03-08 21:22:09 +01:00
|
|
|
$member = $members->get($i);
|
2024-01-24 11:24:41 +01:00
|
|
|
// if ($member->type() == ContactReference::UidReference && ($uid = $member->uid()))
|
|
|
|
$object['member'][] = [
|
|
|
|
'uid' => $member->uid(),
|
|
|
|
'email' => $member->email(),
|
|
|
|
'name' => $member->name(),
|
|
|
|
];
|
2012-03-06 09:58:01 +01:00
|
|
|
}
|
|
|
|
|
2012-03-08 21:22:09 +01:00
|
|
|
$this->data = $object;
|
2012-03-06 09:58:01 +01:00
|
|
|
return $this->data;
|
|
|
|
}
|
|
|
|
}
|