Subversion Repositories Applications.projet

Rev

Rev 249 | Rev 387 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 249 Rev 306
1
<?php
1
<?php
2
//vim: set expandtab tabstop=4 shiftwidth=4:
2
//vim: set expandtab tabstop=4 shiftwidth=4:
3
 
3
 
4
// Copyright (C) 1999-2006 Tela Botanica (accueil@tela-botanica.org)
4
// Copyright (C) 1999-2006 Tela Botanica (accueil@tela-botanica.org)
5
//
5
//
6
// Ce logiciel est un programme informatique servant à gérer du contenu et des
6
// Ce logiciel est un programme informatique servant à gérer du contenu et des
7
// applications web.
7
// applications web.
8
                                                                                                      
8
                                                                                                      
9
// Ce logiciel est regi par la licence CeCILL soumise au droit francais et
9
// Ce logiciel est regi par la licence CeCILL soumise au droit francais et
10
// respectant les principes de diffusion des logiciels libres. Vous pouvez
10
// respectant les principes de diffusion des logiciels libres. Vous pouvez
11
// utiliser, modifier et/ou redistribuer ce programme sous les conditions
11
// utiliser, modifier et/ou redistribuer ce programme sous les conditions
12
// de la licence CeCILL telle que diffusee par le CEA, le CNRS et l'INRIA 
12
// de la licence CeCILL telle que diffusee par le CEA, le CNRS et l'INRIA 
13
// sur le site "http://www.cecill.info".
13
// sur le site "http://www.cecill.info".
14
 
14
 
15
// En contrepartie de l'accessibilite au code source et des droits de copie,
15
// En contrepartie de l'accessibilite au code source et des droits de copie,
16
// de modification et de redistribution accordes par cette licence, il n'est
16
// de modification et de redistribution accordes par cette licence, il n'est
17
// offert aux utilisateurs qu'une garantie limitee.  Pour les memes raisons,
17
// offert aux utilisateurs qu'une garantie limitee.  Pour les memes raisons,
18
// seule une responsabilite restreinte pese sur l'auteur du programme,  le
18
// seule une responsabilite restreinte pese sur l'auteur du programme,  le
19
// titulaire des droits patrimoniaux et les concedants successifs.
19
// titulaire des droits patrimoniaux et les concedants successifs.
20
 
20
 
21
// A cet egard  l'attention de l'utilisateur est attiree sur les risques
21
// A cet egard  l'attention de l'utilisateur est attiree sur les risques
22
// associes au chargement,  a l'utilisation,  a la modification et/ou au
22
// associes au chargement,  a l'utilisation,  a la modification et/ou au
23
// developpement et a la reproduction du logiciel par l'utilisateur etant 
23
// developpement et a la reproduction du logiciel par l'utilisateur etant 
24
// donne sa specificite de logiciel libre, qui peut le rendre complexe a 
24
// donne sa specificite de logiciel libre, qui peut le rendre complexe a 
25
// manipuler et qui le reserve donc a des developpeurs et des professionnels
25
// manipuler et qui le reserve donc a des developpeurs et des professionnels
26
// avertis possedant  des  connaissances  informatiques approfondies.  Les
26
// avertis possedant  des  connaissances  informatiques approfondies.  Les
27
// utilisateurs sont donc invites a charger  et  tester  l'adequation  du
27
// utilisateurs sont donc invites a charger  et  tester  l'adequation  du
28
// logiciel a leurs besoins dans des conditions permettant d'assurer la
28
// logiciel a leurs besoins dans des conditions permettant d'assurer la
29
// securite de leurs systemes et ou de leurs donnees et, plus generalement, 
29
// securite de leurs systemes et ou de leurs donnees et, plus generalement, 
30
// a l'utiliser et l'exploiter dans les memes conditions de securite. 
30
// a l'utiliser et l'exploiter dans les memes conditions de securite. 
31
 
31
 
32
// Le fait que vous puissiez acceder a cet en-tete signifie que vous avez 
32
// Le fait que vous puissiez acceder a cet en-tete signifie que vous avez 
33
// pris connaissance de la licence CeCILL, et que vous en avez accepte les
33
// pris connaissance de la licence CeCILL, et que vous en avez accepte les
34
// termes.
34
// termes.
35
// ----
35
// ----
36
// CVS : $Id: ezmlmAccessObject.class.php,v 1.5 2007-06-25 12:15:06 alexandre_tb Exp $
36
// CVS : $Id: ezmlmAccessObject.class.php,v 1.6 2008-08-25 15:16:59 alexandre_tb Exp $
37
 
