source: branches/2.2/expressoMail1_2/inc/class.ldap_functions.inc.php @ 4645

Revision 4645, 31.0 KB checked in by diegomoreno, 13 years ago (diff)

Ticket #2010 - expressoMail1_2 - Ajuste para quicksearch localizar contas compartilhadas e institucionais.

  • Property svn:eol-style set to native
  • Property svn:executable set to *
Line 
1<?php
2include_once("class.imap_functions.inc.php");
3include_once("class.functions.inc.php");
4
5function ldapRebind($ldap_connection, $ldap_url)
6{
7        @ldap_bind($ldap_connection, $_SESSION['phpgw_info']['expressomail']['ldap_server']['acc'],$_SESSION['phpgw_info']['expressomail']['ldap_server']['pw']);
8}
9
10class ldap_functions
11{
12        var $ds;
13        var $ldap_host;
14        var $ldap_context;
15        var $imap;
16        var $external_srcs;
17        var $max_result;
18        var $functions;
19        function ldap_functions(){
20        // todo: Page Configuration for External Catalogs.
21                @include("../contactcenter/setup/external_catalogs.inc.php");
22                $this->external_srcs= ( isset( $external_srcs ) ) ? $external_srcs : NULL;
23                $this->max_result       = 200;
24                $this->functions = new functions();
25        }
26        // Using ContactCenter configuration.
27        function ldapConnect($refer = false,$catalog = 0){
28                if ($catalog > 0 && is_array($this->external_srcs)){
29                        $this->ldap_host        = $this->external_srcs[$catalog]['host'];
30                        $this->ldap_context = $this->external_srcs[$catalog]['dn'];
31                        $this->bind_dn          = $this->external_srcs[$catalog]['acc'];
32                        $this->bind_dn_pw       = $this->external_srcs[$catalog]['pw'];
33                        $this->object_class = $this->external_srcs[$catalog]['obj'];
34                        $this->base_dn          = $this->external_srcs[$catalog]['dn'];
35                        $this->branch           = $this->external_srcs[$catalog]['branch'];
36                }else {
37                        $this->ldap_host        = $_SESSION['phpgw_info']['expressomail']['ldap_server']['host'];
38                        $this->ldap_context = $_SESSION['phpgw_info']['expressomail']['ldap_server']['dn'];
39                        $this->bind_dn = $_SESSION['phpgw_info']['expressomail']['ldap_server']['acc'];
40                        $this->bind_dn_pw = $_SESSION['phpgw_info']['expressomail']['ldap_server']['pw'];
41                        $this->branch = 'ou';
42                }
43
44                $this->ds = ldap_connect($this->ldap_host);
45                ldap_set_option($this->ds, LDAP_OPT_PROTOCOL_VERSION, 3);
46                ldap_set_option($this->ds, LDAP_OPT_REFERRALS, $refer);
47                if ($refer)     {
48                        ldap_set_rebind_proc($this->ds, ldapRebind);
49                }
50                @ldap_bind($this->ds,$this->bind_dn,$this->bind_dn_pw );
51        }
52
53        //Teste jakjr retornando o DS
54        function ldapConnect2($refer = false){
55                $ds = ldap_connect($_SESSION['phpgw_info']['expressomail']['ldap_server']['host']);
56
57                if (!$ds)
58                        return false;
59
60                ldap_set_option($ds, LDAP_OPT_PROTOCOL_VERSION, 3);
61                ldap_set_option($ds, LDAP_OPT_REFERRALS, $refer);
62                if ($refer)
63                        ldap_set_rebind_proc($ds, ldapRebind);
64                @ldap_bind($ds, $_SESSION['phpgw_info']['expressomail']['ldap_server']['acc'],$_SESSION['phpgw_info']['expressomail']['ldap_server']['pw']);
65
66                return $ds;
67        }
68
69
70        // usa o host e context do setup.
71        function ldapRootConnect($refer = false){
72                $this->ldap_host        = $_SESSION['phpgw_info']['expressomail']['server']['ldap_host'];
73                $this->ldap_context = $_SESSION['phpgw_info']['expressomail']['server']['ldap_context'];
74                $this->ds                       = ldap_connect($this->ldap_host);
75                ldap_set_option($this->ds, LDAP_OPT_PROTOCOL_VERSION, 3);
76                ldap_set_option($this->ds, LDAP_OPT_REFERRALS, $refer);
77                ldap_bind($this->ds, $_SESSION['phpgw_info']['expressomail']['server']['ldap_root_dn'],$_SESSION['phpgw_info']['expressomail']['server']['ldap_root_pw']);
78
79        }
80
81        function quicksearch($params)
82        {
83                include_once("class.functions.inc.php");
84                $functions = new functions;
85
86                $search_for     = utf8_encode($params['search_for']);
87                $field          = $params['field'];
88                $ID                     = $params['ID'];
89               
90                if($_SESSION['phpgw_info']['user']['preferences']['expressoMail']['extended_info'])
91                    $extendedinfo=true;
92                else
93                    $extendedinfo=false;
94
95                $search_for     = explode(" ",$search_for);
96                $aux="";
97                foreach ($search_for as $search)
98                {
99                        if(!$aux)
100                        {
101                                $aux=$search;
102                        }
103                        else
104                        {
105                                if (strlen($search) > 2)
106                                {
107                                        $aux=$aux."*".$search;
108                                }
109                                else
110                                {
111                                        $aux=$aux." ".$search;
112                                }
113                        }
114                }
115                $search_for=$aux;
116               
117                $contacts_result = array();
118                $contacts_result['field'] = $field;
119                $contacts_result['ID'] = $ID;
120                // follow the referral
121                $this->ldapConnect(true);
122
123                if ($this->ds)
124                {
125                        if (($field != 'null') && ($ID != 'null'))
126                        {
127                                $filter="(& (&(|(phpgwAccountType=u)(phpgwAccountType=g)(phpgwAccountType=l)(phpgwAccountType=i)(phpgwAccountType=s))(mail=*)) (|(cn=*$search_for*)(mail=*$search_for*)) (!(phpgwaccountvisible=-1)) )";
128                                if($extendedinfo)
129                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid", "employeeNumber", "ou");
130                                else
131                                    $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid");
132                        }
133                        else
134                        {
135                                $filter="(& (phpgwAccountType=u)(cn=*$search_for*) (!(phpgwaccountvisible=-1)) )";
136                                if($extendedinfo)
137                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible","jpegPhoto", "uid", "employeeNumber", "ou");
138                                else
139                                    $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible","jpegPhoto", "uid");
140                        }
141                        $sr=@ldap_search($this->ds, $this->ldap_context, $filter, $justthese, 0, $this->max_result + 1);
142                        if(!$sr)
143                                return null;
144                        $count_entries = ldap_count_entries($this->ds,$sr);
145
146                        // Get user org dn.
147                        $user_dn = $_SESSION['phpgw_info']['expressomail']['user']['account_dn'];
148                        $user_sector_dn = ldap_explode_dn ( $user_dn, false );
149                        array_shift($user_sector_dn);
150                        array_shift($user_sector_dn);
151                        $user_sector_dn = implode(",", $user_sector_dn);
152
153                        // New search only on user sector
154                        if ($count_entries > $this->max_result)
155                        {
156                                // Close old ldap conection
157                                ldap_close($this->ds);
158
159                                // Reopen a local ldap connection, following referral
160                                $this->ldapRootConnect(true);
161
162                                $sr= ldap_search($this->ds, $user_sector_dn, $filter, $justthese);
163                                if(!$sr)
164                                        return null;
165                                $count_entries = ldap_count_entries($this->ds,$sr);
166
167                                if ($count_entries > $this->max_result){
168                                        $return = array();
169                                        $return['status'] = false;
170                                        $return['error'] = "many results";
171                                        return $return;
172                                }
173                                else
174                                {
175                                        $quickSearch_only_in_userSector = true;
176                                }
177                        }
178
179                        $info = ldap_get_entries($this->ds, $sr);
180
181                        $tmp = array();
182                        $tmp_users_from_user_org = array();
183
184                        if (!$quickSearch_only_in_userSector) {
185                                $catalogsNum=count($this->external_srcs);
186                                for ($i=0; $i<=count($this->external_srcs); $i++)       {
187                                        if ($this->external_srcs[$i]["quicksearch"]) {
188                                                $this->ldapConnect(true,$i);
189                                                $filter="(|(cn=*$search_for*)(mail=*$search_for*))";
190                                                if($extendedinfo)
191                                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid","employeeNumber", "ou");
192                                                else
193                                                    $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid");
194                                                $sr=@ldap_search($this->ds, $this->ldap_context, $filter, $justthese, 0, $this->max_result+1);
195                                                if(!$sr)
196                                                        return null;
197                                                $count_entries = ldap_count_entries($this->ds,$sr);
198                                                $search = ldap_get_entries($this->ds, $sr);
199                                                for ($j=0; $j<$search["count"]; $j++) {
200                                                        $info[] = $search[$j];
201                                                }
202                                                $info["count"] = count($info)-1;
203                                        }
204                                }
205                        }
206
207                        for ($i=0; $i<$info["count"]; $i++)
208                        {
209                                if ($quickSearch_only_in_userSector)
210                                {
211                                        $tmp[$info[$i]["mail"][0] . '%' . $info[$i]["telephonenumber"][0] . '%'. $info[$i]["mobile"][0] . '%' . $info[$i]["uid"][0] . '%' . $info[$i]["jpegphoto"]['count'] . '%' . $info[$i]["employeenumber"][0] . '%' . $info[$i]["ou"][0]] = utf8_decode($info[$i]["cn"][0]);
212                                }
213                                else
214                                {
215                                        if (preg_match("/$user_sector_dn/i", $info[$i]['dn']))
216                                        {
217                                                $tmp_users_from_user_org[$info[$i]["mail"][0] . '%' . $info[$i]["telephonenumber"][0] . '%'. $info[$i]["mobile"][0] . '%' . $info[$i]["uid"][0] . '%' . $info[$i]["jpegphoto"]['count'] . '%' . $info[$i]["employeenumber"][0] . '%' . $info[$i]["ou"][0]] = utf8_decode($info[$i]["cn"][0]);
218                                        }
219                                        else
220                                        {
221                                                $tmp[$info[$i]["mail"][0] . '%' . $info[$i]["telephonenumber"][0] . '%'. $info[$i]["mobile"][0] . '%' . $info[$i]["uid"][0] . '%' . $info[$i]["jpegphoto"]['count'] . '%' . $info[$i]["employeenumber"][0] . '%' . $info[$i]["ou"][0]] = utf8_decode($info[$i]["cn"][0]);
222                                        }
223                                }
224                        }
225                        natcasesort($tmp_users_from_user_org);
226                        natcasesort($tmp);
227
228                        if (($field != 'null') && ($ID != 'null'))
229                        {
230                                $i = 0;
231
232                                $tmp = array_merge($tmp, $tmp_users_from_user_org);
233                                natcasesort($tmp);
234
235                                foreach ($tmp as $info => $cn)
236                                {
237                                        $contacts_result[$i] = array();
238                                        $contacts_result[$i]["cn"] = $cn;
239                                        list ($contacts_result[$i]["mail"], $contacts_result[$i]["phone"], $contacts_result[$i]["mobile"], $contacts_result[$i]["uid"], $contacts_result[$i]["jpegphoto"], $contacts_result[$i]["employeenumber"], $contacts_result[$i]["ou"]) = split ('%', $info);
240                                        $i++;
241                                }
242                                $contacts_result['quickSearch_only_in_userSector'] = $quickSearch_only_in_userSector;
243                        }
244                        else
245                        {
246                                $options_users_from_user_org = '';
247                                $options = '';
248
249                                /* List of users from user org */
250                                $i = 0;
251                                foreach ($tmp_users_from_user_org as $info => $cn)
252                                {
253                                        $contacts_result[$i] = array();
254                                        $options_users_from_user_org .= $this->make_quicksearch_card($info, $cn);
255                                        $i++;
256                                }
257
258                                /* List of users from others org */
259                                foreach ($tmp as $info => $cn)
260                                {
261                                        $contacts_result[$i] = array();
262                                        $options .= $this->make_quicksearch_card($info, $cn);
263                                        $i++;
264                                }
265
266                                if ($quickSearch_only_in_userSector)
267                                {
268                                        if ($options != '')
269                                        {
270                                                $head_option =
271                                                        '<tr class="quicksearchcontacts_unselected">' .
272                                                                '<td colspan="2" width="100%" align="center">' .
273                                                                        str_replace("%1", $this->max_result,$this->functions->getLang('More than %1 results were found')) . '.<br>' .
274                                                                        $this->functions->getLang('Showing only the results found in your organization') . '.';
275                                                                '</td>' .
276                                                        '</tr>';
277                                                $contacts_result = $head_option . $options_users_from_user_org . $options;
278                                        }
279                                        else
280                                        {
281                                                $return = array();
282                                                $return['status'] = false;
283                                                $return['error'] = "many results";
284                                                return $return;
285                                        }
286                                }
287                                else
288                                {
289                                        if (($options_users_from_user_org != '') && ($options != ''))
290                                        {
291                                                $head_option0 =
292                                                        '<tr class="quicksearchcontacts_unselected">' .
293                                                                '<td colspan="2" width="100%" align="center" style="background:#EEEEEE"><B>' .
294                                                                        $this->functions->getLang('Users from your organization') . '</B> ['.count($tmp_users_from_user_org).']';
295                                                                '</td>' .
296                                                        '</tr>';
297
298                                                $head_option1 =
299                                                        '<tr class="quicksearchcontacts_unselected">' .
300                                                                '<td colspan="2" width="100%" align="center" style="background:#EEEEEE"><B>' .
301                                                                        $this->functions->getLang('Users from others organizations') . '</B> ['.count($tmp).']';
302                                                                '</td>' .
303                                                        '</tr>';
304                                        }
305                                        $contacts_result = $head_option0 . $options_users_from_user_org . $head_option1 . $options;
306                                }
307                        }
308                }
309                ldap_close($this->ds);
310                return $contacts_result;
311        }
312
313        function make_quicksearch_card($info, $cn)
314        {
315                include_once("class.functions.inc.php");
316                $functions = new functions;
317
318                $contacts_result = array();
319                $contacts_result["cn"] = $cn;
320                if($_SESSION['phpgw_info']['user']['preferences']['expressoMail']['extended_info'])
321                    $extendedinfo=true;
322                else
323                    $extendedinfo=false;
324
325                list ($contacts_result["mail"], $contacts_result["phone"], $contacts_result["mobile"], $contacts_result["uid"], $contacts_result["jpegphoto"], $contacts_result["employeenumber"], $contacts_result["ou"]) = split ('%', $info);
326
327                if ($contacts_result['jpegphoto'])
328                        $photo_link = '<img src="./inc/show_user_photo.php?mail='.$contacts_result['mail'].'">';
329                else
330                        $photo_link = '<img src="./templates/default/images/photo.jpg">';
331
332                $phoneUser = $contacts_result['phone'];
333
334                if($_SESSION['phpgw_info']['user']['preferences']['expressoMail']['voip_enabled'] && $phoneUser) {
335                        $phoneUser = '<a title="'.$this->functions->getLang("Call to Comercial Number").'" href="#" onclick="InfoContact.connectVoip(\''.$phoneUser.'\',\'com\')">'.$phoneUser.'</a>';
336                        if($contacts_result['mobile']){
337                                $phoneUser .= ' / <a title="'.$this->functions->getLang("Call to Mobile Number").'" href="#" onclick="InfoContact.connectVoip(\''.$contacts_result['mobile'].'\',\'mob\')">'.$contacts_result['mobile'].'</a>';
338                        }
339                }
340                //verifica de existe o celular do funcionario ($contacts_result["mobile"]), se nao, $phoneUser fica vazia;
341
342                    $mobileUser = $contacts_result["mobile"];
343                    if($mobileUser && !$voipMobile) {
344                            $phoneUser .= " / $mobileUser";
345                    }
346                    $empNumber = $contacts_result["employeenumber"];
347                    if($empNumber) {
348                            $empNumber = "$empNumber - ";
349                    }
350                    $ou = $contacts_result["ou"];
351                    if($ou) {
352                            $ou = "<br/>$ou" ;
353                    }
354
355                // Begin: nickname, firstname and lastname for QuickAdd.
356                $fn = $contacts_result["cn"];
357                $array_name = explode(" ", $fn);
358                if(count($array_name) > 1){                     
359                        $fn = $array_name[0];
360                        array_shift($array_name);
361                        $sn = implode(" ",$array_name);
362                }
363                // End:
364                $option =
365                        '<tr class="quicksearchcontacts_unselected">' .
366                                '<td class="cc" width="1%">' .
367                                        '<a title="'.$this->functions->getLang("Write message").'" onClick="javascript:QuickSearchUser.create_new_message(\''.$contacts_result["cn"].'\', \''.$contacts_result["mail"].'\')">' .
368                                                $photo_link .
369                                        '</a>' .
370                                '</td>' .
371                                '<td class="cc">' .
372                                        '<span name="cn">' . $empNumber . $contacts_result['cn'] . '</span>' . '<br>' .
373                                        '<a title="'.$functions->getLang("Write message").'" onClick="javascript:QuickSearchUser.create_new_message(\''.$contacts_result["cn"].'\', \''.$contacts_result["mail"].'\')">' .
374                                                '<font color=blue>' .
375                                                '<span name="mail">' . $contacts_result['mail'] . '</span></a></font>'.
376                                                '<img src="templates/default/images/user_card.png" style="cursor: pointer;" title="'.$this->functions->getLang("Add Contact").'" onclick="javascript:connector.loadScript(\'ccQuickAdd\');ccQuickAddOne.showList(\''.$fn.','.$fn.','.$sn.','.$contacts_result["mail"].'\')">'.
377                                        '<br>' .
378                                        $phoneUser .
379                                        $ou .
380                                '</td>' .
381                                '</tr>';
382                return $option;
383        }
384
385        function get_catalogs(){
386                $catalogs = array();
387                $catalogs[0] = $this->functions->getLang("Global Catalog");
388                if($this->external_srcs)
389                        foreach ($this->external_srcs as $key => $valor ){
390                        $catalogs[$key] = $valor['name'];
391                }
392                return $catalogs;
393        }
394        function get_organizations($params){
395                $organizations = array();
396                $params['referral']?$referral = $params['referral']:$referral = false;
397                $cat = $params['catalog'];
398
399                $this->ldapConnect($referral,$cat);
400
401                        if($this->branch != '') {
402                                $filter="(&(".$this->branch."=*)(!(phpgwAccountVisible=-1)))";
403                                $justthese = array("$this->branch");
404                        $sr = ldap_list($this->ds, $this->ldap_context, $filter, $justthese);
405                        $info = ldap_get_entries($this->ds, $sr);
406
407                        if($info["count"] == 0)
408                        {
409                            $organizations[0]['ou'] = $this->ldap_context;
410                        }
411
412                        for ($i=0; $i<$info["count"]; $i++)
413                                $organizations[$i] = $info[$i]["ou"][0];
414
415                        ldap_close($this->ds);
416                        sort($organizations);
417                return $organizations;
418                        }else{
419                        return null;
420        }
421        }
422        function get_organizations2($params){
423                $organizations = array();
424                $referral = $params['referral'];
425                $this->ldapRootConnect($referral);
426                if ($this->ds) {
427                        $filter="(&(objectClass=organizationalUnit)(!(phpgwAccountVisible=-1)))";
428                        $justthese = array("ou");
429                        $sr = ldap_list($this->ds, $this->ldap_context, $filter, $justthese);
430                        $info = ldap_get_entries($this->ds, $sr);
431
432
433                        if($info["count"] == 0)
434                        {
435                            $organizations[0]['ou'] = $this->ldap_context;
436                            $organizations[0]['dn'] = $this->ldap_context;
437                        }
438                        else{
439                            for ($i=0; $i<$info["count"]; $i++)
440                            {
441                                    $organizations[$i]['ou'] = $info[$i]["ou"][0];
442                                    $organizations[$i]['dn'] = $info[$i]["dn"];
443                            }
444                        }
445                        ldap_close($this->ds);
446                        sort($organizations);
447                }
448                return $organizations;
449        }
450        //Busca usuarios de um contexto e ja retorna as options do select - usado por template serpro;
451        function search_users($params)
452        {
453                $this->ldapConnect(false,0);
454                //Monta lista de Grupos e Usuarios
455                $users = Array();
456                $groups = Array();
457                $user_context= $this->ldap_context;
458                $owner = $_SESSION['phpgw_info']['expressomail']['user']['owner'];
459                $filtro =utf8_encode($params['filter']);
460                $context =utf8_encode($params['context']);//adicionado
461
462                if ($this->ds)
463                {
464                    $justthese = array("gidNumber","cn");
465                    if ($params['type'] == 'search')
466                        $sr=ldap_search($this->ds, $context, ("(&(phpgwaccounttype=g)(!(phpgwaccountvisible=-1))(cn=*$filtro*))"),$justthese);
467                    else
468                        $sr=ldap_list($this->ds,  $context ? $context : $user_context, ("(&(phpgwaccounttype=g)(!(phpgwaccountvisible=-1))(cn=*".$filtro."*))"),$justthese);
469                    $info = ldap_get_entries($this->ds, $sr);
470                    for ($i=0; $i<$info["count"]; $i++)
471                        $groups[$uids=$info[$i]["gidnumber"][0]] = Array('name'    =>    $uids=$info[$i]["cn"][0], 'type'    =>    g);
472                    $justthese = array("phpgwaccountvisible","uidNumber","cn");
473                    if ($params['type'] == 'search')
474                       // $sr=ldap_search($this->ds, $user_context, ("(&(phpgwaccounttype=u)(!(phpgwaccountvisible=-1))(phpgwaccountstatus=A)(|(cn=*$filtro*)(mail=$filtro*)))"),$justthese);
475                       $sr=ldap_search($this->ds, $context, ("(&(phpgwaccounttype=u)(!(phpgwaccountvisible=-1))(phpgwaccountstatus=A)(|(cn=*$filtro*)(mail=$filtro*)))"),$justthese);
476                    else
477                        $sr=ldap_list($this->ds, $context ? $context : $user_context, ("(&(phpgwaccounttype=u)(!(phpgwaccountvisible=-1))(phpgwaccountstatus=A)(|(cn=*$filtro*)(mail=$filtro*)))"),$justthese);
478
479                    $info = ldap_get_entries($this->ds, $sr);
480                    for ($i=0; $i<$info["count"]; $i++)
481                    {
482                        if ($info[$i]["phpgwaccountvisible"][0] == '-1')
483                      continue;
484                        $users[$uids=$info[$i]["uidnumber"][0]] = Array('name'    =>    $uids=$info[$i]["cn"][0], 'type'    =>    u);
485                    }
486                }
487                ldap_close($this->ds);
488       
489                @asort($users);
490                @reset($users);
491                @asort($groups);
492                @reset($groups);
493                $user_options ='';
494                $group_options ='';
495
496                foreach($groups as $id => $user_array) {
497                        $newId = $id.'U';
498                        $group_options .= '<option  value="'.$newId.'">'.utf8_decode($user_array['name']).'</option>'."\n";
499                }
500                foreach($users as $id => $user_array) {
501                    if($owner != $id){
502                        $newId = $id.'U';
503                        $user_options .= '<option  value="'.$newId.'">'.utf8_decode($user_array['name']).'</option>'."\n";
504                    }
505                }
506                return array("users" => $user_options, "groups" => $group_options);
507        }
508
509        function catalogsearch($params)
510        {
511                $cn     = $params['search_for'] ? "*".utf8_encode($params['search_for'])."*" : "*";
512                $max_result       = $params['max_result'] ? $params['max_result'] : $this->max_result;
513                $catalog = $params['catalog'];
514                $error = False;
515                if($_SESSION['phpgw_info']['user']['preferences']['expressoMail']['extended_info'])
516                    $extendedinfo=true;
517                else
518                    $extendedinfo=false;
519
520
521                $this->ldapConnect(true,$catalog);
522
523                $params['organization'] == 'all' ? $user_context = $this->ldap_context :$user_context = $this->branch."=".$params['organization'].",".$this->ldap_context;
524
525                if ($this->ds) {
526                        if ($catalog == 0){
527                                //os atributos "employeeNumber" e "ou" foram adicionado ao vetor de busca;
528                                if($extendedinfo)
529                                $justthese = array("cn", "mail", "phpgwaccounttype", "phpgwAccountVisible", "employeeNumber", "ou");
530                                else
531                                    $justthese = array("cn", "mail", "phpgwaccounttype", "phpgwAccountVisible");
532
533                                $filter="(&(|(phpgwAccountType=u)(phpgwAccountType=l))(cn=".$cn."))";
534                                //$user_context = "ou=".$params['organization'].",".$this->ldap_context;
535                        }else {
536                                //os atributos "employeeNumber" e "ou" foram adicionado ao vetor de busca;
537                                if($extendedinfo)
538                                $justthese = array("cn", "mail", "employeeNumber", "ou");
539                                else
540                                    $justthese = array("cn", "mail");
541                                $filter="(&(objectClass=".$this->object_class.")(cn=".$cn."))";
542                                //$user_context = $this->branch."=".$params['organization'].",".$external_srcs[$catalog]['dn'];
543                        }
544
545                        $sr=@ldap_search($this->ds, $user_context, $filter, $justthese, 0, $max_result+1);
546                        if(!$sr)
547                                return null;
548                        $count_entries = ldap_count_entries($this->ds,$sr);
549                        if ($count_entries > $max_result){
550                                $info = null;
551                                $error = True;
552                        }
553                        else
554                                $info = ldap_get_entries($this->ds, $sr);
555
556                        ldap_close($this->ds);
557
558                        $u_tmp = array();
559                        $g_tmp = array();
560
561                        for ($i=0; $i<$info["count"]; $i++){
562                                if((!$catalog==0)||(strtoupper($info[$i]["phpgwaccounttype"][0]) == 'U') && ($info[$i]["phpgwaccountvisible"][0] != '-1'))
563                                        //aqui eh feita a concatenacao do departamento ao cn;
564                                        $u_tmp[$info[$i]["mail"][0]] = utf8_decode($info[$i]["cn"][0]). '%' . $info[$i]["ou"][0];
565                                if((!$catalog==0)||(strtoupper($info[$i]["phpgwaccounttype"][0]) == 'L') && ($info[$i]["phpgwaccountvisible"][0] != '-1'))
566                                        $g_tmp[$info[$i]["mail"][0]] = utf8_decode($info[$i]["cn"][0]);
567                        }
568
569                        natcasesort($u_tmp);
570                        natcasesort($g_tmp);
571
572                        $i = 0;
573                        $users = array();
574
575                        foreach ($u_tmp as $mail => $cn){
576
577                                $tmp = explode("%", $cn); //explode o cn pelo caracter "%" e joga em $tmp;
578                                $name = $tmp[0]; //pega o primeiro item (cn) do vetor resultante do explode acima;
579                                $department = $tmp[1]; //pega o segundo item (ou) do vetor resultanto do explode acima;
580                                $users[$i++] = array("name" => $name, "email" => $mail, "department" => $department);
581
582                        }
583                        unset($u_tmp);
584
585                        $i = 0;
586                        $groups = array();
587
588                        foreach ($g_tmp as $mail => $cn){
589                                $groups[$i++] = array("name" => $cn, "email" => $mail);
590                        }
591                        unset($g_tmp);
592
593                        return  array('users' => $users, 'groups' => $groups, 'error' => $error);
594                }else
595                return null;
596        }
597
598        function get_emails_ldap(){
599
600                $result['mail']= array();
601                $result['mailalter']= array();
602                $user = $_SESSION['phpgw_info']['expressomail']['user']['account_lid'];
603                $this->ldapRootConnect(false);
604                if ($this->ds) {
605                        $filter="uid=".$user;
606                        $justthese = array("mail","mailAlternateAddress");
607                        $sr = ldap_search($this->ds,$this->ldap_context, $filter, $justthese);
608                        $ent = ldap_get_entries($this->ds, $sr);
609                        ldap_close($this->ds);
610
611                        for ($i=0; $i<$ent["count"]; $i++){
612                                $result['mail'][] = $ent[$i]["mail"][0];
613                                $result['mailalter'][] = $ent[$i]["mailalternateaddress"][0];
614                        }
615                }
616                return $result;
617        }
618
619        //Busca usuarios de um contexto e ja retorna as options do select;
620        function get_available_users($params)
621    {
622        $this->ldapRootConnect();
623        //Monta lista de Grupos e Usuarios
624        $users = Array();
625        $groups = Array();
626        $user_context= $params['context'];
627        $owner = $_SESSION['phpgw_info']['expressomail']['user']['owner'];
628
629        if ($this->ds)
630        {
631            $justthese = array("gidNumber","cn");
632            if ($params['type'] == 'search')
633                $sr=ldap_search($this->ds, $user_context, ("(&(cn=*)(phpgwaccounttype=g)(!(phpgwaccountvisible=-1)))"),$justthese);
634            else
635                $sr=ldap_list($this->ds, $user_context, ("(&(cn=*)(phpgwaccounttype=g)(!(phpgwaccountvisible=-1)))"),$justthese);
636            $info = ldap_get_entries($this->ds, $sr);
637            for ($i=0; $i<$info["count"]; $i++)
638                $groups[$uids=$info[$i]["gidnumber"][0]] = Array('name'    =>    $uids=$info[$i]["cn"][0], 'type'    =>    g);
639            $justthese = array("phpgwaccountvisible","uidNumber","cn");
640            if ($params['type'] == 'search')
641                $sr=ldap_search($this->ds, $user_context, ("(&(cn=*)(phpgwaccounttype=u)(!(phpgwaccountvisible=-1)))"),$justthese);
642            else
643                $sr=ldap_list($this->ds, $user_context, ("(&(cn=*)(phpgwaccounttype=u)(!(phpgwaccountvisible=-1)))"),$justthese);
644
645            $info = ldap_get_entries($this->ds, $sr);
646            for ($i=0; $i<$info["count"]; $i++)
647            {
648                if ($info[$i]["phpgwaccountvisible"][0] == '-1')
649                    continue;
650                $users[$uids=$info[$i]["uidnumber"][0]] = Array('name'    =>    $uids=$info[$i]["cn"][0], 'type'    =>    u);
651            }
652        }
653        ldap_close($this->ds);
654
655        @asort($users);
656        @reset($users);
657        @asort($groups);
658        @reset($groups);
659        $user_options ='';
660        $group_options ='';
661
662        foreach($groups as $id => $user_array) {
663                $newId = $id.'U';
664                $group_options .= '<option  value="'.$newId.'">'.utf8_decode($user_array['name']).'</option>'."\n";
665        }
666        foreach($users as $id => $user_array) {
667            if($owner != $id){
668                $newId = $id.'U';
669                $user_options .= '<option  value="'.$newId.'">'.utf8_decode($user_array['name']).'</option>'."\n";
670            }
671        }
672        return array("users" => $user_options, "groups" => $group_options);
673    }
674
675        //Busca usuarios de um contexto e ja retorna as options do select;
676        function get_available_users2($params)
677        {
678            $this->ldapRootConnect();
679            $context    = $params['context'];
680            $justthese  = array("cn", "uid", "cn");
681            $filter     = ( isset($params['cn']) ) ? "(&(cn=*".$params['cn']."*)(phpgwaccounttype=u)(!(phpgwaccountvisible=-1)))" :
682                                "(&(phpgwaccounttype=u)(!(phpgwaccountvisible=-1)))";
683           
684            if ($this->ds)
685            {
686                $sr = ldap_search($this->ds, $context, $filter, $justthese);
687               
688                $entries = ldap_get_entries($this->ds, $sr);
689
690                for ($i=0; $i<$entries["count"]; $i++)
691                {
692                    if($_SESSION['phpgw_info']['expressomail']['user']['account_lid'] != $entries[$i]["uid"][0])
693                    {
694                        $u_tmp[$entries[$i]["uid"][0]] = $entries[$i]["cn"][0];
695                    }
696                }
697
698                natcasesort($u_tmp);
699
700                $i = 0;
701                $users = array();
702
703                if (count($u_tmp))
704                {
705                    foreach ($u_tmp as $uidnumber => $cn)
706                    {
707                        $options .= "<option value=$uidnumber>$cn</option>";
708                    }
709                   
710                    unset($u_tmp);
711                }
712
713                ldap_close($this->ds);
714                return $options;
715            }
716        }
717
718        function uid2cn($uid)
719        {
720                // do not follow the referral
721                $this->ldapRootConnect(false);
722                if ($this->ds)
723                {
724                        $filter="(&(phpgwAccountType=u)(uid=$uid))";
725                        $justthese = array("cn");
726                        $sr=@ldap_search($this->ds, $this->ldap_context, $filter, $justthese);
727                        if(!$sr)
728                                return false;
729                        $info = ldap_get_entries($this->ds, $sr);
730                        return utf8_decode($info[0]["cn"][0]);
731                }
732                return false;
733        }
734        function uidnumber2uid($uidnumber)
735        {
736                // do not follow the referral
737                $this->ldapRootConnect(false);
738                if ($this->ds)
739                {
740                        $filter="(&(phpgwAccountType=u)(uidnumber=$uidnumber))";
741                        $justthese = array("uid");
742                        $sr=@ldap_search($this->ds, $this->ldap_context, $filter, $justthese);
743                        if(!$sr)
744                                return false;
745                        $info = ldap_get_entries($this->ds, $sr);
746                        return $info[0]["uid"][0];
747                }
748                return false;
749        }
750        function getSharedUsersFrom($params){
751                $filter = '';
752                $i = 0;         
753                //Added to save if must save sent messages in shared folder
754                $acl_save_sent_in_shared = array();
755               
756                if($params['uids']) {
757                        $uids = explode(";",$params['uids']);
758                        $this->imap = new imap_functions();                     
759                        foreach($uids as $index => $uid){
760                                $params = array();
761                                //Added to save if user has create permission
762                                $acl_create_message = array();
763                                $acl = $this->imap->getacltouser($uid);
764                                if ( preg_match("/a/",$acl )){                         
765                                        $filter .= "(uid=$uid)";                                       
766                                        if ( preg_match("/p/",$acl )){                         
767                                                $acl_save_sent_in_shared[ $i ] =$uid;
768                                                $i++;
769                                        }                                       
770                                }                                                       
771                        }                       
772                }
773               
774                $this->ldapRootConnect(false);
775                if ($this->ds) {
776                        $justthese = array("cn","mail","uid");
777                        if($filter) {
778                                $filter="(&(|(phpgwAccountType=u)(phpgwAccountType=s))(|$filter))";
779                                $sr             =       ldap_search($this->ds, $this->ldap_context, $filter, $justthese);
780                                ldap_sort($this->ds,$sr,"cn");
781                                $info   =       ldap_get_entries($this->ds, $sr);
782                                $var = print_r($acl_save_sent_in_shared, true);                         
783                                for ($i = 0;$i < $info["count"]; $i++){
784                                        $info[$i]['cn'][0] = utf8_decode($info[$i]['cn'][0]);
785                                        //verify if user has permission to save sent messages in a shared folder
786                                        if ( in_array( $info[$i]['uid'][0],$acl_save_sent_in_shared) ){                                         
787                                                $info[$i]['save_shared'][0] = 'y';
788                                        } else $info[$i]['save_shared'][0] = 'n';
789                                }
790                        }
791               
792                        $info['myname'] = $_SESSION['phpgw_info']['expressomail']['user']['fullname'];
793
794                        //Find institucional_account.
795                        $filter="(&(phpgwAccountType=i)(mailForwardingAddress=".$_SESSION['phpgw_info']['expressomail']['user']['email']."))";
796                        $sr     = ldap_search($this->ds, $this->ldap_context, $filter, $justthese);
797                        ##
798                        # @AUTHOR Rodrigo Souza dos Santos
799                        # @DATE 2008/09/17
800                        # @BRIEF Changing to ensure that the variable session is always with due value.
801                        ##
802                        if(ldap_count_entries($this->ds,$sr))
803                        {
804                                ldap_sort($this->ds,$sr,"cn");
805                                $result = ldap_get_entries($this->ds, $sr);
806                                for ($j = 0;$j < $result["count"]; $j++){
807                                        $info[$i]['cn'][0] = utf8_decode($result[$j]['cn'][0]);
808                                        $info[$i]['mail'][0] = $result[$j]['mail'][0];
809                                        $info[$i]['save_shared'][0] = 'n';
810                                        $info[$i++]['uid'][0] = $result[$j]['uid'][0];                                 
811                                }
812                        }
813
814                        $_SESSION['phpgw_info']['expressomail']['user']['shared_mailboxes'] = $info;
815                       
816                        return $info;
817                }
818        }
819
820        function getUserByEmail($params)
821        {
822                $expires = 60*60*24*30; /* 30 days */
823                header("Cache-Control: maxage=".$expires);
824                header("Pragma: public");
825                header("Expires: ".gmdate('D, d M Y H:i:s', time()+$expires)); 
826                $filter="(&(phpgwAccountType=u)(mail=" . $params['email'] . "))";
827                $ldap_context = $_SESSION['phpgw_info']['expressomail']['ldap_server']['dn'];
828                if($_SESSION['phpgw_info']['user']['preferences']['expressoMail']['extended_info'])
829                    $extendedinfo=true;
830                else
831                    $extendedinfo=false;
832
833                if($extendedinfo)
834                    $justthese = array("cn","uid","telephoneNumber","jpegPhoto","mobile","ou","employeeNumber");
835                else
836                    $justthese = array("cn","uid","telephoneNumber","jpegPhoto","mobile");
837
838                // Follow the referral
839                $ds = $this->ldapConnect2(true);
840                if ($ds)
841                {
842                        $sr=@ldap_search($ds, $ldap_context, $filter, $justthese);
843
844                        if (!$sr)
845                                return null;
846
847                        $entry = ldap_first_entry($ds, $sr);
848
849                        if($entry) {
850                                $obj =  array("cn" => utf8_decode(current(ldap_get_values($ds, $entry, "cn"))),
851                                                  "email" => $params['email'],
852                                                  "uid" => ldap_get_values($ds, $entry, "uid"),
853                                                  "type" => "global",
854                                                  "mobile" =>  @ldap_get_values($ds, $entry, "mobile"),
855                                                  "telefone" =>  @ldap_get_values($ds, $entry, "telephonenumber"),
856                                                  "ou" =>  @ldap_get_values($ds, $entry, "ou"),
857                                                  "employeeNumber" =>  @ldap_get_values($ds, $entry, "employeeNumber")
858                                        );
859
860                                $_SESSION['phpgw_info']['expressomail']['contact_photo'] = @ldap_get_values_len($ds, $entry, "jpegphoto");
861                                ldap_close($ds);
862                                return $obj;
863                        }
864                }
865                return null;
866        }
867       
868        function uid2uidnumber($uid)
869        {
870                // do not follow the referral
871                $this->ldapRootConnect(false);
872                if ($this->ds)
873                {
874                        $filter="(&(phpgwAccountType=u)(uid=$uid))";
875                        $justthese = array("uidnumber");
876                        $sr=@ldap_search($this->ds, $this->ldap_context, $filter, $justthese);
877                        if(!$sr)
878                                return false;
879                        $info = ldap_get_entries($this->ds, $sr);
880                        return $info[0]["uidnumber"][0];
881                }
882                return false;
883        }
884}
885?>
Note: See TracBrowser for help on using the repository browser.