LSattribute :: generateValue() : Fixed bug when generated value is an array.
[ldapsaisie.git] / public_html / includes / class / class.LSattr_html_maildir.php
1 <?php
2 /*******************************************************************************
3  * Copyright (C) 2007 Easter-eggs
4  * http://ldapsaisie.labs.libre-entreprise.org
5  *
6  * Author: See AUTHORS file in top-level directory.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License version 2
10  * as published by the Free Software Foundation.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20
21 ******************************************************************************/
22
23 LSsession :: loadLSaddon('maildir');
24
25 /**
26  * Type d'attribut HTML maildir
27  *
28  * @author Benjamin Renard <brenard@easter-eggs.com>
29  */
30 class LSattr_html_maildir extends LSattr_html {
31
32   var $LSformElement_type = 'maildir';
33   var $_toDo = array();
34   
35   function LSattr_html_maildir ($name,$config,&$attribute) {
36     $attribute -> addObjectEvent('before_delete',$this,'beforeDelete');
37     $attribute -> addObjectEvent('after_delete',$this,'deleteMaildirByFTP');
38     return parent :: LSattr_html($name,$config,&$attribute);
39   }
40   
41   public function doOnModify($action,$cur,$new) {
42     $this -> _toDo = array (
43       'action' => $action,
44       'old' => $cur,
45       'new' => $new
46     );
47     $this -> attribute -> addObjectEvent('after_modify',$this,'toDo');
48   }
49   
50   function toDo() {
51     if (is_array($this -> _toDo)) {
52       switch($this -> _toDo['action']) {
53         case 'delete':
54             return $this -> deleteMaildirByFTP();
55           break;
56         case 'modify':
57           if (renameMaildirByFTP($this -> _toDo['old'],$this -> _toDo['new'])) {
58             LSsession :: addInfo(_("The mailbox has been moved."));
59             return true;
60           }
61           return;
62           break;
63         case 'create':
64           if (createMaildirByFTP(null,$this -> _toDo['new'])) {
65             LSsession :: addInfo(_("The mailbox has been created."));
66             return true;
67           }
68           return;
69           break;
70         default:
71           LSdebug($this -> name.' - LSformElement_maildir->toDo() : Unknown action.');
72       }
73     }
74     LSdebug($this -> name.' - LSformElement_maildir->toDo() : Nothing to do.');
75     return true;
76   }
77   
78   public function deleteMaildirByFTP() {
79     if ($this -> config['html_options']['archiveNameFormat']) {
80       LSdebug('LSformElement_maildir : archive');
81       $newname=getFData($this -> config['html_options']['archiveNameFormat'],$this -> _toDo['old']);
82       if ($newname) {
83         if (renameMaildirByFTP($this -> _toDo['old'],$newname)) {
84           LSsession :: addInfo(_("The mailbox has been archived successfully."));
85           return true;
86         }
87         return;
88       }
89       LSdebug($this -> name." - LSformElement_maildir->toDo() : Incorrect archive name.");
90       return;
91     }
92     else {
93       LSdebug('LSformElement_maildir : delete');
94       if (removeMaildirByFTP(null,$this -> _toDo['old'])) {
95         LSsession :: addInfo(_("The mailbox has been deleted."));
96         return true;
97       }
98       return;
99     }
100   }
101   
102   public function beforeDelete() {
103     $this -> _toDo = array (
104       'action' => 'delete',
105       'old' => $this -> getRemoteRootPathRegex(),
106       'new' => ''
107     );
108   }
109   
110   public function getRemoteRootPathRegex($val='LS') {
111     if ($val=='LS') {
112       $val = $this -> attribute -> getValue();
113       $val=$val[0];
114     }
115     if ($this -> config['html_options']['remoteRootPathRegex']) {
116       if (
117         ereg($this -> config['html_options']['remoteRootPathRegex'],$val,$r)
118         ||
119         empty($val)
120       )
121       {
122         $val = $r[1];
123       }
124       else {
125         LSdebug('Pbl remoteRootPathRegex');
126       }
127     }
128     return $val;
129   }
130   
131 }
132
133 ?>