37
 
38
/**
38
/**
39
* Application projet
39
* Application projet
40
*
40
*
41
* La classe ezmlmAccessObject
41
* La classe ezmlmAccessObject
42
*
42
*
43
*@package projet
43
*@package projet
44
//Auteur original :
44
//Auteur original :
45
*@author        Alexandre Granier <alexandre@tela-botanica.org>
45
*@author        Alexandre Granier <alexandre@tela-botanica.org>
46
//Autres auteurs :
46
//Autres auteurs :
47
*@author        Aucun
47
*@author        Aucun
48
*@copyright     Tela-Botanica 2000-2006
48
*@copyright     Tela-Botanica 2000-2006
49
*@version       $Revision: 1.5 $
49
*@version       $Revision: 1.6 $
50
// +------------------------------------------------------------------------------------------------------+
50
// +------------------------------------------------------------------------------------------------------+
51
*/
51
*/
52
 
52
 
53
/** Etend XML_Parser_Simple */
53
/** Etend XML_Parser_Simple */
54
require_once 'XML/Parser/Simple.php' ;
54
require_once 'XML/Parser/Simple.php' ;
55
 
55
 
56
/**
56
/**
57
 * Les codes erreurs
57
 * Les codes erreurs
58
 */
58
 */
59
 
59
 
60
define ('EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE', 206) ;
60
define ('EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE', 206) ;
61
/**
61
/**
62
 * classe ezmlmAccessObject parse les fichiers XML
62
 * classe ezmlmAccessObject parse les fichiers XML
63
 * issue de ezmlm
63
 * issue de ezmlm
64
 * 
64
 * 
65
 * @category XML  
65
 * @category XML  
66
 * @package projet
66
 * @package projet
67
 * @author alex  
67
 * @author alex  
68
 */
68
 */
69
 
69
 
