source: trunk/prototype/modules/filters/interceptors/FilterMapping.php @ 6534

Revision 6534, 26.4 KB checked in by cristiano, 12 years ago (diff)

Ticket #2865 - Exibição de mensagem ao mover pastas no Expresso Mail

Line 
1<?php
2/**
3*
4* Copyright (C) 2011 Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
5*
6* This program is free software; you can redistribute it and/or modify it under
7* the terms of the GNU Affero General Public License version 3 as published by
8* the Free Software Foundation with the addition of the following permission
9* added to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED
10* WORK IN WHICH THE COPYRIGHT IS OWNED BY FUNAMBOL, FUNAMBOL DISCLAIMS THE
11* WARRANTY OF NON INFRINGEMENT  OF THIRD PARTY RIGHTS.
12*
13* This program is distributed in the hope that it will be useful, but WITHOUT
14* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15* FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more
16* details.
17*
18* You should have received a copy of the GNU Affero General Public License
19* along with this program; if not, see www.gnu.org/licenses or write to
20* the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
21* MA 02110-1301 USA.
22*
23* This code is based on the OpenXchange Connector and on the Prognus pSync
24* Connector both developed by the community and licensed under the GPL
25* version 2 or above as published by the Free Software Foundation.
26*
27* You can contact Prognus Software Livre headquarters at Av. Tancredo Neves,
28* 6731, PTI, Bl. 05, Esp. 02, Sl. 10, Foz do Iguaçu - PR - Brasil or at
29* e-mail address prognus@prognus.com.br.
30*
31* Descrição rápida do arquivo
32*
33* Arquivo responsável pela manipulação dos filtros
34*
35* @package    filters
36* @license    http://www.gnu.org/copyleft/gpl.html GPL
37* @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
38* @version    1.0
39* @sponsor    Caixa Econômica Federal
40* @since      Arquivo disponibilizado na versão 2.4
41*/
42
43use prototype\api\Config as Config;
44
45/**
46* Classe responsável pela manipulação dos filtros.
47*
48*
49* @package    prototype
50* @license    http://www.gnu.org/copyleft/gpl.html GPL
51* @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
52* @author     Airton Bordin Junior <airton@prognus.com.br>
53* @author     Gustavo Pereira dos Santos <gustavo@prognus.com.br>
54* @version    1.0
55* @since      Classe disponibilizada na versão 2.4
56*/
57class FilterMapping
58{
59        var $service;
60        var $msgs_apply = array();
61        /**
62        * Método que cria o ID da regra que está sendo criada.
63        *
64        * @license    http://www.gnu.org/copyleft/gpl.html GPL
65        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
66        * @sponsor    Caixa Econômica Federal
67        * @author     Airton Bordin Junior <airton@prognus.com.br>
68        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
69        * @author         Natan Fonseca <natan@prognus.com.br> 
70        * @param      <$uri>
71        * @param      <$result>
72        * @param      <$criteria>
73        * @param      <$original>
74        * @access     <public>
75        */
76        public function makeId(&$uri , &$result , &$criteria , $original) {
77                $result['id'] = $uri['id'];
78        }
79       
80       
81        /**
82        * Método que formata o Script de acordo com a sintaxe do Sieve.
83        *
84        * @license    http://www.gnu.org/copyleft/gpl.html GPL
85        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
86        * @sponsor    Caixa Econômica Federal
87        * @author     Airton Bordin Junior <airton@prognus.com.br>
88        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
89        * @param      <Array> <$rules> <Array com as regras do usuário>
90        * @return     <Regra de acordo com a sintaxe do Sieve>
91        * @access     <public>
92        */
93        public function formatSieveScript( $rules )
94    {
95                $require_fileinto = $require_flag = $require_reject = $require_vacation = $require_body = $require_imapflag = $vacation = $startswith = $endswith = false;
96
97                $script_rules = $script_header = $script_criteria = $vacation_action = "";
98
99                $i = 0;
100               
101                foreach( $rules as $name => $data )
102                {       
103                        if( $data['enabled'] == 'false' )
104                                continue;
105                               
106                        if(array_key_exists("block", $data)) {
107                                /* Usado na opção Bloquear usuário do ExpressoMail */
108                                if($data['block']) {
109                                        ($i >0) ? $script_match = 'elsif anyof' : $script_match = 'if anyof';
110                                        $script_match = $script_match . "(address :is \"from\" [\"" .$data['name'] . "\"]) {\r\n"; 
111                                        $script_match .= "fileinto \"INBOX/Spam\"; \r\n}\r\n";
112                                        $script_rules .= $script_match;
113                                        $script_match = "";
114                                        $script_criteria = "";
115                                        $require_fileinto = true;
116                                        $i++;
117                                        continue;
118                                }
119                        }
120                               
121                        $vacation = false;
122                        $criteria = $data['criteria'];
123                        $action   = $data['actions'];
124                       
125                        ($i >0) ? $script_match = 'els' : $script_match = '';
126                        $data['isExact'] == 'false' ?  $script_match .= 'if anyof (' : $script_match .= 'if allof (';
127
128                        if( is_array($criteria) )
129                        foreach ($criteria as $j => $value)
130                        {                                       
131                               
132                                switch($criteria[$j]['field']) {
133                                        case 'To':   
134                                        case 'to':   
135                                        case 'CC':
136                                        case 'Cc':
137                                                $criteria[$j]['field'] = "[\"To\", \"TO\", \"Cc\", \"CC\"]";
138                                                $script_criteria .= "address :";
139                                                break;
140                                        case 'from':
141                                                $criteria[$j]['field'] = "\"" . $criteria[$j]['field'] . "\"";
142                                                $script_criteria .= "address :";
143                                                break;
144                                        case 'size':   
145                                                $criteria[$j]['field'] = '';
146                                                $script_criteria .= "size :";
147                                                break;
148                                        case 'subject':
149                                                $criteria[$j]['field'] = "\"" . $criteria[$j]['field'] . "\"";
150                                                $criteria[$j]['value'] = "" . imap_8bit($criteria[$j]['value']) . "*\", \"" . base64_encode($criteria[$j]['value']) . "";
151                                                $criteria[$j]['operator'] = "^";  //temporary
152                                                $script_criteria .= "header :";
153                                                break;
154                                        case 'body':
155                                                $criteria[$j]['field'] = '';
156                                                $script_criteria .= "body :";
157                                                $require_body = true;
158                                                break;
159                                        case 'vacation':
160                                                continue;
161                                        case 'hasAttachment':
162                                                $criteria[$j]['field'] = '';
163                                                $script_criteria .= "body :";
164                                                $criteria[$j]['operator'] = "^^";
165                                                $require_body = true;
166                                                break;
167                                        default:
168                                                $script_criteria .= "header :";
169                                                break;
170                                }
171                               
172                                switch ($criteria[$j]['operator']) {
173                                        case '>':
174                                                $criteria[$j]['operator'] = "over";
175                                                $criteria[$j]['value'] = $criteria[$j]['value'] . "K";
176                                                break;
177                                        case '<':
178                                                $criteria[$j]['operator'] = "under";
179                                                $criteria[$j]['value'] = $criteria[$j]['value'] . "K";
180                                                break;
181                                        case '=':
182                                                $criteria[$j]['operator'] = "is";
183                                                $criteria[$j]['value'] = "[\"" . $criteria[$j]['value'] . "\"]";
184                                                break;
185                                        case '*':
186                                                $criteria[$j]['operator'] = "contains";
187                                                $criteria[$j]['value'] = "[\"" . $criteria[$j]['value'] . "\"]";
188                                                break;                                         
189                                        case '^':
190                                                $criteria[$j]['operator'] = "matches";
191                                                $criteria[$j]['value'] = "[\"" . $criteria[$j]['value'] . "*\"]";
192                                                $startswith = true;
193                                                break;
194                                        case '^^':
195                                                $criteria[$j]['operator'] = "raw :matches";
196                                                $criteria[$j]['value'] = "[\"*filename=*\"]";
197                                                $startswith = true;
198                                                break;
199                                        case '$':
200                                                $criteria[$j]['operator'] = "matches";
201                                                $criteria[$j]['value'] = "[\"*" . $criteria[$j]['value'] . "\"]";
202                                                $endswith = true;
203                                                break;
204                                        /*
205                                           TO-DO:
206                                           Inconsistência na regra do "não contém".
207                                        */
208                                        case '!*':
209                                                $criteria[$j]['operator'] = "contains";
210                                                $criteria[$j]['value'] = "[\"" . $criteria[$j]['value'] . "\"]";
211                                                break;
212                                }
213                               
214                                if ($criteria[$j]['field'] == "" || $criteria[$j]['field'] == "\"subject\"" || $startswith || $endswith)
215                                {
216                                        $script_criteria .= $criteria[$j]['operator'] . " " . $criteria[$j]['field'] . " " . $criteria[$j]['value'] . ", ";
217                                        $startswith = $endswith = false;
218                                }
219                                else
220                                        $script_criteria .= $criteria[$j]['operator'] . " " . $criteria[$j]['field'] . " " . $criteria[$j]['value'] . ", ";
221                        }
222                        $script_criteria = substr($script_criteria,0,-2);
223                        /* if ($vacation == false) */
224                        $script_criteria .= ")";
225
226                        //$script_action = " {\r\n ";
227                        /* Somente para controlar que o addFlag virá antes de qualquer ação. Modificar isso depois */
228                        $action_addFlag = '';
229                       
230                        if( is_array($action) )
231                        foreach ($action as $k => $value)
232                        {
233                                switch ($action[$k]['type']) {
234                                        case 'setflag':
235                                                $require_flag = true;
236                                                $action[$k]['parameter'] = "\\\\" . $action[$k]['parameter'];
237                                                break;
238                                        case 'addflag':
239                                                $require_flag = true;
240                                                $action_addFlag = "addflag \"" . $action[$k]['parameter'] . "\";\r\n ";
241                                                break;
242                                        case 'redirect':
243                                                break;
244                                        case 'reject':
245                                                $require_reject = true;
246                                                break;
247                                        case 'fileinto':
248                                                $require_fileinto = true;
249                                                $action[$k]['parameter'] = mb_convert_encoding($action[$k]['parameter'], "UTF7-IMAP","UTF-8, ISO-8859-1, UTF7-IMAP");
250                                                break;
251                                        case 'vacation':
252                                                $require_vacation = true;
253                                                $action[$k]['parameter'] = "\"" . $action[$k]['parameter'] . "\"";
254                                                $vacation_action = ' :subject "Fora do Escrit&oacuterio" ' . $action[$k]['parameter'] . ";";
255                                                $vacation = true;
256                                                continue;
257                                        case 'discard':
258                                                break;
259                                }
260                                if ($vacation == false && $action[$k]['type'] != 'addflag') $script_action .= $action[$k]['type'] . " \"" . $action[$k]['parameter'] . "\";\r\n ";
261                        }
262                       
263                        /* ATENÇÃO: Colocar sempre o comando addflag antes de qualquer outro no caso de ações compostas no Sieve */
264                        if ($action_addFlag != '') $script_action = $action_addFlag . $script_action;
265                       
266                        $script_action = "{\r\n " . $script_action . "}";
267                        $action_addFlag = '';
268                        if($vacation == false)
269                                $script_rules .= $script_match . $script_criteria . $script_action . "\r\n";
270
271                        if($data['id'] != "vacation")
272                                $i++;
273                        $script_match = "";
274                        $script_criteria = ""; 
275                        $script_action = "";
276                        $data['applyMessages'] = "";                                                   
277                }
278
279                if($require_reject || $require_fileinto || $require_vacation || $require_body || $require_flag)
280                {
281                        /* Para habilitar as funções desejadas, edite a diretiva sieve_extensions no arquivo de configuração "/etc/imapd.conf" */
282                        $script_header .= "require [";
283                        $require_reject ? $script_header .= "\"reject\", " : "";
284                        $require_fileinto ? $script_header .= "\"fileinto\", " : "";
285                        $require_vacation? $script_header .= "\"vacation\", " : ""; 
286                        $require_flag ? $script_header .= "\"imapflags\", " : ""; 
287                        $require_body ? $script_header .= "\"body\", " : ""; 
288                        $script_header = substr($script_header,0,-2);
289                        $script_header .= "];\r\n";
290                }
291
292                if( $vacation_action )
293                {
294                  $script_rules .= "vacation" . $vacation_action . "\r\n";
295                }
296
297                foreach ($rules as &$values) {                                         
298                        if($values['applyMessages'])
299                                $this->msgs_apply[] = $values['applyMessages'];
300                        $values['applyMessages'] = array();
301                }
302
303                $json_data = json_encode($rules);
304               
305                $script_begin = "#Filtro gerado por Expresso Livre\r\n\r\n";
306
307                $content = $script_begin . $script_header . $script_rules . "\r\n\r\n#PseudoScript#" . "\r\n#" . $json_data;
308
309                return( $content );
310        }
311       
312        /**
313        * Método que lê e faz o parser dos filtros antigos
314        *
315        * @license    http://www.gnu.org/copyleft/gpl.html GPL
316        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
317        * @sponsor    Caixa Econômica Federal
318        * @author     Airton Bordin Junior <airton@prognus.com.br>
319        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
320        * @param      <$scriptName> <Regras do usuário>
321        * @return     <Regra do usuário parseada>
322        * @access     <public>
323        */
324        public function readOldScript($scriptName)
325        {
326        // Recebe o conteúdo do array;
327        $lines = array();
328        $lines = preg_split("/\n/", $scriptName);
329
330        // Pega o tamanho da regra na primeira do script;
331        $size_rule = array_shift($lines);
332
333        // Recebe o tamanho do script, pela primeira linha;
334        //$this->size = trim($size_rule);
335
336        // Verifica a composição do script; */
337        $line = array_shift($lines);
338
339        // Variaveis para a regra e o campo ferias;
340        $regexps = array('##PSEUDO', '#rule', '#vacation', '#mode');
341        $retorno['rule'] = array();
342
343        $line = array_shift($lines);
344        while (isset($line)) {
345            foreach ($regexps as $regp) {
346                if (preg_match("/$regp/i", $line)) {
347                    // Recebe todas as regras criadas no servidor;
348                    if (preg_match("/#rule&&/i", $line)) {
349                        $retorno['rule'][] = ltrim($line) . "\n";                         
350                    }
351                }
352            }
353            // Pega a proxima linha do sript;
354            $line = array_shift($lines);
355        }
356        return $retorno;
357    }
358       
359       
360       
361       
362        /**
363        * Método que faz o parsing do Script Sieve, transformando em Array.
364        *
365        * @license    http://www.gnu.org/copyleft/gpl.html GPL
366        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
367        * @sponsor    Caixa Econômica Federal
368        * @author     Airton Bordin Junior <airton@prognus.com.br>
369        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
370        * @param      <String> <$script> <Script Sieve com as regras do usuário>
371        * @return     <Regras do usuário em Array>
372        * @access     <public>
373        */
374        public function parseSieveScript( $script )
375        {
376                $old_rule = strripos($script, "##PSEUDO script start");
377                /* Tem regra antiga */
378                if($old_rule) {
379                        $parsed_rule = $this->readOldScript($script);
380                        $old_rules = array();
381                        $i_return = 0;
382                        foreach ($parsed_rule['rule'] as $i => $value) {
383                                $array_rule = explode("&&", $parsed_rule['rule'][$i]);
384                               
385                                $action_type = array();
386                                $action_parameter = array();
387                                $criteria_value = array();
388                                $criteria_operator = array();
389                                $criteria_field = array();
390                                       
391                                $i_criteria = 0;
392                                $i_action = 0;
393
394                                /* TO-DO: Ver as actions possíveis além de reject e fileinto */
395                                switch($array_rule[6]) {
396                                        case 'reject':
397                                                $action_type[$i_action] = 'reject';
398                                                $action_parameter[$i_action] = $array_rule[7];
399                                                $i_action++;
400                                                break;
401                                        case 'folder':
402                                                $action_type[$i_action] = 'fileinto';
403                                                $action_parameter[$i_action] = $array_rule[7];
404                                                $i_action++;
405                                                break;
406                                        case 'flagged':
407                                                $action_type[$i_action] = 'setflag';
408                                                $action_parameter[$i_action] = 'flagged';
409                                                $i_action++;
410                                                break;
411                                        case 'address':
412                                                $action_type[$i_action] = 'redirect';
413                                                $action_parameter[$i_action] = $array_rule[7];
414                                                $i_action++;
415                                                break;
416                                        /* Somente para tratar casos em que a ação não é suportada */
417                                        default:       
418                                                $action_type[$i_action] = 'setflag';
419                                                $action_parameter[$i_action] = 'flagged';
420                                                $i_action++;
421                                                break;
422                                        // Recuperar o cyrus_delimiter para forçar um fileinto para INBOX/trash
423                                        //case 'discard':
424                                                //$action_type[$i_action] = 'fileinto';
425                                                //$action_parameter[$i_action] =;
426                                                //$i_action++;
427                                                //break;
428                                }
429                                if($array_rule[3] != "") {
430                                        $criteria_value[$i_criteria] = $array_rule[3];
431                                        $criteria_operator[$i_criteria] = '=';
432                                        $criteria_field[$i_criteria] = 'from';
433                                        $i_criteria++;
434                                }
435                                if($array_rule[4] != "") {
436                                        $criteria_value[$i_criteria] = $array_rule[4];
437                                        $criteria_operator[$i_criteria] = '=';
438                                        $criteria_field[$i_criteria] = 'to';
439                                        $i_criteria++;
440                                }
441                                if($array_rule[5] != "") {
442                                        $criteria_value[$i_criteria] = $array_rule[5];
443                                        $criteria_operator[$i_criteria] = '=';
444                                        $criteria_field[$i_criteria] = 'subject';
445                                        $i_criteria++;
446                                }
447                                $old_retorno = array();
448                                $old_retorno['isExact']  = true;
449                                $old_retorno['name'] = 'regra_migrada_' . $array_rule[1];
450                               
451                                $old_retorno['criteria'] = array();                             
452                                foreach($criteria_value as $j => $value) {
453                                        $old_retorno['criteria'][$j] = array();
454                                        $old_retorno['criteria'][$j]['value'] = $criteria_value[$j];
455                                        $old_retorno['criteria'][$j]['operator'] = $criteria_operator[$j];
456                                        $old_retorno['criteria'][$j]['field'] = $criteria_field[$j];
457                                }
458                               
459                                $old_retorno['actions'] = array();                             
460                                foreach($action_parameter as $j => $value) {
461                                        $old_retorno['actions'][$j] = array();
462                                        $old_retorno['actions'][$j]['parameter'] = $action_parameter[$j];
463                                        $old_retorno['actions'][$j]['type'] = $action_type[$j];
464                                }
465                               
466                                $old_retorno['enabled'] = ($array_rule[2] == 'ENABLED') ? 'true' : 'false';
467                                $old_retorno['id'] = 'Regra_migrada_' . $i_return;
468                                $old_retorno['applyMessages']  = '';
469
470                                $old_rules[$i_return] = $old_retorno;
471                                $i_return++;
472                        }                       
473                        return $old_rules;
474                }
475                /* Não tem regra antiga */
476                $pos = strripos($script, "#PseudoScript#");
477                $pseudo_script = substr( $script, $pos+17 );
478
479                $return = json_decode( $pseudo_script, true );
480       
481                return $return;
482        }
483
484        var $rules = false;
485
486        /**
487        * Construtor da classe.
488        *
489        * @license    http://www.gnu.org/copyleft/gpl.html GPL
490        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
491        * @sponsor    Caixa Econômica Federal
492        * @author     Airton Bordin Junior <airton@prognus.com.br>
493        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
494        * @access     <public>
495        */
496        public function __construct()
497        {
498                $this->service = Controller::service("Sieve");
499        }
500
501       
502        /**
503        * Método que recupera as regras do usuário.
504        *
505        * @license    http://www.gnu.org/copyleft/gpl.html GPL
506        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
507        * @sponsor    Caixa Econômica Federal
508        * @author     Airton Bordin Junior <airton@prognus.com.br>
509        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
510        * @return     <Regras do usuário>
511        * @access     <public>
512        */
513        public function getRules()
514        {
515                $this->rules = Controller::find( array( 'concept' => 'filter' ) );
516
517                if( !$this->rules ) {
518                        $this->rules = array();
519                }
520                return( $this->rules );
521        }
522
523       
524        /**
525        * Método que aplica o filtro para as mensagens do usuário.
526        *
527        * @license    http://www.gnu.org/copyleft/gpl.html GPL
528        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
529        * @sponsor    Caixa Econômica Federal
530        * @author     Airton Bordin Junior <airton@prognus.com.br>
531        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
532        * @param      <$uri>
533        * @param      <$result>
534        * @param      <$criteria>
535        * @param      <$original>
536        * @access     <public>
537        */
538        public function applySieveFilter( &$uri , &$result , &$criteria , $original  )
539        {
540                $rule_apply = array();
541                       
542                $filter = Controller::read($uri);
543                $filter_ = $this->parseSieveScript($filter['content']);
544               
545                foreach ($filter_ as $f_) {
546                        if($f_['id'] == $uri['id']) {
547                                $rule_apply     = $f_;
548                        }
549                }
550                               
551                $actions = array();
552                $actions['type'] = $rule_apply['actions'][0]['type'];
553                $actions['parameter'] = $rule_apply['actions'][0]['parameter'];
554                /* Hardcoded */
555                $actions['keep'] = false;
556
557                //$messages = $rule_apply['applyMessages'];
558                $messages = $this->msgs_apply[0];
559                $this->msgs_apply = array();
560                       
561                $imap = Controller::service( 'Imap' );
562                $imap->apliSieveFilter($messages, $actions);
563                return $result;
564        }
565
566       
567        /**
568        * Método que lê o script do usuário.
569        *
570        * @license    http://www.gnu.org/copyleft/gpl.html GPL
571        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
572        * @sponsor    Caixa Econômica Federal
573        * @author     Airton Bordin Junior <airton@prognus.com.br>
574        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
575        * @param      <$uri>
576        * @param      <$result>
577        * @param      <$criteria>
578        * @param      <$original>
579        * @return     <Script do usuário>
580        * @access     <public>
581        */
582        public function readUserScript( &$uri , &$params , &$criteria , $original )
583        { 
584                $uri['id'] = $this->service->config['user'];
585        }
586 
587 
588        /**
589        * Método que seta o script do usuário.
590        *
591        * @license    http://www.gnu.org/copyleft/gpl.html GPL
592        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
593        * @sponsor    Caixa Econômica Federal
594        * @author     Airton Bordin Junior <airton@prognus.com.br>
595        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
596        * @param      <$uri>
597        * @param      <$result>
598        * @param      <$criteria>
599        * @param      <$original>
600        * @return     <Script do usuário>
601        * @access     <public>
602        */
603        public function setRule( &$uri , &$params , &$criteria , $original  )
604        {
605                if( !$this->rules )
606                        $this->rules = $this->getRules();
607
608            $uri['id'] = $params['id'] = isset($params['id']) ? $params['id'] : urlencode($params['name']);
609
610            $i = 0;
611
612            for( ; isset($this->rules[$i]) && $this->rules[$i]['id'] !== $params['id']; $i++ );
613
614            $this->rules[$i] = array_merge( ( isset($this->rules[$i]) ? $this->rules[$i] : array() ), $params );
615
616            $params = array( 'name' => $this->service->config['user'],
617                             'content' => $this->formatSieveScript( $this->rules ),
618                             'active' => true );
619        }
620
621       
622        /**
623        * Método que deleta o script do usuário.
624        *
625        * @license    http://www.gnu.org/copyleft/gpl.html GPL
626        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
627        * @sponsor    Caixa Econômica Federal
628        * @author     Airton Bordin Junior <airton@prognus.com.br>
629        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
630        * @param      <$uri>
631        * @param      <$result>
632        * @param      <$criteria>
633        * @param      <$original>
634        * @access     <public>
635        */
636        public function deleteRule( &$uri, &$params, &$criteria, $original )
637        {
638                if( !$this->rules ) {   
639                        $this->rules = $this->getRules();
640                }         
641                $params['id'] = $uri['id'];
642
643                $rules = array();
644
645                foreach( $this->rules as $i => $rule )
646                        if( $rule['id'] !== $uri['id'] )
647                                $rules[] = $this->rules[$i];
648
649                $this->rules = $rules;
650               
651                $uri['id'] = '';
652
653                $params = array( 'name' => $this->service->config['user'],
654                           'content' => $this->formatSieveScript( $this->rules ),
655                           'active' => true );
656
657                $URI = Controller::URI( $uri['concept'], $this->service->config['user'] );
658                $this->service->update( $URI, $params );
659       
660                return( false );
661        }
662
663       
664        /**
665        * Método que pega o script do usuário.
666        *
667        * @license    http://www.gnu.org/copyleft/gpl.html GPL
668        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
669        * @sponsor    Caixa Econômica Federal
670        * @author     Airton Bordin Junior <airton@prognus.com.br>
671        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
672        * @param      <$uri>
673        * @param      <$result>
674        * @param      <$criteria>
675        * @param      <$original>
676        * @return     <Script do usuário>
677        * @access     <public>
678        */
679        public function getSieveRule( &$uri , &$params , &$criteria , $original )
680        {         
681                $script = $this->parseSieveScript( $params['content'] );
682
683                foreach( $script as $i => $rule )
684                        if(is_array ($rule['name']) && is_array($original['id']))
685                        if( $rule['name'] === $original['id'] )
686                                return( $params = $rule );
687        }
688
689       
690        /**
691        * Método que lista as regras do usuário.
692        *
693        * @license    http://www.gnu.org/copyleft/gpl.html GPL
694        * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
695        * @sponsor    Caixa Econômica Federal
696        * @author     Airton Bordin Junior <airton@prognus.com.br>
697        * @author         Gustavo Pereira dos Santos <gustavo@prognus.com.br>   
698        * @param      <$uri>
699        * @param      <$result>
700        * @param      <$criteria>
701        * @param      <$original>
702        * @return     <Regras do usuário>
703        * @access     <public>
704        */
705        public function listSieveRules( &$uri , &$params , &$criteria , $original  )
706        {
707                $return = $params = $this->parseSieveScript( $params[0]['content'] );
708                return( $return );
709        }
710
711        /**
712         * Método que insere no ldap as informações do vacation
713         *
714         * @license    http://www.gnu.org/copyleft/gpl.html GPL
715         * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
716         * @sponsor     Caixa Econômica Federal
717         * @author     Cristiano Corrêa Schmidt
718         * @param      <$uri>
719         * @param      <$result>
720         * @param      <$criteria>
721         * @param      <$original>
722         * @return     <void>
723         * @access     public
724         */
725        public function verifyVacationRule( &$uri , &$params , &$criteria , $original  )
726        {
727            if( $original['properties']['id'] === 'vacation' )
728            {
729
730                $user = Controller::read(array('concept' => 'user' , 'id' => config::me('uidNumber') , 'service' => 'OpenLDAP'));
731                $ldapConf = Config::service('OpenLDAP', 'config');
732                $con = ldap_connect( $ldapConf['host'] );
733                ldap_set_option( $con,LDAP_OPT_PROTOCOL_VERSION, 3 );
734                ldap_bind( $con, $ldapConf['user'], $ldapConf['password']);
735
736                $info = array();
737                if(!in_array('Vacation', $user['objectClass']))
738                        $info['objectClass'] = 'Vacation';
739
740                $info['vacationActive'] = strtoupper($original['properties']['enabled']);
741
742                if(isset($original['properties']['actions']) && isset($original['properties']['actions'][0]['parameter']))
743                        $info['vacationInfo']   = $original['properties']['actions'][0]['parameter'];
744                else if( !isset($user['vacationInfo']) )
745                {
746                    $rules = $this->getRules();
747                    if(is_array($rules))
748                        foreach ($rules as $rule)
749                        if($rule['id'] === 'vacation')
750                                $info['vacationInfo'] = $rule['actions'][0]['parameter'];
751                }
752
753                if(!in_array('Vacation', $user['objectClass']))
754                        ldap_mod_add ( $con , $user['dn'] ,  $info );
755                else
756                        ldap_modify ( $con , $user['dn'] ,  $info );
757
758
759                ldap_close($con);
760
761            }
762         
763        }
764
765        /**
766         * Método que remove do ldap as informações do vacation
767         *
768         * @license    http://www.gnu.org/copyleft/gpl.html GPL
769         * @author     Consórcio Expresso Livre - 4Linux (www.4linux.com.br) e Prognus Software Livre (www.prognus.com.br)
770         * @sponsor     Caixa Econômica Federal
771         * @author     Cristiano Corrêa Schmidt
772         * @param      <$uri>
773         * @param      <$result>
774         * @param      <$criteria>
775         * @param      <$original>
776         * @return     <void>
777         * @access     public
778         */
779        public function deleteVacationRule( &$uri , &$params , &$criteria , $original  )
780        {         
781            if( $original['URI']['id'] === 'vacation' )
782            {
783                $user = Controller::read(array('concept' => 'user' , 'id' => config::me('uidNumber') , 'service' => 'OpenLDAP'));
784                $ldapConf = Config::service('OpenLDAP', 'config');
785                $con = ldap_connect( $ldapConf['host'] );
786                ldap_set_option( $con,LDAP_OPT_PROTOCOL_VERSION, 3 );
787                ldap_bind( $con, $ldapConf['user'], $ldapConf['password']);
788                $info = array();
789                $info['vacationActive'] = 'FALSE';
790                $info['vacationInfo'] = "";
791                ldap_modify ( $con , $user['dn'] ,  $info );
792                ldap_close($con);
793            }
794        }
795}
Note: See TracBrowser for help on using the repository browser.