821 |
alexandre_ |
1 |
<?php
|
|
|
2 |
//vim: set expandtab tabstop=4 shiftwidth=4:
|
|
|
3 |
|
|
|
4 |
// Copyright (C) 1999-2006 Tela Botanica (accueil@tela-botanica.org)
|
|
|
5 |
//
|
|
|
6 |
// Ce logiciel est un programme informatique servant à gérer du contenu et des
|
|
|
7 |
// applications web.
|
|
|
8 |
|
|
|
9 |
// Ce logiciel est régi par la licence CeCILL soumise au droit français et
|
|
|
10 |
// respectant les principes de diffusion des logiciels libres. Vous pouvez
|
|
|
11 |
// utiliser, modifier et/ou redistribuer ce programme sous les conditions
|
|
|
12 |
// de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
|
|
|
13 |
// sur le site "http://www.cecill.info".
|
|
|
14 |
|
|
|
15 |
// En contrepartie de l'accessibilité au code source et des droits de copie,
|
|
|
16 |
// de modification et de redistribution accordés par cette licence, il n'est
|
|
|
17 |
// offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
|
|
|
18 |
// seule une responsabilité restreinte pèse sur l'auteur du programme, le
|
|
|
19 |
// titulaire des droits patrimoniaux et les concédants successifs.
|
|
|
20 |
|
|
|
21 |
// A cet égard l'attention de l'utilisateur est attirée sur les risques
|
|
|
22 |
// associés au chargement, à l'utilisation, à la modification et/ou au
|
|
|
23 |
// développement et à la reproduction du logiciel par l'utilisateur étant
|
|
|
24 |
// donné sa spécificité de logiciel libre, qui peut le rendre complexe à
|
|
|
25 |
// manipuler et qui le réserve donc à des développeurs et des professionnels
|
|
|
26 |
// avertis possédant des connaissances informatiques approfondies. Les
|
|
|
27 |
// utilisateurs sont donc invités à charger et tester l'adéquation du
|
|
|
28 |
// logiciel à leurs besoins dans des conditions permettant d'assurer la
|
|
|
29 |
// sécurité de leurs systèmes et ou de leurs données et, plus généralement,
|
|
|
30 |
// à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
|
|
|
31 |
|
|
|
32 |
// Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
|
|
|
33 |
// pris connaissance de la licence CeCILL, et que vous en avez accepté les
|
|
|
34 |
// termes.
|
|
|
35 |
// ----
|
|
|
36 |
// CVS : $Id: ezmlmAccessObject.class.php,v 1.1 2006-04-19 13:49:48 alexandre_tb Exp $
|
|
|
37 |
|
|
|
38 |
/**
|
|
|
39 |
* Application projet
|
|
|
40 |
*
|
|
|
41 |
* La classe ezmlmAccessObject
|
|
|
42 |
*
|
|
|
43 |
*@package projet
|
|
|
44 |
//Auteur original :
|
|
|
45 |
*@author Alexandre Granier <alexandre@tela-botanica.org>
|
|
|
46 |
//Autres auteurs :
|
|
|
47 |
*@author Aucun
|
|
|
48 |
*@copyright Tela-Botanica 2000-2006
|
|
|
49 |
*@version $Revision: 1.1 $
|
|
|
50 |
// +------------------------------------------------------------------------------------------------------+
|
|
|
51 |
*/
|
|
|
52 |
|
|
|
53 |
/** Etend XML_Parser_Simple */
|
|
|
54 |
require_once 'XML/Parser/Simple.php' ;
|
|
|
55 |
|
|
|
56 |
/**
|
|
|
57 |
* Les codes erreurs
|
|
|
58 |
*/
|
|
|
59 |
|
|
|
60 |
define ('EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE', 206) ;
|
|
|
61 |
/**
|
|
|
62 |
* classe ezmlmAccessObject parse les fichiers XML
|
|
|
63 |
* issue de ezmlm
|
|
|
64 |
*
|
|
|
65 |
* @category XML
|
|
|
66 |
* @package projet
|
|
|
67 |
* @author alex
|
|
|
68 |
*/
|
|
|
69 |
|
|
|
70 |
class ezmlmAccessObject extends XML_Parser_Simple {
|
|
|
71 |
|
|
|
72 |
/**
|
|
|
73 |
* Le domaine de la liste
|
|
|
74 |
*/
|
|
|
75 |
|
|
|
76 |
var $domaine ;
|
|
|
77 |
|
|
|
78 |
/**
|
|
|
79 |
* Le nom de la liste
|
|
|
80 |
*/
|
|
|
81 |
|
|
|
82 |
var $liste ;
|
|
|
83 |
|
|
|
84 |
/**
|
|
|
85 |
* Les actions valides
|
|
|
86 |
*/
|
|
|
87 |
|
|
|
88 |
var $actions_supportees = array ('calendrier_messages',
|
|
|
89 |
'message');
|
|
|
90 |
|
|
|
91 |
/**
|
|
|
92 |
* l'action sélectionnée
|
|
|
93 |
*/
|
|
|
94 |
var $action ;
|
|
|
95 |
|
|
|
96 |
/**
|
|
|
97 |
* La langue 'fr-FR'
|
|
|
98 |
*/
|
|
|
99 |
var $langue ;
|
|
|
100 |
|
|
|
101 |
/**
|
|
|
102 |
* L'url de base
|
|
|
103 |
*/
|
|
|
104 |
var $url ;
|
|
|
105 |
|
|
|
106 |
/**
|
|
|
107 |
* L'identifiant du répertoire
|
|
|
108 |
*/
|
|
|
109 |
var $identifiant_repertoire ;
|
|
|
110 |
|
|
|
111 |
/**
|
|
|
112 |
* Identifiant message
|
|
|
113 |
*/
|
|
|
114 |
|
|
|
115 |
var $identifiant_message;
|
|
|
116 |
|
|
|
117 |
/**
|
|
|
118 |
* L'identifiant du répertoire
|
|
|
119 |
*/
|
|
|
120 |
var $_numeroRepertoireSuivant ;
|
|
|
121 |
|
|
|
122 |
var $_numeraRepertoirePrecedent;
|
|
|
123 |
|
|
|
124 |
/**
|
|
|
125 |
* Identifiant message
|
|
|
126 |
*/
|
|
|
127 |
|
|
|
128 |
var $_numeroFichierSuivant;
|
|
|
129 |
|
|
|
130 |
var $_numeroFichierPrecedent;
|
|
|
131 |
|
|
|
132 |
/**
|
|
|
133 |
* Creation de l'objet d'accès
|
|
|
134 |
*
|
|
|
135 |
*
|
|
|
136 |
*/
|
|
|
137 |
|
|
|
138 |
function ezmlmAccessObject ($action, $domaine, $liste, $langue = 'fr', $url = '') {
|
|
|
139 |
$this->XML_Parser_Simple(null, 'func') ;
|
|
|
140 |
$this->action = $action ;
|
|
|
141 |
$this->domaine = $domaine ;
|
|
|
142 |
$this->liste = $liste ;
|
|
|
143 |
$this->langue = $langue ;
|
|
|
144 |
$this->url = $url ;
|
|
|
145 |
}
|
|
|
146 |
|
|
|
147 |
/**
|
|
|
148 |
* Gestion des balises
|
|
|
149 |
*
|
|
|
150 |
* Cette méthode spécifie les balises reconnus par ezmlmAccessObject
|
|
|
151 |
* Elle remplace la méthode handleElement de XML_Parser_Simple
|
|
|
152 |
*
|
|
|
153 |
* @access public
|
|
|
154 |
* @param string nom de l'élément (Voir la doc de PHP)
|
|
|
155 |
* @param array attributes
|
|
|
156 |
* @param
|
|
|
157 |
* @link http://fr.php.net/manual/fr/ref.xml.php manuel
|
|
|
158 |
*/
|
|
|
159 |
|
|
|
160 |
function handleElement_ezmlm_message ($name, $attribs, $data) {
|
|
|
161 |
echo $data ;
|
|
|
162 |
}
|
|
|
163 |
|
|
|
164 |
function handleElement_message_suivant ($name, $attribs, $data) {
|
|
|
165 |
$this->_numeroRepertoireSuivant = $attribs['NUMERO_REPERTOIRE'] ;
|
|
|
166 |
$this->_numeroFichierSuivant = $attribs['NUMERO'] ;
|
|
|
167 |
}
|
|
|
168 |
|
|
|
169 |
function handleElement_message_precedent ($name, $attribs, $data) {
|
|
|
170 |
$this->_numeroRepertoirePrecedent = $attribs['NUMERO_REPERTOIRE'] ;
|
|
|
171 |
$this->_numeroFichierPrecedent = $attribs['NUMERO'] ;
|
|
|
172 |
}
|
|
|
173 |
function handleElement_ezmlm_calendrier_messages ($name, $attribs, $data) { echo $data ; }
|
|
|
174 |
/**
|
|
|
175 |
* Choix de l'action
|
|
|
176 |
*
|
|
|
177 |
* Liste des actions :
|
|
|
178 |
* 'calendrier_messages'
|
|
|
179 |
*
|
|
|
180 |
* @access public
|
|
|
181 |
* @param string une action qui doit être supporté
|
|
|
182 |
*/
|
|
|
183 |
|
|
|
184 |
function setAction($action) {
|
|
|
185 |
// vérification de l'action
|
|
|
186 |
if (!in_array($action, $this->actions_supportees)) {
|
|
|
187 |
return raiseError(EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE) ;
|
|
|
188 |
}
|
|
|
189 |
$this->action = $action ;
|
|
|
190 |
|
|
|
191 |
// Libere les ressources (XML_Parser::free)
|
|
|
192 |
$this->free();
|
|
|
193 |
|
|
|
194 |
// Charge la nouvelle action
|
|
|
195 |
$this->load() ;
|
|
|
196 |
}
|
|
|
197 |
|
|
|
198 |
/**
|
|
|
199 |
* Charge une action
|
|
|
200 |
*
|
|
|
201 |
* cad affecte un fichier xml au parser
|
|
|
202 |
*
|
|
|
203 |
* @access public
|
|
|
204 |
*/
|
|
|
205 |
function load() {
|
|
|
206 |
$chemin_fichier_xml = PROJET_SERVEUR_VPOPMAIL.'/'.$this->action.'.php?domaine='.
|
|
|
207 |
$this->domaine.'&liste='.$this->liste.'&langue='.
|
|
|
208 |
$this->langue ;
|
|
|
209 |
if ($this->url != '') $chemin_fichier_xml.= '&url='.urlencode($this->url) ;
|
|
|
210 |
if (isset ($this->identifiant_repertoire))
|
|
|
211 |
$chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_repertoire ;
|
|
|
212 |
if (isset ($this->identifiant_message))
|
|
|
213 |
$chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_message ;
|
|
|
214 |
|
|
|
215 |
$this->setInputFile($chemin_fichier_xml) ;
|
|
|
216 |
}
|
|
|
217 |
|
|
|
218 |
/**
|
|
|
219 |
* Précise un message à extraire
|
|
|
220 |
*
|
|
|
221 |
* On indique le numéro de répertoire ezmlm et le numéro du message
|
|
|
222 |
* @param integer le numéro du répertoire
|
|
|
223 |
* @param integer le numéro du message
|
|
|
224 |
*
|
|
|
225 |
*/
|
|
|
226 |
|
|
|
227 |
function setIdMessage ($identifiant_repertoire, $identifiant_message) {
|
|
|
228 |
$this->identifiant_repertoire = $identifiant_repertoire ;
|
|
|
229 |
$this->identifiant_message = $identifiant_message ;
|
|
|
230 |
}
|
|
|
231 |
|
|
|
232 |
/**
|
|
|
233 |
* Renvoi le numero du repertoire suivant
|
|
|
234 |
*
|
|
|
235 |
*
|
|
|
236 |
*/
|
|
|
237 |
function getNumeroRepertoireSuivant() { return $this->_numeroRepertoireSuivant; }
|
|
|
238 |
|
|
|
239 |
function getNumeroFichierSuivant () { return $this->_numeroFichierSuivant ; }
|
|
|
240 |
|
|
|
241 |
function getNumeroRepertoirePrecedent() { return $this->_numeroRepertoirePrecedent; }
|
|
|
242 |
|
|
|
243 |
function getNumeroFichierPrecedent () { return $this->_numeroFichierPrecedent ; }
|
|
|
244 |
}
|
|
|
245 |
|
|
|
246 |
?>
|