Subversion Repositories Applications.wikini

Rev

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

Rev 38 Rev 39
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Web service de consultation d'un page wiki
4
 * Web service de consultation d'un page wiki
5
 *
5
 *
6
 * @category	php 5.2
6
 * @category	php 5.2
7
 * @package		wapi
7
 * @package		wapi
8
 * @author		Aurélien Peronnet < aurelien@tela-botanica.org>
8
 * @author		Aurélien Peronnet < aurelien@tela-botanica.org>
9
 * @author		Jean-Pascal Milcent < jpm@tela-botanica.org>
9
 * @author		Jean-Pascal Milcent < jpm@tela-botanica.org>
10
 * @copyright	Copyright (c) 2011, Tela Botanica (accueil@tela-botanica.org)
10
 * @copyright	Copyright (c) 2011, Tela Botanica (accueil@tela-botanica.org)
11
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
11
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
12
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
12
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
13
 * @version		$Id$
13
 * @version		$Id$
14
 */
14
 */
15
class Pages extends Service {
15
class Pages extends Service {
16
	
16
	
17
	private $wiki = null;
17
	private $wiki = null;
18
	private $pageNom = null;
18
	private $pageNom = null;
19
	private $section = null;
19
	private $section = null;
20
	
20
	
21
	private $retour = 'txt';
21
	private $retour = 'txt';
22
	private $formats_retour = array('text/plain','text/html');
22
	private $formats_retour = array('text/plain','text/html');
23
	private $format_texte;
23
	private $format_texte;
24
	
24
	
25
	const MIME_JSON = 'application/json';
25
	const MIME_JSON = 'application/json';
26
	const MIME_HTML = 'text/html';
26
	const MIME_HTML = 'text/html';
27
	const MIME_TEXT = 'text/plain';
27
	const MIME_TEXT = 'text/plain';
28
	
28
	
29
	public function consulter($ressources, $parametres) {
29
	public function consulter($ressources, $parametres) {
30
		
30
		
31
		try {
31
		try {
32
			$this->definirValeurParDefautDesParametres();
32
			$this->definirValeurParDefautDesParametres();
33
			$this->verifierParametres($parametres);
33
			$this->verifierParametres($parametres);
34
			$this->analyserParametres($ressources, $parametres);
34
			$this->analyserParametres($ressources, $parametres);
35
			
35
			
36
			$page = $this->consulterPage($this->pageNom, $this->section);
36
			$page = $this->consulterPage($this->pageNom, $this->section);
37
			
37
			
38
			if ($page == null) {
38
			// on devrait normalement renvoyer une erreur 404 mais 
39
				$message = 'La page demandée n\'existe pas';
39
			// l'api de consultation d'url du framework prend mal en compte 
40
				$code = RestServeur::HTTP_CODE_RESSOURCE_INTROUVABLE;
40
			// le 404 et ne permet pas de le traiter quand on le recoit
41
				throw new Exception($message, $code);
-
 
42
			}
41
			$page['existe'] = ($page != null);
43
			$retour = $this->formaterRetour($page);
42
			$retour = $this->formaterRetour($page);
44
			
43
			
45
			$this->envoyerContenuJson($retour);
44
			$this->envoyerContenuJson($retour);
46
		} catch (Exception $e) {
45
		} catch (Exception $e) {
47
			$this->envoyerErreur($e);
46
			$this->envoyerErreur($e);
48
		}
47
		}
49
	}
48
	}
50
	
49
	
51
	private function definirValeurParDefautDesParametres() {
50
	private function definirValeurParDefautDesParametres() {
52
		if (isset($this->parametres['txt_format']) == false) {
51
		if (isset($this->parametres['txt_format']) == false) {
53
			$this->parametres['txt_format'] = 'text/plain';
52
			$this->parametres['txt_format'] = 'text/plain';
54
		}
53
		}
55
	}
54
	}
56
	
55
	
57
	private function verifierParametres($parametres) {
56
	private function verifierParametres($parametres) {
58
		$erreurs = array();
57
		$erreurs = array();
59
		
58
		
60
		if (isset($parametres['txt_format'])) {
59
		if (isset($parametres['txt_format'])) {
61
			if(!in_array($parametres['txt_format'], $this->formats_retour)) {
60
			if(!in_array($parametres['txt_format'], $this->formats_retour)) {
62
				$message = "La valeur du paramètre 'txt.format' peut seulement prendre les valeurs : text/plain et text/html.";
61
				$message = "La valeur du paramètre 'txt.format' peut seulement prendre les valeurs : text/plain et text/html.";
63
				$erreurs[] = $message;
62
				$erreurs[] = $message;
64
			}
63
			}
65
		}
64
		}
66
		
65
		
67
		if (isset($parametres['txt_section_position']) && !is_numeric($parametres['txt_section_position'])) {
66
		if (isset($parametres['txt_section_position']) && !is_numeric($parametres['txt_section_position'])) {
68
			$message = "La valeur du paramètre 'txt.section.position' peut seulement prendre des valeurs numeriques";
67
			$message = "La valeur du paramètre 'txt.section.position' peut seulement prendre des valeurs numeriques";
69
			$erreurs[] = $message;
68
			$erreurs[] = $message;
70
		}
69
		}
71
		
70
		
72
		if (isset($parametres['txt_section_titre']) && trim($parametres['txt_section_titre']) == '') {
71
		if (isset($parametres['txt_section_titre']) && trim($parametres['txt_section_titre']) == '') {
73
			$message = "La valeur du paramètre 'txt.section.titre' ne peut pas être vide si celui-ci est présent";
72
			$message = "La valeur du paramètre 'txt.section.titre' ne peut pas être vide si celui-ci est présent";
74
			$erreurs[] = $message;
73
			$erreurs[] = $message;
75
		}
74
		}
76
				
75
				
77
		if (count($erreurs) > 0) {
76
		if (count($erreurs) > 0) {
78
			$message = implode('<br />', $erreurs);
77
			$message = implode('<br />', $erreurs);
79
			$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
78
			$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
80
			throw new Exception($message, $code);
79
			throw new Exception($message, $code);
81
		}
80
		}
82
	}
81
	}
83
	
82
	
84
	private function analyserParametres($ressources, $parametres) {	
83
	private function analyserParametres($ressources, $parametres) {	
85
		$this->pageNom = $ressources[0];
84
		$this->pageNom = $ressources[0];
86
		if (isset($parametres['txt_section_titre'])) {
85
		if (isset($parametres['txt_section_titre'])) {
87
			$this->section = $parametres['txt_section_titre'];
86
			$this->section = $parametres['txt_section_titre'];
88
		}
87
		}
89
		if (isset($parametres['txt_section_position'])) {
88
		if (isset($parametres['txt_section_position'])) {
90
			$this->section = $parametres['txt_section_position'];
89
			$this->section = $parametres['txt_section_position'];
91
		}
90
		}
92
		if (isset($parametres['txt_format'])) {
91
		if (isset($parametres['txt_format'])) {
93
			$this->retour = $parametres['txt_format'];
92
			$this->retour = $parametres['txt_format'];
94
		}
93
		}
95
	}
94
	}
96
	
95
	
97
	private function consulterPage($page, $section = null) {
96
	private function consulterPage($page, $section = null) {
98
		
97
		
99
		$this->wiki = Registre::get('wikiApi');
98
		$this->wiki = Registre::get('wikiApi');
100
		$this->wiki->setPageCourante($this->pageNom);
99
		$this->wiki->setPageCourante($this->pageNom);
101
		$page = $this->wiki->LoadPage($page);
100
		$page = $this->wiki->LoadPage($page);
102
				
101
				
103
		if ($page != null) {
102
		if ($page != null) {
104
			// attention les wikis sont souvent en ISO !
103
			// attention les wikis sont souvent en ISO !
105
			$page["body"] = $this->convertirTexteWikiVersEncodageAppli($page['body']);
104
			$page["body"] = $this->convertirTexteWikiVersEncodageAppli($page['body']);
106
			if($section != null) {
105
			if($section != null) {
107
				$page["body"] = $this->decouperPageSection($page["body"], $section);
106
				$page["body"] = $this->decouperPageSection($page["body"], $section);
108
			}
107
			}
109
		}
108
		}
110
	
109
	
111
		return $page;
110
		return $page;
112
	}
111
	}
113
	
112
	
114
	private function decouperPageSection($contenu_page, $section) {
113
	private function decouperPageSection($contenu_page, $section) {
115
	
-
 
116
		$section_retour = '';
114
		$section_retour = '';
117
		if (is_numeric($section)) {
115
		if (is_numeric($section)) {
118
			$section_retour =  $this->getSectionParNumero($contenu_page, $section);
116
			$section_retour =  $this->getSectionParNumero($contenu_page, $section);
119
		} else {
117
		} else {
120
			$section_retour =  $this->getSectionParTitre($contenu_page, $section);
118
			$section_retour =  $this->getSectionParTitre($contenu_page, $section, false);
121
		}
119
		}
122
		return $section_retour;
120
		return $section_retour;
123
	}
121
	}
124
	
122
	
125
	public function getSectionParNumero($page, $num) {
123
	public function getSectionParNumero($page, $num) {
126
		preg_match_all('/(=[=]+[ ]*)(.[.^=]*)+[ ]*=[=]+[.]*/i', $page, $sections, PREG_OFFSET_CAPTURE);
124
		preg_match_all('/(=[=]+[ ]*)(.[.^=]*)+[ ]*=[=]+[.]*/i', $page, $sections, PREG_OFFSET_CAPTURE);
127
		$sectionTxt = '';
125
		$sectionTxt = '';
128
		$debut_section = 0;
126
		$debut_section = 0;
129
		$lg_page = strlen($page);
127
		$lg_page = strlen($page);
130
		$fin_section = $lg_page;
128
		$fin_section = $lg_page;
131
		
129
		
132
		if ($num <= count($sections[1]) && $num > 0) {	
130
		if ($num <= count($sections[1]) && $num > 0) {	
133
						
131
						
134
			$debut_section = $sections[1][$num - 1][1];
132
			$debut_section = $sections[1][$num - 1][1];
135
			$separateur = trim($sections[1][$num - 1][0]);
133
			$separateur = trim($sections[1][$num - 1][0]);
136
			$separateur_trouve = false;
134
			$separateur_trouve = false;
137
						
135
						
138
			for ($i = $num; $i < count($sections[1]); $i++) {
136
			for ($i = $num; $i < count($sections[1]); $i++) {
139
				$fin_section = $sections[1][$i][1];
137
				$fin_section = $sections[1][$i][1];
140
				if($separateur == trim($sections[1][$i][0])) {
138
				if($separateur == trim($sections[1][$i][0])) {
141
					$separateur_trouve = true;
139
					$separateur_trouve = true;
142
					break;
140
					break;
143
				}
141
				}
144
			}
142
			}
145
			
143
			
146
			$fin_section = $separateur_trouve ? $fin_section : $lg_page;
144
			$fin_section = $separateur_trouve ? $fin_section : $lg_page;
147
			$sectionTxt = substr($page, $debut_section, $fin_section - $debut_section);
145
			$sectionTxt = substr($page, $debut_section, $fin_section - $debut_section);
148
			
146
			
149
		} else {
147
		} else {
150
			$sectionTxt = '';
148
			$sectionTxt = '';
151
		}
149
		}
152
 
150
 
153
		return $sectionTxt;
151
		return $sectionTxt;
154
	}
152
	}
155
	
153
	
156
	public function getSectionParTitre($page, $titre) {
154
	public function getSectionParTitre($page, $titre, $inclure_titre = false) {
157
		$section = '';
155
		$section = '';
158
		$reg_exp = '/((=[=]+)[ ]*'.preg_quote(trim($titre), '/').'[ ]*=[=]+)[.]*/i';
156
		$reg_exp = '/((=[=]+)[ ]*'.preg_quote(trim($titre), '/').'[ ]*=[=]+)[.]*/i';
159
		$match = preg_split($reg_exp, $page, 2, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);
157
		$match = preg_split($reg_exp, $page, 2, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);
160
		if (count($match) > 3) {
158
		if (count($match) > 3) {
161
			$section = explode(trim($match[2]), $match[3], 2);
159
			$section = explode(trim($match[2]), $match[3], 2);
162
			$section = $match[1].$section[0];
160
			$section = $section[0];
-
 
161
			$section = ($inclure_titre) ? $match[1].$section : $section;
163
		} elseif (count($match) == 3) {
162
		} elseif (count($match) == 3) {
164
			$section = explode(trim($match[1]), $match[2], 2);
163
			$section = explode(trim($match[1]), $match[2], 2);
165
			$section = $match[0].$section[0];
164
			$section = $section[0];
-
 
165
			$section = ($inclure_titre) ? $match[0].$section : $section;
166
		} else {
166
		} else {
167
			$section = "";
167
			$section = "";
168
		}
168
		}
169
		
169
		
170
		return $section;
170
		return $section;
171
	}
171
	}
172
	
172
	
173
	private function formaterRetour($page) {
173
	private function formaterRetour($page) {
174
 
174
 
175
		$mime = null;
175
		$mime = null;
176
		$texte = '';
176
		$texte = '';
177
		
177
		
178
		switch ($this->retour) {
178
		switch ($this->retour) {
179
			case self::MIME_HTML:
179
			case self::MIME_HTML:
180
				$texte = $this->wiki->Format($page["body"], "wakka");
180
				$texte = $this->wiki->Format($page["body"], "wakka");
181
				$mime = self::MIME_HTML;
181
				$mime = self::MIME_HTML;
182
				break;
182
				break;
183
			default:
183
			default:
184
				$texte = $page["body"];
184
				$texte = $page["body"];
185
				$mime = self::MIME_TEXT;
185
				$mime = self::MIME_TEXT;
186
		}
186
		}
187
		
187
		
188
		$url = $this->wiki->Href("", $this->pageNom);
188
		$url = $this->wiki->Href("", $this->pageNom);
189
		
189
		
190
		$retour = array('id' => $this->pageNom,
190
		$retour = array('id' => $this->pageNom,
191
				'titre' => $this->pageNom,
191
				'titre' => $this->pageNom,
192
				'mime' => $mime,
192
				'mime' => $mime,
193
				'texte' => $texte,
193
				'texte' => $texte,
194
				'href' => $url);
194
				'href' => $url,
-
 
195
				'existe' => $page['existe']);
195
		
196
		
196
		return $retour;
197
		return $retour;
197
	}
198
	}
198
	
199
	
199
	public function ajouter($ressources, $requeteDonnees) {
200
	public function ajouter($ressources, $requeteDonnees) {
200
		return $this->modifier($ressources, $requeteDonnees);
201
		return $this->modifier($ressources, $requeteDonnees);
201
	}
202
	}
202
	
203
	
203
	public function modifier($ressources, $requeteDonnees) {
204
	public function modifier($ressources, $requeteDonnees) {
204
 
205
 
205
		$requeteDonnees['pageTag'] = $ressources[0];
206
		$requeteDonnees['pageTag'] = $ressources[0];
206
		$this->verifierParametresEcriture($requeteDonnees);
207
		$this->verifierParametresEcriture($requeteDonnees);
207
		$this->analyserParametresEcriture($requeteDonnees);
208
		$this->analyserParametresEcriture($requeteDonnees);
208
		$this->wiki = Registre::get('wikiApi');
209
		$this->wiki = Registre::get('wikiApi');
209
		$this->wiki->setPageCourante($this->pageNom);
210
		$this->wiki->setPageCourante($this->pageNom);
210
		
211
		
211
		$texte = $requeteDonnees['pageContenu'];
212
		$texte = $requeteDonnees['pageContenu'];
212
		$page = $this->consulterPage($this->pageNom);
213
		$page = $this->consulterPage($this->pageNom);
213
				
214
				
214
		if ($page != null) {
215
		if ($page != null) {
215
			$corps = ($this->section != null) ? $this->remplacerSection($this->section, $texte, $page['body']) : $texte;	
216
			$corps = ($this->section != null) ? $this->remplacerSection($this->section, $texte, $page['body']) : $texte;	
216
		} else {
217
		} else {
217
			$corps = $texte;
218
			$corps = $texte;
218
		}	
219
		}	
219
		
220
		
220
		$ecriture = $this->ecrirePage($this->pageNom, $corps);	
221
		$ecriture = $this->ecrirePage($this->pageNom, $corps);	
221
		
222
		
222
		if ($ecriture) {
223
		if ($ecriture) {
223
			$this->envoyerCreationEffectuee();
224
			$this->envoyerCreationEffectuee();
224
		} else {
225
		} else {
225
			$message = 'Impossible de créer ou modifier la page';
226
			$message = 'Impossible de créer ou modifier la page';
226
			$code = RestServeur::HTTP_CODE_ERREUR;
227
			$code = RestServeur::HTTP_CODE_ERREUR;
227
			throw new Exception($message, $code);
228
			throw new Exception($message, $code);
228
		}
229
		}
229
		
230
		
230
		return $ecriture;
231
		return $ecriture;
231
	}
232
	}
-
 
233
	
-
 
234
	/**
-
 
235
	 * 
-
 
236
	 * Si la section demandée existe dans la page, renvoie un tableau contenant le numéro de caractère de 
-
 
237
	 * début de la section, après son titre, ainsi que la longeur du titre
-
 
238
	 * @param string $titre de la section
-
 
239
	 * @param string $page contenu de la page wiki
-
 
240
	 * @return tableau associatif tel que décrit ici
232
	
241
	 */
-
 
242
	private function getInformationsPositionSection($titre, $page) {
-
 
243
		
-
 
244
		preg_match_all('/(=[=]+[ ]*'.preg_quote(trim($titre), '/').'[ ]*=[=]+[.]*)/i', $page, $sections, PREG_OFFSET_CAPTURE);
-
 
245
		$longueur_titre = 0;
-
 
246
		$debut_section_apres_titre = 0;
-
 
247
		
-
 
248
		if (count($sections) > 0 && is_array($sections[0]) && count($sections[0][0]) >= 2) {
-
 
249
			$longueur_titre = mb_strlen($sections[0][0][0]);
-
 
250
			$debut_section_apres_titre = $sections[0][0][1] + $longueur_titre;
-
 
251
		}
-
 
252
		
-
 
253
		// ATTENTION : début contient le numéro du caractere de début de la section, après le titre
-
 
254
		$infos = array('debut' => $debut_section_apres_titre,
-
 
255
						'longueur_titre' => $longueur_titre
233
	private function remplacerSection($titre_ou_numero_section, $section_remplacement, $corps) {
256
				);
-
 
257
		
-
 
258
		return $infos;
234
		
259
	}
235
		//TODO: empecher l'insertion de section de niveau supérieur (avec plus de =)
-
 
236
		// en les réduisant pour que le niveau de la section soit toujours inférieur à celui
260
	
237
		// de la section éditée ? voir avec le PO !	
261
	private function remplacerSection($titre_section, $section_remplacement, $corps) {
238
		
262
				
239
		//TODO: insérer un espace ou un saut de ligne à la fin du texte si celui-ci n'en contient pas 
263
		$section_remplacement = "\n".$section_remplacement."\n";
240
		// à la fin, ceci pour éviter que le formatage saute lors de l'édition du wiki
264
		$section_page_originale = $this->getSectionParTitre($corps, $titre_section, true);
-
 
265
		$infos_section = $this->getInformationsPositionSection($titre_section, $corps);
-
 
266
		$nb_caracteres_a_remplacer = mb_strlen($section_page_originale) - $infos_section['longueur_titre'];
241
		$section_page_originale = $this->decouperPageSection($corps, $titre_ou_numero_section);
267
		
242
		$contenu = str_replace($section_page_originale, $section_remplacement, $corps);
268
		$nouveau_contenu = substr_replace($corps, $section_remplacement, $infos_section['debut'], $nb_caracteres_a_remplacer);
243
			
269
			
244
		return $contenu;
270
		return $nouveau_contenu;
245
	}
271
	}
246
	
272
	
247
	private function ecrirePage($nom_page, $contenu) {
273
	private function ecrirePage($nom_page, $contenu) {
248
		
274
		
249
		$texte_encode = $this->convertirTexteAppliVersEncodageWiki($contenu);
275
		$texte_encode = $this->convertirTexteAppliVersEncodageWiki($contenu);
250
		$ecriture = $this->wiki->SavePage($nom_page, $texte_encode, "", true);
276
		$ecriture = $this->wiki->SavePage($nom_page, $texte_encode, "", true);
251
		
277
		
252
		return $ecriture;
278
		return $ecriture;
253
	}
279
	}
254
	
280
	
255
	private function analyserParametresEcriture($parametres) {
281
	private function analyserParametresEcriture($parametres) {
256
		$this->pageNom = $parametres['pageTag'];
282
		$this->pageNom = $parametres['pageTag'];
257
		$this->section = isset($parametres['pageSection']) ? $parametres['pageSection'] : null;
283
		$this->section = isset($parametres['pageSectionTitre']) ? $parametres['pageSectionTitre'] : null;
258
	}
284
	}
259
	
285
	
260
	private function verifierParametresEcriture($parametres) {
286
	private function verifierParametresEcriture($parametres) {
261
			
287
			
262
		$erreurs = array();
288
		$erreurs = array();
263
		
289
		
264
		if(!isset($parametres['pageContenu'])) {
290
		if(!isset($parametres['pageContenu'])) {
265
			$message = "Le paramètre pageContenu est obligatoire";
291
			$message = "Le paramètre pageContenu est obligatoire";
266
			$erreurs[] = $message;
292
			$erreurs[] = $message;
267
		}
293
		}
268
		
294
		
269
		if(!isset($parametres['pageTag']) || trim($parametres['pageTag']) == '') {
295
		if(!isset($parametres['pageTag']) || trim($parametres['pageTag']) == '') {
270
			$message = "Le paramètre pageTag est obligatoire";
296
			$message = "Le paramètre pageTag est obligatoire";
271
			$erreurs[] = $message;
297
			$erreurs[] = $message;
-
 
298
		}
-
 
299
		
-
 
300
		if(isset($parametres['pageSectionTitre']) && $parametres['pageSectionTitre'] == '') {
-
 
301
			$message = "Le paramètre pageSectionTitre ne doit pas être vide s'il est présent";
-
 
302
			$erreurs[] = $message;
272
		}
303
		}
273
		
304
		
274
		if (count($erreurs) > 0) {
305
		if (count($erreurs) > 0) {
275
			$message = implode('<br />', $erreurs);
306
			$message = implode('<br />', $erreurs);
276
			$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
307
			$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
277
			throw new Exception($message, $code);
308
			throw new Exception($message, $code);
278
		}
309
		}
279
	}
310
	}
280
	
311
	
281
	private function convertirTexteWikiVersEncodageAppli($texte) {
312
	private function convertirTexteWikiVersEncodageAppli($texte) {
282
		if(Config::get('encodage_appli') != Config::get('encodage_wiki')) {
313
		if(Config::get('encodage_appli') != Config::get('encodage_wiki')) {
283
			$texte = mb_convert_encoding($texte,Config::get('encodage_appli'),Config::get('encodage_wiki'));
314
			$texte = mb_convert_encoding($texte,Config::get('encodage_appli'),Config::get('encodage_wiki'));
284
		}
315
		}
285
		return $texte;
316
		return $texte;
286
	}
317
	}
287
	
318
	
288
	private function convertirTexteAppliVersEncodageWiki($texte) {
319
	private function convertirTexteAppliVersEncodageWiki($texte) {
289
		if(Config::get('encodage_appli') != Config::get('encodage_wiki')) {
320
		if(Config::get('encodage_appli') != Config::get('encodage_wiki')) {
290
			$texte = mb_convert_encoding($texte,Config::get('encodage_wiki'),Config::get('encodage_appli'));
321
			$texte = mb_convert_encoding($texte,Config::get('encodage_wiki'),Config::get('encodage_appli'));
291
		}
322
		}
292
		return $texte;
323
		return $texte;
293
	}
324
	}
294
}	
325
}	
295
?>
326
?>