Ignore:
Timestamp:
06/24/08 16:45:40 (16 years ago)
Author:
rafaelraymundo
Message:

Alterações realizadas para unificação do ExpressoMail?


r39 | 50673548368 | 2008-06-24 18:17:33 -0300 (Ter, 24 Jun 2008) | 9 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/js/QuickCatalogSearch.js

Os arquivos abaixo sofreram modificacoes para tratar a exibicao do departamento na opcao "Pesquisar" do email.

  • alteracao na funcao catalogsearch() em expressoMail1_2/inc/class.ldap_functions.inc.php
  • alteracao na funcao searchCatalogList em expressoMail1_2/js/QuickCatalogSearch.js

r38 | 98954890059 | 2008-06-24 18:07:11 -0300 (Ter, 24 Jun 2008) | 1 line
Caminhos mudados:

M /trunk/expressoMail1_2/js/rich_text_editor.js

Correcao de traducoes e remocao da variavel defaultDraftsFodler


r35 | 98954890059 | 2008-06-19 21:11:11 -0300 (Qui, 19 Jun 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/js/QuickCatalogSearch.js

Melhoria inseridas pelo Emerson:

Pesquisa por catalogos externos na Lupa(f9).


r34 | 00105772038 | 2008-06-19 19:51:58 -0300 (Qui, 19 Jun 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/templates/default/preferences.tpl

Em preferências do Email foi removida a opção duplicada:

  • Salvar rascunhos automaticamente

r33 | 98954890059 | 2008-06-19 19:23:04 -0300 (Qui, 19 Jun 2008) | 2 lines
Caminhos mudados:

M /trunk/expressoMail1_2/js/draw_api.js

correcao de bug que nao mostrava a cota do usuario ao abrir o expressoMail.


r32 | 98954890059 | 2008-06-19 18:17:39 -0300 (Qui, 19 Jun 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ScriptS.inc.php
M /trunk/expressoMail1_2/inc/class.imap_functions.inc.php
M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/index.php
M /trunk/expressoMail1_2/js/DropDownContacts.js
M /trunk/expressoMail1_2/js/InfoContact.js
M /trunk/expressoMail1_2/js/TreeS.js
M /trunk/expressoMail1_2/js/TreeShow.js
M /trunk/expressoMail1_2/js/abas.js
M /trunk/expressoMail1_2/js/common_functions.js
M /trunk/expressoMail1_2/js/doiMenuData.js
M /trunk/expressoMail1_2/js/drag_area.js
M /trunk/expressoMail1_2/js/draw_api.js
M /trunk/expressoMail1_2/js/globals.js
M /trunk/expressoMail1_2/js/main.js
M /trunk/expressoMail1_2/js/rich_text_editor.js
M /trunk/expressoMail1_2/js/search.js
M /trunk/expressoMail1_2/js/shortcut.js
M /trunk/expressoMail1_2/preferences.php
M /trunk/expressoMail1_2/setup/phpgw_pt-br.lang
M /trunk/expressoMail1_2/setup/setup.inc.php
M /trunk/expressoMail1_2/templates/default/index.tpl
M /trunk/expressoMail1_2/templates/default/preferences.tpl

Corcacoes da celepar do bug das imagens e tabelas


r30 | 00105772038 | 2008-06-05 18:12:17 -0300 (Qui, 05 Jun 2008) | 5 lines
Caminhos mudados:

M /trunk/expressoMail1_2/js/common_functions.js
M /trunk/expressoMail1_2/js/globals.js

  • Foram inseridas funcionalidades para:

globals.js: Extenções de imagens permitidas "allowFileExtensions"

common_functions.js: Alterada a função validateFileExtension para rejeitar arquivos que não sejam imagens no corpo do email


r28 | 98954890059 | 2008-05-28 17:37:52 -0300 (Qua, 28 Mai 2008) | 2 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.imap_functions.inc.php
M /trunk/expressoMail1_2/js/main.js

Alterada a funcao empty_trash() para mudar de Lixeira para imapDefaultTrashFolder.


r27 | 00105772038 | 2008-05-28 17:11:41 -0300 (Qua, 28 Mai 2008) | 1 line
Caminhos mudados:

M /trunk/expressoMail1_2/setup/phpgw_pt-br.lang

Incluida tradução para mensagem de 'alert' ao tentar excluir emails de uma pasta compartilhada


r26 | 98954890059 | 2008-05-28 13:08:26 -0300 (Qua, 28 Mai 2008) | 1 line
Caminhos mudados:

M /trunk/expressoMail1_2/js/main.js

Inserido get_lang na ACL das pastas compartilhadas. Função move_msgs()


r24 | 98954890059 | 2008-05-27 17:53:30 -0300 (Ter, 27 Mai 2008) | 2 lines
Caminhos mudados:

M /trunk/expressoMail1_2/js/preferences.js

Aumentado o tamanho da janela javascript das preferencias do expressoMail.


r23 | 03436989789 | 2008-05-27 17:43:54 -0300 (Ter, 27 Mai 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.imap_functions.inc.php
M /trunk/expressoMail1_2/js/QuickCatalogSearch.js

Substituição de links no email.


r22 | 98954890059 | 2008-05-27 17:07:32 -0300 (Ter, 27 Mai 2008) | 2 lines
Caminhos mudados:

M /trunk/expressoMail1_2/js/draw_api.js

Corrigido um bug na visualizacao das pastas compartilhadas.


r19 | 03436989789 | 2008-05-27 15:37:01 -0300 (Ter, 27 Mai 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php

Pesquisa em catalogos externos


r17 | 03436989789 | 2008-05-27 13:18:56 -0300 (Ter, 27 Mai 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/js/QuickCatalogSearch.js

Busca de catálogos externos no email.


r15 | 98954890059 | 2008-05-27 12:19:50 -0300 (Ter, 27 Mai 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/js/QuickCatalogSearch.js

Procura em catálogos externos


r6 | 98954890059 | 2008-05-21 16:14:33 -0300 (Qua, 21 Mai 2008) | 2 lines
Caminhos mudados:

M /trunk/expressoMail1_2/js/draw_api.js

Correção para atualizar a visualização das cotas
de pastas compartilhadas ao mudar de pasta.


r5 | 98954890059 | 2008-05-21 16:02:37 -0300 (Qua, 21 Mai 2008) | 3 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.imap_functions.inc.php
M /trunk/expressoMail1_2/js/draw_api.js

Alterações iniciais do serpro:

-Mostrar quotas das pastas compartilhadas


r4 | 03436989789 | 2008-05-21 13:25:29 -0300 (Qua, 21 Mai 2008) | 10 lines
Caminhos mudados:

M /trunk/expressoMail1_2/inc/class.imap_functions.inc.php
M /trunk/expressoMail1_2/inc/class.ldap_functions.inc.php
M /trunk/expressoMail1_2/index.php
M /trunk/expressoMail1_2/js/common_functions.js
M /trunk/expressoMail1_2/js/filter.js
M /trunk/expressoMail1_2/js/main.js
M /trunk/expressoMail1_2/js/preferences.js
M /trunk/expressoMail1_2/js/rich_text_editor.js
M /trunk/expressoMail1_2/preferences.php
M /trunk/expressoMail1_2/setup/phpgw_pt-br.lang
M /trunk/expressoMail1_2/templates/default/preferences.tpl

Alterações iniciais do sepro:

  • Assinatura automática no corpo das mensagens
  • Fixar assinatura no corpo das mensagens
  • Questão dos Catálogos Externos (Ao clicar em um email o módulo abre nova mensagem)
  • Inserção de imagens em Firefox3
  • Quota nas pastas compartilhadas
  • Traduções nas pastas

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/expressoMail1_2/inc/class.ldap_functions.inc.php

    r320 r325  
    1515         
    1616        // usa o host e context do contact center. 
    17         function ldapConnect($refer = false){ 
    18                 $this->ldap_host        = $_SESSION['phpgw_info']['expressomail']['ldap_server']['host']; 
    19                 $this->ldap_context = $_SESSION['phpgw_info']['expressomail']['ldap_server']['dn']; 
    20                 $this->ds                       = ldap_connect($this->ldap_host); 
     17        function ldapConnect($refer = false,$catalogo = 0){ 
     18        include("../contactcenter/setup/external_catalogs.inc.php"); 
     19                if ($catalogo == 0){ 
     20                        $this->ldap_host        = $_SESSION['phpgw_info']['expressomail']['ldap_server']['host']; 
     21                        $this->ldap_context = $_SESSION['phpgw_info']['expressomail']['ldap_server']['dn']; 
     22                        $this->bind_dn = $_SESSION['phpgw_info']['expressomail']['ldap_server']['acc']; 
     23                        $this->bind_dn_pw = $_SESSION['phpgw_info']['expressomail']['ldap_server']['pw']; 
     24                        $this->branch = 'ou';                    
     25                }else { 
     26                         
     27                        $this->ldap_host        =   $external_srcs[$catalogo]['host']; 
     28                        $this->ldap_context =   $external_srcs[$catalogo]['dn']; 
     29                        $this->bind_dn = $external_srcs[$catalogo]['acc']; 
     30                        $this->bind_dn_pw = $external_srcs[$catalogo]['pw']; 
     31                        $this->object_class = $external_srcs[$catalogo]['obj']; 
     32                        $this->base_dn = $external_srcs[$catalogo]['dn']; 
     33                        $this->branch = $external_srcs[$catalogo]['branch']; 
     34 
     35                } 
     36                $this->ds = ldap_connect($this->ldap_host); 
    2137                ldap_set_option($this->ds, LDAP_OPT_PROTOCOL_VERSION, 3); 
    2238                ldap_set_option($this->ds, LDAP_OPT_REFERRALS, $refer); 
    23                 if ($refer) 
    24                 { 
     39                if ($refer){ 
    2540                        ldap_set_rebind_proc($this->ds, ldapRebind); 
    2641                } 
    27                 @ldap_bind($this->ds, $_SESSION['phpgw_info']['expressomail']['ldap_server']['acc'],$_SESSION['phpgw_info']['expressomail']['ldap_server']['pw']);                               
     42                @ldap_bind($this->ds,$this->bind_dn,$this->bind_dn_pw );                                 
     43                 
    2844        } 
    2945 
     
    5874        function quicksearch($params) 
    5975        {        
     76                include_once("../contactcenter/setup/external_catalogs.inc.php"); 
    6077                include_once("class.functions.inc.php"); 
    6178                $functions = new functions;                                              
    6279 
    63                 $search_for     = $params['search_for']; 
     80                $search_for     = utf8_encode($params['search_for']); 
    6481                $field          = $params['field']; 
    6582                $ID                     = $params['ID']; 
    6683                 
     84                $search_for     = explode(" ",$search_for); 
     85                $aux=""; 
     86                foreach ($search_for as $search) 
     87                        { 
     88                        if(!$aux) 
     89                                { 
     90                                $aux=$search; 
     91                                } 
     92                                else 
     93                                { 
     94                                $aux=$aux."*".$search; 
     95                                } 
     96                        } 
     97                $search_for=$aux; 
    6798                $contacts_result = array(); 
    6899                $contacts_result['field'] = $field; 
     
    73104                 
    74105                if ($this->ds) 
    75                 { 
     106                        { 
    76107                        if (($field != 'null') && ($ID != 'null')) 
    77                         { 
    78                                 $filter="(& (|(phpgwAccountType=u)(phpgwAccountType=l)) (|(cn=*$search_for*)(mail=$search_for*)) (!(phpgwaccountvisible=-1)) )"; 
    79                                 $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid"); 
    80                         } 
     108                                { 
     109                                $filter="(& (|(phpgwAccountType=u)(phpgwAccountType=l)) (|(cn=*$search_for*)(mail=*$search_for*)) (!(phpgwaccountvisible=-1)) )"; 
     110                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid", "employeeNumber", "ou"); 
     111                                } 
    81112                        else 
    82                         { 
     113                                { 
    83114                                $filter="(& (phpgwAccountType=u)(cn=*$search_for*) (!(phpgwaccountvisible=-1)) )"; 
    84                                 $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "jpegPhoto", "uid"); 
    85                         } 
    86                          
    87                         $sr=ldap_search($this->ds, $this->ldap_context, $filter, $justthese); 
     115                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "jpegPhoto", "uid", "employeeNumber", "ou"); 
     116                                } 
     117                        $sr=ldap_search($this->ds, $this->ldap_context, $filter, $justthese, 0, 201); 
    88118                        $count_entries = ldap_count_entries($this->ds,$sr); 
    89  
     119                         
    90120                        // Get user org dn.                      
    91121                        $user_dn = $_SESSION['phpgw_info']['expressomail']['user']['account_dn']; 
     
    104134                                $this->ldapRootConnect(true); 
    105135                                 
    106                                 $sr=ldap_search($this->ds, $user_sector_dn, $filter, $justthese); 
     136                                $sr=ldap_search($this->ds, $user_sector_dn, $filter, $justthese, 0, 201); 
    107137                                $count_entries = ldap_count_entries($this->ds,$sr); 
    108138                                 
     
    123153                        $tmp = array(); 
    124154                        $tmp_users_from_user_org = array(); 
     155                         
     156                        if (!$quickSearch_only_in_userSector) 
     157                                { 
     158                                $catalogsNum=count($external_srcs); 
     159                                for ($i=0; $i<=count($external_srcs); $i++) 
     160                                        { 
     161                                        if ($external_srcs[$i]["quicksearch"]) 
     162                                                { 
     163                                                $this->ldapConnect(true,$i); 
     164                                                $filter="(|(cn=*$search_for*)(mail=*$search_for*))"; 
     165                                                $justthese = array("cn", "mail", "telephoneNumber", "mobile", "phpgwAccountVisible", "uid", "employeeNumber", "ou"); 
     166                                                $sr=ldap_search($this->ds, $this->ldap_context, $filter, $justthese, 0, 201); 
     167                                                $count_entries = ldap_count_entries($this->ds,$sr); 
     168                                                $search = ldap_get_entries($this->ds, $sr); 
     169                                                for ($i=0; $i<$search["count"]; $i++) 
     170                                                        { 
     171                                                        $info[] = $search[$i]; 
     172                                                        } 
     173                                                $info["count"] = count($info)-1; 
     174                                                } 
     175                                        } 
     176                                } 
     177                         
    125178                        for ($i=0; $i<$info["count"]; $i++) 
    126                         { 
    127                                 // Usuario sempre serao da minha org. 
     179                                { 
    128180                                if ($quickSearch_only_in_userSector) 
    129                                 { 
    130                                         $tmp[$info[$i]["mail"][0] . '%' . $info[$i]["telephonenumber"][0] . '%'. $info[$i]["mobile"][0] . '%' . $info[$i]["uid"][0] . '%' . $info[$i]["jpegphoto"]['count']] = $info[$i]["cn"][0]; 
    131                                 } 
     181                                        { 
     182                                        $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]); 
     183                                        } 
    132184                                else 
    133                                 { 
     185                                        { 
    134186                                        if (preg_match("/$user_sector_dn/i", $info[$i]['dn'])) 
    135                                         { 
    136                                                 $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]["cn"][0]; 
     187                                                { 
     188                                                $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]); 
     189                                                } 
     190                                        else 
     191                                                { 
     192                                                $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]); 
     193                                                } 
    137194                                        } 
    138                                         else 
    139                                         { 
    140                                                 $tmp[$info[$i]["mail"][0] . '%' . $info[$i]["telephonenumber"][0] . '%'. $info[$i]["mobile"][0] . '%' . $info[$i]["uid"][0] . '%' . $info[$i]["jpegphoto"]['count']] = $info[$i]["cn"][0]; 
    141                                         } 
    142                                 } 
    143                         } 
     195                                } 
    144196                        natcasesort($tmp_users_from_user_org); 
    145197                        natcasesort($tmp); 
     
    156208                                        $contacts_result[$i] = array(); 
    157209                                        $contacts_result[$i]["cn"] = $cn; 
    158                                         list ($contacts_result[$i]["mail"], $contacts_result[$i]["phone"], $contacts_result[$i]["mobile"]) = split ('%', $info); 
     210                                        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); 
    159211                                        $i++; 
    160212                                } 
     
    272324        } 
    273325 
     326        function get_catalogs(){ 
     327                include("../contactcenter/setup/external_catalogs.inc.php"); 
     328                $catalogs = array(); 
     329                $catalogs[0] = "Catalogo geral";  
     330                foreach ($external_srcs as $key => $valor ){ 
     331                        $catalogs[$key] = $valor['name']; 
     332                } 
     333                return $catalogs; 
     334        } 
    274335        function get_organizations($params){ 
     336 
    275337                $organizations = array(); 
    276                 $referral = $params['referral']; 
    277                 $this->ldapConnect($referral); 
    278                 if ($this->ds) { 
    279                         $filter="ou=*";          
    280                         $justthese = array("ou"); 
    281                         $sr = ldap_list($this->ds, $this->ldap_context, $filter, $justthese); 
    282                         $info = ldap_get_entries($this->ds, $sr); 
    283                          
    284                         for ($i=0; $i<$info["count"]; $i++) 
    285                                 $organizations[$i] = $info[$i]["ou"][0]; 
    286  
    287                         ldap_close($this->ds); 
    288                         sort($organizations);                                    
    289                 } 
    290                 return $organizations; 
    291         } 
    292  
     338                $params['referral']?$referral = $params['referral']:$referral = false; 
     339                $cat = $params['catalog']; 
     340 
     341                $this->ldapConnect($referral,$cat); 
     342 
     343                        if($this->branch != '') { 
     344                                $filter=$this->branch."=*"; 
     345                                $justthese = array("$this->branch"); 
     346                                $sr = ldap_list($this->ds, $this->ldap_context, $filter, $justthese); 
     347                                $info = ldap_get_entries($this->ds, $sr); 
     348 
     349                                for ($i=0; $i<$info["count"]; $i++) 
     350                                        $organizations[$i] = $info[$i]["ou"][0]; 
     351 
     352                                ldap_close($this->ds); 
     353                                sort($organizations); 
     354                                return $organizations; 
     355                        }else{ 
     356                        return null; 
     357                } 
     358        } 
    293359        function get_organizations2($params){ 
    294360                $organizations = array(); 
     
    315381        function catalogsearch($params) 
    316382        {        
    317                 $this->ldapConnect(true); 
    318                 $cn     = $params['search_for'] ? "*".$params['search_for']."*" : "*"; 
    319                 $user_context = "ou=".$params['organization'].",".$this->ldap_context;           
    320                 $max_result       = $params['max_result'] ? $params['max_result'] : '200';               
     383                //$this->ldapConnect(true); 
     384                include("../contactcenter/inc/external_catalogs.inc.php"); 
     385                $cn     = $params['search_for'] ? "*".utf8_encode($params['search_for'])."*" : "*"; 
     386                $max_result       = $params['max_result'] ? $params['max_result'] : '200'; 
     387                $catalog = $params['catalog']; 
    321388                $error = False; 
     389                         
     390                $this->ldapConnect(false,$catalog); 
     391                 
     392                $params['organization'] == 'todos'?$user_context = $this->ldap_context :$user_context = $this->branch."=".$params['organization'].",".$this->ldap_context;               
    322393                 
    323394                if ($this->ds) {                                                                                         
    324                         $justthese = array("cn", "mail", "phpgwaccounttype", "phpgwAccountVisible"); 
    325                         $filter="(&(|(phpgwAccountType=u)(phpgwAccountType=l))(cn=".$cn."))"; 
    326                         $sr=ldap_search($this->ds, $user_context, $filter, $justthese); 
    327                          
     395                        if ($catalog == 0){ 
     396                                //os atributos "employeeNumber" e "ou" foram adicionado ao vetor de busca; 
     397                                $justthese = array("cn", "mail", "phpgwaccounttype", "phpgwAccountVisible", "employeeNumber", "ou"); 
     398                                $filter="(&(|(phpgwAccountType=u)(phpgwAccountType=l))(cn=".$cn."))"; 
     399                                //$user_context = "ou=".$params['organization'].",".$this->ldap_context; 
     400                        }else { 
     401                                //os atributos "employeeNumber" e "ou" foram adicionado ao vetor de busca; 
     402                                $justthese = array("cn", "mail", "employeeNumber", "ou"); 
     403                                $filter="(&(objectClass=".$this->object_class.")(cn=".$cn."))"; 
     404                                //$user_context = $this->branch."=".$params['organization'].",".$external_srcs[$catalog]['dn']; 
     405                        } 
     406                         
     407                        $sr=ldap_search($this->ds, $user_context, $filter, $justthese,0,200); 
    328408                        $count_entries = ldap_count_entries($this->ds,$sr); 
    329409                        if ($count_entries > $max_result){ 
     
    340420                         
    341421                        for ($i=0; $i<$info["count"]; $i++){ 
    342                                 if ($info[$i]["phpgwaccountvisible"][0] == '-1') 
    343                                         continue; 
    344                                 if((strtoupper($info[$i]["phpgwaccounttype"][0]) == 'U') && ($info[$i]["phpgwaccountvisible"][0] != '-1')) 
    345                                         $u_tmp[$info[$i]["mail"][0]] = $info[$i]["cn"][0]; 
     422                                if((!$catalog==0)||(strtoupper($info[$i]["phpgwaccounttype"][0]) == 'U') && ($info[$i]["phpgwaccountvisible"][0] != '-1')) 
     423                                        //aqui eh feita a concatenacao do departamento ao cn; 
     424                                        $u_tmp[$info[$i]["mail"][0]] = utf8_decode($info[$i]["cn"][0]). '%' . $info[$i]["ou"][0]; 
    346425                                else 
    347                                         $g_tmp[$info[$i]["mail"][0]] = $info[$i]["cn"][0]; 
     426                                        $g_tmp[$info[$i]["mail"][0]] = utf8_decode($info[$i]["cn"][0]); 
    348427                        }                                                                                
    349428                         
    350429                        natcasesort($u_tmp); 
    351430                        natcasesort($g_tmp); 
    352                          
     431 
    353432                        $i = 0; 
    354                         $users = array();                        
    355                          
    356                         foreach ($u_tmp as $mail => $cn){                                
    357                                 $users[$i++] = array("name" => $cn, "email" => $mail); 
    358                         } 
     433                        $users = array(); 
     434 
     435 
     436                        foreach ($u_tmp as $mail => $cn){ 
     437 
     438                                $tmp = explode("%", $cn); //explode o cn pelo caracter "%" e joga em $tmp; 
     439                                $name = $tmp[0]; //pega o primeiro item (cn) do vetor resultante do explode acima; 
     440                                $department = $tmp[1]; //pega o segundo item (ou) do vetor resultanto do explode acima; 
     441                                $users[$i++] = array("name" => $name, "email" => $mail, "department" => $department); 
     442 
     443                        } 
     444 
    359445                        unset($u_tmp); 
    360446                         
     
    368454                         
    369455                        return  array('users' => $users, 'groups' => $groups, 'error' => $error); 
    370                 }                                
     456                }else                            
    371457                return null; 
    372458        } 
     
    393479        } 
    394480         
    395         //Busca usuários de um contexto e já retorna as options do select; 
     481        //Busca usuï¿œrios de um contexto e jï¿œ retorna as options do select; 
    396482        function get_available_users($params) 
    397483    { 
    398484        $this->ldapRootConnect(); 
    399         //Monta lista de Grupos e Usuários 
     485        //Monta lista de Grupos e Usuï¿œrios 
    400486        $users = Array(); 
    401487        $groups = Array(); 
     
    449535    } 
    450536 
    451         //Busca usuários de um contexto e já retorna as options do select; 
     537        //Busca usuï¿œrios de um contexto e jï¿œ retorna as options do select; 
    452538        function get_available_users2($params) 
    453539        { 
     
    499585                         
    500586                        $info = ldap_get_entries($this->ds, $sr); 
    501                         return $info[0]["cn"][0]; 
     587                        return utf8_decode($info[0]["cn"][0]); 
    502588                } 
    503589                return false; 
     
    524610                        $info   =       ldap_get_entries($this->ds, $sr); 
    525611                        $info['myname'] = $_SESSION['phpgw_info']['expressomail']['user']['fullname'];                                           
     612                        for ($i = 0;$i < $info["count"]; $i++) 
     613                                $info[$i]['cn'][0] = utf8_decode($info[$i]['cn'][0]); 
    526614                        return $info; 
    527615                } 
     
    546634                         
    547635                        if($entry) {                                             
    548                                 $obj =  array("cn" => ldap_get_values($ds, $entry, "cn"), 
     636                                $obj =  array("cn" => utf8_decode(ldap_get_values($ds, $entry, "cn")), 
    549637                                                  "email" => $params['email'], 
    550638                                                  "uid" => ldap_get_values($ds, $entry, "uid"), 
Note: See TracChangeset for help on using the changeset viewer.