70
class ezmlmAccessObject extends XML_Parser_Simple {
70
class ezmlmAccessObject extends XML_Parser_Simple {
71
	
71
	
72
	/**
72
	/**
73
	 * Le domaine de la liste
73
	 * Le domaine de la liste
74
	 */
74
	 */
75
	 
75
	 
76
	var $domaine ;
76
	var $domaine ;
77
	 
77
	 
78
	 /**
78
	 /**
79
	  * Le nom de la liste
79
	  * Le nom de la liste
80
	 */
80
	 */
81
	  
81
	  
82
	var $liste ;
82
	var $liste ;
83
	  
83
	  
84
	  /**
84
	  /**
85
	  * Les actions valides
85
	  * Les actions valides
86
	  */
86
	  */
87
	   
87
	   
88
	var $actions_supportees = array ('calendrier_messages',
88
	var $actions_supportees = array ('calendrier_messages',
89
									 'message',
89
									 'message',
90
									 'derniers_messages',
90
									 'derniers_messages',
91
									 'messages_auteur',
91
									 'messages_auteur',
92
									 'messages_mois',
92
									 'messages_mois',
93
									 'messages_thread',
93
									 'messages_thread',
94
									 'supprimer',
94
									 'supprimer',
95
									 'liste_abonnes');
95
									 'liste_abonnes',
-
 
96
									 'nombre_messages');
96
	   
97
	   
97
	/**
98
	/**
98
	* l'action selectionnee
99
	* l'action selectionnee
99
	*/
100
	*/
100
	var $action ;
101
	var $action ;
101
	
102
	
102
	/**
103
	/**
103
	 * La langue 'fr-FR'
104
	 * La langue 'fr-FR'
104
	 */
105
	 */
105
	 var $langue ;
106
	 var $langue ;
106
	
107
	
107
	/**
108
	/**
108
	 * L'url de base
109
	 * L'url de base
109
	 */
110
	 */
110
	 var $url ;
111
	 var $url ;
111
	
112
	
112
	/**
113
	/**
113
	 * L'identifiant du repertoire
114
	 * L'identifiant du repertoire
114
	 */ 
115
	 */ 
115
	var $identifiant_repertoire ;
116
	var $identifiant_repertoire ;
116
	
117
	
117
	/**
118
	/**
118
	 * Identifiant message
119
	 * Identifiant message
119
	 */
120
	 */
120
	
121
	
121
	var $identifiant_message;
122
	var $identifiant_message;
122
 
123
 
123
	/**
124
	/**
124
	 * L'identifiant du repertoire
125
	 * L'identifiant du repertoire
125
	 */ 
126
	 */ 
126
	var $_numeroRepertoireSuivant ;
127
	var $_numeroRepertoireSuivant ;
127
	
128
	
128
	/**
129
	/**
129
	 * L'identifiant du repertoire
130
	 * L'identifiant du repertoire
130
	 */ 
131
	 */ 
131
	var $hash_auteur ;
132
	var $hash_auteur ;
132
	
133
	
133
	/**
134
	/**
134
	 * Le mois a afficher
135
	 * Le mois a afficher
135
	 */ 
136
	 */ 
136
	var $mois ;
137
	var $mois ;
137
	
138
	
138
	var $_numeraRepertoirePrecedent;
139
	var $_numeraRepertoirePrecedent;
139
	
140
	
140
	/**
141
	/**
141
	 * Identifiant message
142
	 * Identifiant message
142
	 */
143
	 */
143
	
144
	
144
	var $_numeroFichierSuivant;
145
	var $_numeroFichierSuivant;
145
	
146
	
146
	var $_numeroFichierPrecedent;
147
	var $_numeroFichierPrecedent;
147
	
148
	
148
	var $chemin_fichier_xml;
149
	var $chemin_fichier_xml;
149
	
150
	
150
	/**
151
	/**
151
	 * Creation de l'objet d'acces
152
	 * Creation de l'objet d'acces
152
	 * 
153
	 * 
153
	 */
154
	 */
154
	
155
	
155
	function ezmlmAccessObject ($action, $domaine, $liste, $langue = 'fr', $url = '') {
156
	function ezmlmAccessObject ($action, $domaine, $liste, $langue = 'fr', $url = '') {
156
		$this->XML_Parser_Simple(null, 'func') ;
157
		$this->XML_Parser_Simple(null, 'func') ;
157
		$this->action = $action ;
158
		$this->action = $action ;
158
		$this->domaine = $domaine ;
159
		$this->domaine = $domaine ;
159
		$this->liste = $liste ;
160
		$this->liste = $liste ;
160
		$this->langue = $langue ;
161
		$this->langue = $langue ;
161
		$this->url = $url ;
162
		$this->url = $url ;
162
	}
163
	}
163
	
164
	
164
	/**
165
	/**
165
	 * Gestion des balises
166
	 * Gestion des balises
166
	 * 
167
	 * 
167
	 * Cette méthode spàcifie les balises reconnus par ezmlmAccessObject
168
	 * Cette methode specifie les balises reconnus par ezmlmAccessObject
168
	 * Elle remplace la méthode handleElement de XML_Parser_Simple
169
	 * Elle remplace la methode handleElement de XML_Parser_Simple
169
	 * 
170
	 * 
170
	 * @access public
171
	 * @access public
171
	 * @param string nom de l'élément (Voir la doc de PHP)
172
	 * @param string nom de l'element (Voir la doc de PHP)
172
	 * @param array attributes
173
	 * @param array attributes
173
	 * @param 
174
	 * @param 
174
	 * @link http://fr.php.net/manual/fr/ref.xml.php manuel
175
	 * @link http://fr.php.net/manual/fr/ref.xml.php manuel
175
	 */
176
	 */
176
	
177
	
177
	function handleElement_ezmlm_message ($name, $attribs, $data) {
178
	function handleElement_ezmlm_message ($name, $attribs, $data) {
178
		echo $data ;		
179
		echo $data ;		
179
	}
180
	}
180
	
181
	
181
	function handleElement_message_suivant ($name, $attribs, $data) {
182
	function handleElement_message_suivant ($name, $attribs, $data) {
182
		$this->_numeroRepertoireSuivant = $attribs['NUMERO_REPERTOIRE'] ;
183
		$this->_numeroRepertoireSuivant = $attribs['NUMERO_REPERTOIRE'] ;
183
		$this->_numeroFichierSuivant = $attribs['NUMERO'] ;
184
		$this->_numeroFichierSuivant = $attribs['NUMERO'] ;
184
	}
185
	}
185
	
186
	
186
	function handleElement_message_precedent ($name, $attribs, $data) {
187
	function handleElement_message_precedent ($name, $attribs, $data) {
187
		$this->_numeroRepertoirePrecedent = $attribs['NUMERO_REPERTOIRE'] ;
188
		$this->_numeroRepertoirePrecedent = $attribs['NUMERO_REPERTOIRE'] ;
188
		$this->_numeroFichierPrecedent = $attribs['NUMERO'] ;
189
		$this->_numeroFichierPrecedent = $attribs['NUMERO'] ;
189
	}
190
	}
190
	function handleElement_ezmlm_calendrier_messages ($name, $attribs, $data) { echo $data ; }
191
	function handleElement_ezmlm_calendrier_messages ($name, $attribs, $data) { echo $data ; }
191
	
192
	
192
	function handleElement_ezmlm_derniers_messages ($name, $attribs, $data) { echo $data ; }
193
	function handleElement_ezmlm_derniers_messages ($name, $attribs, $data) { echo $data ; }
193
	
194
	
194
	function handleElement_ezmlm_messages_auteur ($name, $attribs, $data) { echo $data ; }
195
	function handleElement_ezmlm_messages_auteur ($name, $attribs, $data) { echo $data ; }
195
	
196
	
196
	function handleElement_ezmlm_messages_mois ($name, $attribs, $data) { echo $data ; }
197
	function handleElement_ezmlm_messages_mois ($name, $attribs, $data) { echo $data ; }
197
	
198
	
198
	function handleElement_ezmlm_messages_thread ($name, $attribs, $data) { echo $data ; }
199
	function handleElement_ezmlm_messages_thread ($name, $attribs, $data) { echo $data ; }
199
	
200
	
200
	function handleElement_ezmlm_liste_abonnes ($name, $attribs, $data) { echo $data ; }
201
	function handleElement_ezmlm_liste_abonnes ($name, $attribs, $data) { echo $data ; }
-
 
202
	
-
 
203
	function handleElement_ezmlm_nombre_messages ($name, $attribs, $data) { echo $data ; }
201
	/**
204
	/**
202
	 * Choix de l'action
205
	 * Choix de l'action
203
	 * 
206
	 * 
204
	 * Liste des actions :
207
	 * Liste des actions :
205
	 * 'calendrier_messages'
208
	 * 'calendrier_messages'
206
	 * 
209
	 * 
207
	 * @access public
210
	 * @access public
208
	 * @param string	une action qui doit etre supporté
211
	 * @param string	une action qui doit etre supporté
209
	 */
212
	 */
210
	
213
	
211
	function setAction($action) {
214
	function setAction($action) {
212
		// verification de l'action 
215
		// verification de l'action 
213
		if (!in_array($action, $this->actions_supportees)) {
216
		if (!in_array($action, $this->actions_supportees)) {
214
			return raiseError(EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE) ;	
217
			return raiseError(EZMLM_ACCESS_OBJECT_ACTION_NON_SUPPORTEE) ;	
215
		}
218
		}
216
		$this->action = $action ;
219
		$this->action = $action ;
217
		
220
		
218
		// Libere les ressources (XML_Parser::free)
221
		// Libere les ressources (XML_Parser::free)
219
		$this->free();
222
		$this->free();
220
		
223
		
221
		// On vide l url
224
		// On vide l url
222
		//$this->url = '';
225
		//$this->url = '';
223
		$this->chemin_fichier_xml = '';
226
		$this->chemin_fichier_xml = '';
224
		// Charge la nouvelle action
227
		// Charge la nouvelle action
225
		$this->load() ;
228
		$this->load() ;
226
	}
229
	}
227
	
230
	
228
	/**
231
	/**
229
	 * Charge une action
232
	 * Charge une action
230
	 * 
233
	 * 
231
	 * cad affecte un fichier xml au parser
234
	 * cad affecte un fichier xml au parser
232
	 * 
235
	 * 
233
	 * @access public
236
	 * @access public
234
	 */
237
	 */
235
	function load() {
238
	function load() {
236
		$this->chemin_fichier_xml = PROJET_SERVEUR_VPOPMAIL.'/'.$this->action.'.php?domaine='.
239
		$this->chemin_fichier_xml = PROJET_SERVEUR_VPOPMAIL.'/'.$this->action.'.php?domaine='.
237
                         $this->domaine.'&liste='.$this->liste.'&langue='.
240
                         $this->domaine.'&liste='.$this->liste.'&langue='.
238
                         $this->langue ;
241
                         $this->langue ;
239
		if ($this->url != '') $this->chemin_fichier_xml.= '&url='.urlencode($this->url) ; 
242
		if ($this->url != '') $this->chemin_fichier_xml.= '&url='.urlencode($this->url) ; 
240
		if (isset ($this->identifiant_repertoire)) 
243
		if (isset ($this->identifiant_repertoire)) 
241
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_repertoire ;
244
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_repertoire ;
242
		if (isset ($this->identifiant_message)) 
245
		if (isset ($this->identifiant_message)) 
243
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_message ;
246
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->identifiant_message ;
244
		if (isset ($this->hash_auteur)) 
247
		if (isset ($this->hash_auteur)) 
245
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->hash_auteur ;
248
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->hash_auteur ;
246
		if (isset ($this->mois)) 
249
		if (isset ($this->mois)) 
247
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->mois ;
250
			$this->chemin_fichier_xml .= '&actionargs[]='.$this->mois ;
248
		
251
		
249
		$this->setInputFile($this->chemin_fichier_xml) ;
252
		$this->setInputFile($this->chemin_fichier_xml) ;
250
	}
253
	}
251
	
254
	
252
	/**
255
	/**
253
	 * Precise un message a extraire
256
	 * Precise un message a extraire
254
	 * 
257
	 * 
255
	 * On indique le numero de repertoire ezmlm et le numero du message
258
	 * On indique le numero de repertoire ezmlm et le numero du message
256
	 * @param	integer	le numero du repertoire
259
	 * @param	integer	le numero du repertoire
257
	 * @param 	integer le numero du message
260
	 * @param 	integer le numero du message
258
	 * 
261
	 * 
259
	 */
262
	 */
260
	 
263
	 
261
	 function setIdMessage ($identifiant_repertoire, $identifiant_message) {
264
	 function setIdMessage ($identifiant_repertoire, $identifiant_message) {
262
	 	$this->identifiant_repertoire = $identifiant_repertoire ;
265
	 	$this->identifiant_repertoire = $identifiant_repertoire ;
263
	 	$this->identifiant_message = $identifiant_message ;	
266
	 	$this->identifiant_message = $identifiant_message ;	
264
	 }
267
	 }
265
	 
268
	 
266
	 	/**
269
	 	/**
267
	 * Precise un auteur
270
	 * Precise un auteur
268
	 * 
271
	 * 
269
	 * On indique le numero de repertoire ezmlm et le numero du message
272
	 * On indique le numero de repertoire ezmlm et le numero du message
270
	 * @param	string	le hash d'un auteur
273
	 * @param	string	le hash d'un auteur
271
	 * 
274
	 * 
272
	 */
275
	 */
273
	 
276
	 
274
	 function setHashAuteur ($hash_auteur) {
277
	 function setHashAuteur ($hash_auteur) {
275
	 	$this->hash_auteur = $hash_auteur;	
278
	 	$this->hash_auteur = $hash_auteur;	
276
	 }
279
	 }
277
	 /**
280
	 /**
278
	 * Precise un mois
281
	 * Precise un mois
279
	 * 
282
	 * 
280
	 * On indique le numero de repertoire ezmlm et le numéro du message
283
	 * On indique le numero de repertoire ezmlm et le numéro du message
281
	 * @param	string	le hash d'un auteur
284
	 * @param	string	le hash d'un auteur
282
	 * 
285
	 * 
283
	 */
286
	 */
284
	 
287
	 
285
	 function setMois ($mois) {
288
	 function setMois ($mois) {
286
	 	$this->mois = $mois;	
289
	 	$this->mois = $mois;	
287
	 }
290
	 }
288
	 
291
	 
289
	 /**
292
	 /**
290
	  * Renvoi le numero du repertoire suivant
293
	  * Renvoi le numero du repertoire suivant
291
	  * 
294
	  * 
292
	  * 
295
	  * 
293
	 */
296
	 */
294
	 function getNumeroRepertoireSuivant() { return $this->_numeroRepertoireSuivant; } 
297
	 function getNumeroRepertoireSuivant() { return $this->_numeroRepertoireSuivant; } 
295
	 
298
	 
296
	 function getNumeroFichierSuivant () { return $this->_numeroFichierSuivant ; }
299
	 function getNumeroFichierSuivant () { return $this->_numeroFichierSuivant ; }
297
	 
300
	 
298
	 function getNumeroRepertoirePrecedent() { return $this->_numeroRepertoirePrecedent; }
301
	 function getNumeroRepertoirePrecedent() { return $this->_numeroRepertoirePrecedent; }
299
	 
302
	 
300
	 function getNumeroFichierPrecedent () { return $this->_numeroFichierPrecedent ; }
303
	 function getNumeroFichierPrecedent () { return $this->_numeroFichierPrecedent ; }
-
 
304
	 
-
 
305
	 function getNumeroMessage () { return $this->_numeroMessage ; }
-
 
306
	 
-
 
307
	 function getNombreTotalMessage () { return $this->_nombreTotalMessage ; }
301
	 
308
	 
302
	 function parse()
309
	 function parse()
303
    {
310
    {
304
  		if (substr(phpversion(), 0, 1) == '5') {
311
  		if (substr(phpversion(), 0, 1) == '5') {
305
  			//try {
312
  			try {
306
			    $xml = new SimpleXMLElement($this->chemin_fichier_xml, null, true);
313
			    $xml = new SimpleXMLElement($this->chemin_fichier_xml, null, true);
307
			    switch ($this->action) {
314
			    switch ($this->action) {
308
  				case 'calendrier_messages' :echo utf8_decode($xml); 
315
  				case 'calendrier_messages' :echo utf8_decode($xml); 
309
	  				echo utf8_decode($xml->ezmlm_calendrier_messages);
316
	  				echo utf8_decode($xml->ezmlm_calendrier_messages);
310
	  				break;
317
	  				break;
311
	  				case 'message':
318
	  				case 'message':
312
	  				echo utf8_decode ($xml);
319
	  				echo utf8_decode ($xml);
313
	  				$this->_numeroRepertoirePrecedent = $xml->message_precedent['numero_repertoire'];
320
	  				$this->_numeroRepertoirePrecedent = $xml->message_precedent['numero_repertoire'];
314
	  				$this->_numeroRepertoireSuivant = $xml->message_suivant['numero_repertoire'];
321
	  				$this->_numeroRepertoireSuivant = $xml->message_suivant['numero_repertoire'];
315
	  				$this->_numeroFichierSuivant = $xml->message_suivant['numero'];
322
	  				$this->_numeroFichierSuivant = $xml->message_suivant['numero'];
316
	  				$this->_numeroFichierPrecedent = $xml->message_precedent['numero'];
323
	  				$this->_numeroFichierPrecedent = $xml->message_precedent['numero'];
-
 
324
	  				$this->_numeroMessage = $xml->numero;
-
 
325
	  				$this->_nombreTotalMessage = $xml->numero['total_message'];
-
 
326
  				break;
-
 
327
  					case 'nombre_messages':
-
 
328
  					
-
 
329
  					echo $xml[0];
-
 
330
  					
-
 
331
  				break;
-
 
332
  					case 'liste_abonnes':
-
 
333
  					return $xml;
317
  				break;
334
  				break;
318
  				default :
335
  				default :
319
  					echo utf8_decode($xml);
336
  					echo utf8_decode($xml);
-
 
337
  					
320
  				}
338
  				}
321
			    $error = 'Erreur dans l\'acc&egrave;s au fichier:<br />'.$this->chemin_fichier_xml.'<br />';
339
			    $error = 'Erreur dans l\'acc&egrave;s au fichier:<br />'.$this->chemin_fichier_xml.'<br />';
322
			    $error = '';
340
			    $error = '';
323
			 //   throw new Exception($error);
341
			   throw new Exception($error);
324
			//}
342
			}
325
			//catch (Exception $e) {
343
			catch (Exception $e) {
326
			//    echo $e->getMessage(). "<br />";
344
			    echo $e->getMessage().'<br />';
-
 
345
			    //echo $this->chemin_fichier_xml;
327
			//}
346
			}
328
  			
347
  			
329
  		} else {
348
  		} else {
330
  			return parent::parse();
349
  			return parent::parse();
331
  		}
350
  		}
332
    }
351
    }
333
}
352
}
334
 
353
 
335
?>
354
?>