Implemented AS prefs for addressbook:

- which addressbooks to sync
- sync selected as one addrressbook (for devices only supporting on addressbook)
This commit is contained in:
Ralf Becker 2011-03-19 12:51:50 +00:00
parent 9888fb0c2f
commit dbce0992af

View File

@ -106,26 +106,54 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
/** /**
* Get addressbooks (no extra private one and do some caching) * Get addressbooks (no extra private one and do some caching)
* *
* Takes addessbook-abs and addressbook-all-in-one preference into account.
*
* @param int $account=null account_id of addressbook or null to get array of all addressbooks * @param int $account=null account_id of addressbook or null to get array of all addressbooks
* @param boolean $return_all_in_one=true if false and all-in-one pref is set, return all selected abs
* if true only the all-in-one ab is returned (with id of personal ab)
* @return string|array addressbook name of array with int account_id => label pairs * @return string|array addressbook name of array with int account_id => label pairs
*/ */
private function get_addressbooks($account=null) private function get_addressbooks($account=null,$return_all_in_one=true)
{ {
static $abs; static $abs;
if (!isset($abs)) if (!isset($abs) || !$resolve_all_in_one)
{ {
translation::add_app('addressbook'); // we need the addressbook translations if ($return_all_in_one && $GLOBALS['egw_info']['user']['preferences']['activesync']['addressbook-all-in-one'])
if ($GLOBALS['egw_info']['user']['preferences']['addressbook']['private_addressbook'])
{ {
unset($GLOBALS['egw_info']['user']['preferences']['addressbook']['private_addressbook']); $abs = array(
if (isset($this->addressbook)) $this->addressbook->private_addressbook = false; $GLOBALS['egw_info']['user']['account_id'] => lang('All'),
);
} }
if (!isset($this->addressbook)) $this->addressbook = new addressbook_bo(); else
{
translation::add_app('addressbook'); // we need the addressbook translations
$abs = $this->addressbook->get_addressbooks(EGW_ACL_READ); if ($GLOBALS['egw_info']['user']['preferences']['addressbook']['private_addressbook'])
{
unset($GLOBALS['egw_info']['user']['preferences']['addressbook']['private_addressbook']);
if (isset($this->addressbook)) $this->addressbook->private_addressbook = false;
}
if (!isset($this->addressbook)) $this->addressbook = new addressbook_bo();
// error_log(print_r($this->addressbook->get_addressbooks(EGW_ACL_READ),true));
$pref_abs = $GLOBALS['egw_info']['user']['preferences']['activesync']['addressbook-abs'];
if (empty($pref_abs)) $pref_abs = 'P'; // implicit default
$pref_abs = explode(',',$pref_abs);
foreach ($this->addressbook->get_addressbooks() as $account_id => $label)
{
if ($account_id && in_array($account,$pref_abs) || in_array('A',$pref_abs) ||
$account_id == 0 && in_array('U',$pref_abs) ||
$account_id == $GLOBALS['egw_info']['user']['account_id'] && in_array('P',$pref_abs) ||
$account_id == $GLOBALS['egw_info']['user']['account_primary_group'] && in_array('G',$pref_abs))
{
$abs[$account_id] = $label;
}
}
}
} }
//error_log(__METHOD__."($account) returning ".array2string(is_null($account) ? $abs : $abs[$account]));
return is_null($account) ? $abs : $abs[$account]; return is_null($account) ? $abs : $abs[$account];
} }
@ -137,7 +165,6 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
public function GetFolderList() public function GetFolderList()
{ {
// error_log(print_r($this->addressbook->get_addressbooks(EGW_ACL_READ),true)); // error_log(print_r($this->addressbook->get_addressbooks(EGW_ACL_READ),true));
foreach ($this->get_addressbooks() as $account => $label) foreach ($this->get_addressbooks() as $account => $label)
{ {
$folderlist[] = array( $folderlist[] = array(
@ -145,7 +172,7 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
'mod' => $label, 'mod' => $label,
'parent'=> '0', 'parent'=> '0',
); );
}; }
debugLog(__METHOD__."() returning ".array2string($folderlist)); debugLog(__METHOD__."() returning ".array2string($folderlist));
//error_log(__METHOD__."() returning ".array2string($folderlist)); //error_log(__METHOD__."() returning ".array2string($folderlist));
return $folderlist; return $folderlist;
@ -174,6 +201,14 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
{ {
$folderObj->type = SYNC_FOLDER_TYPE_USER_CONTACT; $folderObj->type = SYNC_FOLDER_TYPE_USER_CONTACT;
} }
/*
// not existing folder requested --> return false
if (is_null($folderObj->displayname))
{
$folderObj = false;
debugLog(__METHOD__."($id) returning ".array2string($folderObj));
}
*/
//error_log(__METHOD__."('$id') returning ".array2string($folderObj)); //error_log(__METHOD__."('$id') returning ".array2string($folderObj));
return $folderObj; return $folderObj;
} }
@ -200,6 +235,14 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
'mod' => $this->get_addressbooks($owner), 'mod' => $this->get_addressbooks($owner),
'parent' => '0', 'parent' => '0',
); );
/*
// not existing folder requested --> return false
if (is_null($stat['mod']))
{
$stat = false;
debugLog(__METHOD__."('$id') ".function_backtrace());
}
*/
//error_log(__METHOD__."('$id') returning ".array2string($stat)); //error_log(__METHOD__."('$id') returning ".array2string($stat));
debugLog(__METHOD__."('$id') returning ".array2string($stat)); debugLog(__METHOD__."('$id') returning ".array2string($stat));
return $stat; return $stat;
@ -227,6 +270,12 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
$this->backend->splitID($id,$type,$user); $this->backend->splitID($id,$type,$user);
$filter = array('owner' => $user); $filter = array('owner' => $user);
if ($GLOBALS['egw_info']['user']['preferences']['activesync']['addressbook-all-in-one'] &&
$user == $GLOBALS['egw_info']['user']['account_id'])
{
$filter['owner'] = array_keys($this->get_addressbooks(null,false)); // false = return all selected abs
}
$messagelist = array(); $messagelist = array();
if (($contacts =& $this->addressbook->search($criteria,'contact_id,contact_etag',$order_by='',$extra_cols='',$wildcard='', if (($contacts =& $this->addressbook->search($criteria,'contact_id,contact_etag',$order_by='',$extra_cols='',$wildcard='',
$empty=false,$op='AND',$start=false,$filter))) $empty=false,$op='AND',$start=false,$filter)))
@ -405,7 +454,11 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
debugLog(__METHOD__." Folder wrong or contact not existing"); debugLog(__METHOD__." Folder wrong or contact not existing");
return false; return false;
} }
if ($account == 0) return false; //no changing of accounts if ($account == 0) // as a precausion, we currently do NOT allow to change accounts
{
debugLog(__METHOD__." Changing of accounts denied!");
return false; //no changing of accounts
}
$contact = array(); $contact = array();
if ((empty($id) && ($this->addressbook->grants[$account] & EGW_ACL_EDIT)) || ( $contact = $this->addressbook->read($id) && $this->addressbook->check_perms(EGW_ACL_EDIT, $id))) if ((empty($id) && ($this->addressbook->grants[$account] & EGW_ACL_EDIT)) || ( $contact = $this->addressbook->read($id) && $this->addressbook->check_perms(EGW_ACL_EDIT, $id)))
{ {
@ -438,11 +491,16 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
break; break;
} }
} }
// for all-in-one addressbook, account is meaningless and wrong!
$contact['owner'] = $account; // addressbook_bo::save() keeps the owner or sets an appropriate one if none given
if (!$GLOBALS['egw_info']['user']['preferences']['activesync']['addressbook-all-in-one'])
{
$contact['owner'] = $account;
}
if (!empty($id)) $contact['id'] = $id; if (!empty($id)) $contact['id'] = $id;
$this->addressbook->fixup_contact($contact); $this->addressbook->fixup_contact($contact);
$newid = $this->addressbook->save($contact); $newid = $this->addressbook->save($contact);
error_log(__METHOD__."($folderid,$id) addressbook(".array2string($contact).") returning ".array2string($newid));
return $this->StatMessage($folderid, $newid); return $this->StatMessage($folderid, $newid);
} }
return false; return false;
@ -461,10 +519,17 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
* to have a new parent. This means that it will disappear from GetMessageList() will not return the item * to have a new parent. This means that it will disappear from GetMessageList() will not return the item
* at all on the source folder, and the destination folder will show the new message * at all on the source folder, and the destination folder will show the new message
* *
* @ToDo: If this gets implemented, we have to take into account the 'addressbook-all-in-one' pref!
*/ */
public function MoveMessage($folderid, $id, $newfolderid) public function MoveMessage($folderid, $id, $newfolderid)
{ {
error_log(__METHOD__); if ($GLOBALS['egw_info']['user']['preferences']['activesync']['addressbook-all-in-one'])
{
debugLog(__METHOD__."('$folderid', $id, $newfolderid) NOT allowed for an all-in-one addressbook --> returning false");
return false;
}
debugLog(__METHOD__."('$folderid', $id, $newfolderid) NOT implemented --> returning false");
return false;
} }
@ -569,4 +634,64 @@ class addressbook_activesync implements activesync_plugin_write, activesync_plug
} }
return $items; return $items;
} }
/**
* Populates $settings for the preferences
*
* @param array|string $hook_data
* @return array
*/
function settings($hook_data)
{
if ($hook_data['setup'])
{
$addressbooks = array();
}
else
{
$user = $GLOBALS['egw_info']['user']['account_id'];
$addressbook_bo = new addressbook_bo();
$addressbooks = $addressbook_bo->get_addressbooks(EGW_ACL_READ);
unset($addressbooks[$user]); // Use P for personal addressbook
unset($addressbooks[$user.'p']);// ignore (optional) private addressbook for now
}
$addressbooks = array(
'P' => lang('Personal'),
'G' => lang('Primary Group'),
'U' => lang('Accounts'),
'A' => lang('All'),
) + $addressbooks;
// rewriting owner=0 to 'U', as 0 get's always selected by prefs
if (!isset($addressbooks[0]))
{
unset($addressbooks['U']);
}
else
{
unset($addressbooks[0]);
}
$settings['addressbook-abs'] = array(
'type' => 'multiselect',
'label' => 'Addressbooks to sync',
'name' => 'addressbook-abs',
'help' => 'Global address search always searches in all addressbooks, so you dont need to sync all addressbooks to be able to access them, if you are online.',
'values' => $addressbooks,
'xmlrpc' => True,
'admin' => False,
'default' => 'P',
);
$settings['addressbook-all-in-user'] = array(
'type' => 'check',
'label' => 'Sync all addressbooks as one',
'name' => 'addressbook-all-in-one',
'help' => 'Not all clients support multiple addressbooks, so you can choose to sync all above selected addressbooks as one.',
'xmlrpc' => true,
'admin' => false,
'default' => '0',
);
return $settings;
}
} }