array ( * // Required * 'LSform' => array ( // To define if the user can active triggers for the LSform * 'create' => 1, // Example : LSform 'create' => Triggers active by default * 'modify' => 0 // Example : LSform 'modify' => Triggers disable by default * ), * // Optional * 'remoteRootPathRegex' => "^\/home\/vmail\/([^\/]*)\/+$", // Regex to determine the path of * // maildir from the attribute value * 'archiveNameFormat' => "archives/%{old}" // To archive rather than destroyed : * // At the elimination, the maildir is moved * // rather than deleted. The new name / path * // of the maildir is determined from the old * // name and LSformat. * ), * // ************************************* * * @author Benjamin Renard */ class LSformElement_maildir extends LSformElement_text { var $_toDo=null; var $JSscripts = array( 'LSformElement_maildir_field.js', 'LSformElement_maildir.js' ); var $fieldTemplate = 'LSformElement_maildir_field.tpl'; function getDisplay() { LSsession :: addHelpInfos ( 'LSformElement_maildir', array( 'do' => _("Concurrent creation or modification of the maildir by many users is enabled. Click to disable."), 'nodo' => _("Click to enable concurrent creation/modification of the maildir by many users at the same time.") ) ); return parent :: getDisplay($return); } /** * Recupère la valeur de l'élement passée en POST * * Cette méthode vérifie la présence en POST de la valeur de l'élément et la récupère * pour la mettre dans le tableau passer en paramètre avec en clef le nom de l'élément * * @param[] array Pointeur sur le tableau qui recupèrera la valeur. * * @retval boolean true si la valeur est présente en POST, false sinon */ function getPostData(&$return) { // Récupère la valeur dans _POST, et les vérifie avec la fonction générale $retval = parent :: getPostData($return); // Si une valeur est recupérée if ($retval&&$_POST['LSformElement_maildir_'.$this -> name.'_do']) { $cur = $this -> form -> ldapObject -> attrs[$this -> name] -> getValue(); $cur=$cur[0]; $new = $return[$this -> name][0]; $action=null; if ( $new != $cur ) { if( ($new=="") && ( $cur!="" ) ) { $action='delete'; } else if ( ($new!="") && ( $cur!="" ) ) { $action='modify'; } else { $action='create'; } if ($action) { if ($this -> params['html_options']['remoteRootPathRegex']) { if ( (ereg($this -> params['html_options']['remoteRootPathRegex'],$new,$r_new) ||empty($new)) && (ereg($this -> params['html_options']['remoteRootPathRegex'],$cur,$r_cur)||empty($cur)) ) { $new = $r_new[1]; $cur = $r_cur[1]; } else { LSdebug('Pbl remoteRootPathRegex'); } } $this -> _toDo = array ( 'action' => $action, 'old' => $cur, 'new' => $new ); $this -> attr_html -> attribute -> addObjectEvent('after_modify',$this,'toDo'); } } } return $retval; } function toDo() { if (is_array($this -> _toDo)) { switch($this -> _toDo['action']) { case 'delete': if ($this -> params['html_options']['archiveNameFormat']) { $newname=getFData($this -> params['html_options']['archiveNameFormat'],$this -> _toDo['old']); if ($newname) { if (renameMaildirByFTP($this -> _toDo['old'],$newname)) { LSsession :: addInfo(_("The mailbox has been renamed successfully.")); return true; } return; } LSdebug($this -> name." - LSformElement_maildir->toDo() : Incorrect archive name."); return; } else { if (removeMaildirByFTP(null,$this -> _toDo['old'])) { LSsession :: addInfo(_("The mailbox has been deleted.")); return true; } return; } break; case 'modify': if (renameMaildirByFTP($this -> _toDo['old'],$this -> _toDo['new'])) { LSsession :: addInfo(_("The mailbox has been moved.")); return true; } return; break; case 'create': if (createMaildirByFTP(null,$this -> _toDo['new'])) { LSsession :: addInfo(_("The mailbox has been created.")); return true; } return; break; default: LSdebug($this -> name.' - LSformElement_maildir->toDo() : Unknown action.'); } } LSdebug($this -> name.' - LSformElement_maildir->toDo() : Nothing to do.'); return true; } } ?>