2 require_once('init.php');
6 $ldapfilter = _makeldapfilter();
8 //check public addressbook
9 $sr = ldap_list($LDAP_CON,$conf['publicbook'],$ldapfilter);
10 $result1 = ldap_get_binentries($LDAP_CON, $sr);
11 //check users private addressbook
12 if(!empty($_SESSION['ldapab']['binddn'])){
13 $sr = @ldap_list($LDAP_CON,
14 $conf['privatebook'].','.$_SESSION['ldapab']['binddn'],
16 $result2 = ldap_get_binentries($LDAP_CON, $sr);
19 $result = array_merge((array)$result1,(array)$result2);
21 // select entry template
22 if($_REQUEST['export'] == 'csv'){
23 $entrytpl = 'export_list_csv_entry.tpl';
25 $entrytpl = 'list_entry.tpl';
29 if(count($result)==1 && $_REQUEST['search']){
30 //only one result on a search -> display page
31 header("Location: entry.php?dn=".$result[0]['dn']);
33 }elseif(count($result)){
34 $keys = array_keys($result);
35 uksort($keys,"_namesort");
36 foreach($keys as $key){
37 tpl_entry($result[$key]);
38 $list .= $smarty->fetch($entrytpl);
44 tpl_markers(); //FIXME not needed anymore!?
48 $smarty->assign('list',$list);
49 $smarty->assign('filter',$_REQUEST['filter']);
50 $smarty->assign('marker',$_REQUEST['marker']);
51 $smarty->assign('search',$_REQUEST['search']);
53 if($_REQUEST['export'] == 'csv'){
54 if ($conf['userlogreq'] == 1 && $user == '')
56 header("HTTP/1.1 401 ACCESS DENIED");
59 header("Content-Type: text/csv");
60 header('Content-Disposition: Attachement; filename="ldapabexport.csv"');
61 $smarty->display('export_list_csv.tpl');
64 //save location in session
65 $_SESSION['ldapab']['lastlocation']=$_SERVER["REQUEST_URI"];
67 header('Content-Type: text/html; charset=utf-8');
68 $smarty->display('list.tpl');
71 //------- functions -----------//
74 * callback function to sort entries by name
77 function _namesort($a,$b){
79 $x = $result[$a]['sn'][0].$result[$a]['givenName'][0];
80 $y = $result[$b]['sn'][0].$result[$b]['givenName'][0];
81 return(strcasecmp($x,$y));
86 * Creates an LDAP filter from given request variables search or filter
88 function _makeldapfilter(){
91 $filter = ldap_filterescape($_REQUEST['filter']);
92 $search = ldap_filterescape($_REQUEST['search']);
93 $org = ldap_filterescape($_REQUEST['org']);
94 $marker = ldap_filterescape($_REQUEST['marker']);
95 $categories = ldap_filterescape($_REQUEST['categories']);
96 $_SESSION['ldapab']['filter'] = $_REQUEST['filter'];
97 if(empty($filter)) $filter='a';
100 $ldapfilter = '(&(objectClass=contactPerson)';
101 $marker = explode(',',$marker);
102 foreach($marker as $m){
104 $ldapfilter .= "(marker=$m)";
107 }elseif(!empty($categories)){
108 $ldapfilter = "(&(objectClass=OXUserObject)(OXUserCategories=$categories))";
109 }elseif(!empty($search)){
110 $search = trim($search);
111 $words=preg_split('/\s+/',$search);
113 foreach($words as $word){
114 $filter .= "(|(|(sn=*$word*)(givenName=*$word*))(o=*$word*))";
116 $ldapfilter = "(&(objectClass=inetOrgPerson)$filter)";
117 }elseif(!empty($org)){
118 $ldapfilter = "(&(objectClass=inetOrgPerson)(o=$org))";
119 }elseif($filter=='other'){
121 for ($i=ord('a');$i<=ord('z');$i++){
122 $other .= '(!(sn='.chr($i).'*))';
124 $ldapfilter = "(&(objectClass=inetOrgPerson)$other)";
125 }elseif($filter=='*'){
126 $ldapfilter = "(objectClass=inetOrgPerson)";
128 $ldapfilter = "(&(objectClass=inetOrgPerson)(sn=$filter*))";