search was missing the email address

This commit is contained in:
Ralf Becker 2006-06-24 05:57:13 +00:00
parent fbcded1a6b
commit 4685b9e003

View File

@ -92,6 +92,23 @@ class socontacts
*/ */
var $memberships; var $memberships;
/**
* LDAP searches only a limited set of attributes for performance reasons,
* you NEED an index for that columns, ToDo: make it configurable
* minimum: $this->columns_to_search = array('n_family','n_given','org_name','email');
*/
var $ldap_search_attributes = array(
'n_family','n_middle','n_given','org_name','org_unit',
'adr_one_location','adr_two_location','note',
'email','mozillasecondemail',
);
/**
* In SQL we can search all columns, though a view make on real sense
*/
var $sql_cols_not_to_search = array(
'jpegphoto','owner','tid','private','id','cat_id',
'modified','modifier','creator','created','tz','account_id',
);
/** /**
* columns to search, if we search for a single pattern * columns to search, if we search for a single pattern
* *
@ -155,7 +172,7 @@ class socontacts
* @var so_sql-object * @var so_sql-object
*/ */
var $soextra; var $soextra;
function socontacts($contact_app='addressbook') function socontacts($contact_app='addressbook')
{ {
$this->user = $GLOBALS['egw_info']['user']['account_id']; $this->user = $GLOBALS['egw_info']['user']['account_id'];
@ -182,9 +199,7 @@ class socontacts
{ {
$this->grants[$gid] = ~0; $this->grants[$gid] = ~0;
} }
// LDAP uses a limited set for performance reasons, you NEED an index for that columns, ToDo: make it configurable $this->columns_to_search = $this->ldap_search_attributes;
// minimum: $this->columns_to_search = array('n_family','n_given','org_name');
$this->columns_to_search = array('n_family','n_middle','n_given','org_name','org_unit','adr_one_location','adr_two_location','note');
} }
else // sql or sql->ldap else // sql or sql->ldap
{ {
@ -197,10 +212,7 @@ class socontacts
$this->grants = $GLOBALS['egw']->acl->get_grants($contact_app,false); $this->grants = $GLOBALS['egw']->acl->get_grants($contact_app,false);
// remove some columns, absolutly not necessary to search in sql // remove some columns, absolutly not necessary to search in sql
$this->columns_to_search = array_diff(array_values($this->somain->db_cols),array( $this->columns_to_search = array_diff(array_values($this->somain->db_cols),$this->sql_cols_not_to_search);
'jpegphoto','owner','tid','private','id','cat_id',
'modified','modifier','creator','created','tz','account_id',
));
} }
if ($this->account_repository == 'ldap' && $this->contact_repository == 'sql') if ($this->account_repository == 'ldap' && $this->contact_repository == 'sql')
{ {
@ -208,7 +220,7 @@ class socontacts
{ {
$this->so_accounts =& CreateObject('addressbook.so_ldap'); $this->so_accounts =& CreateObject('addressbook.so_ldap');
$this->so_accounts->contacts_id = 'id'; $this->so_accounts->contacts_id = 'id';
$this->account_cols_to_search = array('uid','n_family','n_middle','n_given','org_name','org_unit','adr_one_location','adr_two_location','note'); $this->account_cols_to_search = $this->ldap_search_attributes;
} }
else else
{ {
@ -639,6 +651,7 @@ class socontacts
function &search($criteria,$only_keys=True,$order_by='',$extra_cols='',$wildcard='',$empty=False,$op='AND',$start=false,$filter=null,$join='') function &search($criteria,$only_keys=True,$order_by='',$extra_cols='',$wildcard='',$empty=False,$op='AND',$start=false,$filter=null,$join='')
{ {
//echo "<p>socontacts::search(".print_r($criteria,true).",'$only_keys','$order_by','$extra_cols','$wildcard','$empty','$op','$start',".print_r($filter,true).",'$join')</p>\n"; //echo "<p>socontacts::search(".print_r($criteria,true).",'$only_keys','$order_by','$extra_cols','$wildcard','$empty','$op','$start',".print_r($filter,true).",'$join')</p>\n";
error_log("socontacts::search(".print_r($criteria,true).",'$only_keys','$order_by','$extra_cols','$wildcard','$empty','$op','$start',".print_r($filter,true).",'$join')");
$backend =& $this->get_backend(null,$filter['owner']); $backend =& $this->get_backend(null,$filter['owner']);
// single string to search for --> create so_sql conformant search criterial for the standard search columns // single string to search for --> create so_sql conformant search criterial for the standard search columns