Subversion Repositories Applications.wikini

Rev

Rev 31 | Rev 35 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
30 aurelien 1
<?php
2
// declare(encoding='UTF-8');
3
/**
31 aurelien 4
 * Web service de consultation d'un page wiki
30 aurelien 5
 *
6
 * @category	php 5.2
31 aurelien 7
 * @package		wapi
8
 * @author		Aurélien Peronnet < aurelien@tela-botanica.org>
9
 * @author		Jean-Pascal Milcent < jpm@tela-botanica.org>
30 aurelien 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
12
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
13
 * @version		$Id$
14
 */
15
class Pages extends Service {
16
 
31 aurelien 17
	private $wiki = null;
30 aurelien 18
	private $pageNom = null;
31 aurelien 19
	private $section = null;
30 aurelien 20
 
31 aurelien 21
	private $retour = 'txt';
22
	private $formats_retour = array('txt','html');
33 aurelien 23
	private $format_texte;
31 aurelien 24
 
33 aurelien 25
	const MIME_JSON = 'application/json';
26
	const MIME_HTML = 'text/html';
27
	const MIME_TEXT = 'text/plain';
28
 
30 aurelien 29
	public function consulter($ressources, $parametres) {
33 aurelien 30
 
31
		try {
32
			$this->definirValeurParDefautDesParametres();
33
			$this->verifierParametres($parametres);
34
			$this->analyserParametres($ressources, $parametres);
35
 
36
			$page = $this->consulterPage($this->pageNom);
37
			$retour = $this->formaterRetour($page);
38
 
39
			$this->envoyerContenuJson($retour);
40
		} catch (Exception $e) {
41
			$this->envoyerErreur($e);
30 aurelien 42
		}
43
	}
44
 
31 aurelien 45
	private function definirValeurParDefautDesParametres() {
46
		if (isset($this->parametres['txt_format']) == false) {
47
			$this->parametres['txt_format'] = 'txt';
48
		}
49
	}
50
 
30 aurelien 51
	private function verifierParametres($parametres) {
33 aurelien 52
		$erreurs = array();
53
 
31 aurelien 54
		if (isset($parametres['txt_format'])) {
55
			if(!in_array($parametres['txt_format'], $this->formats_retour)) {
56
				$message = "La valeur du paramètre 'txt.format' peut seulement prendre les valeurs : txt et html.";
33 aurelien 57
				$erreurs[] = $message;
30 aurelien 58
			}
59
		}
31 aurelien 60
 
33 aurelien 61
		if(isset($parametres['txt_section_position']) && !is_numeric($parametres['txt_section_position'])) {
62
			$message = "La valeur du paramètre 'txt.section.position' peut seulement prendre des valeurs numeriques";
63
			$erreurs[] = $message;
31 aurelien 64
		}
65
 
33 aurelien 66
		if(isset($parametres['txt_section_titre']) && trim($parametres['txt_section_titre']) == '') {
67
			$message = "La valeur du paramètre 'txt.section.titre' ne peut pas être vide si celui-ci est présent";
68
			$erreurs[] = $message;
69
		}
70
 
71
		if (count($erreurs) > 0) {
72
			$message = implode('<br />', $erreurs);
73
			$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
74
			throw new Exception($message, $code);
75
		}
76
	}
77
 
78
	private function analyserParametres($ressources, $parametres) {
79
		$this->pageNom = $ressources[0];
31 aurelien 80
		if(isset($parametres['txt_section_titre'])) {
81
			$this->section = $parametres['txt_section_titre'];
82
		}
33 aurelien 83
		if(isset($parametres['txt_section_position'])) {
84
			$this->section = $parametres['txt_section_position'];
85
		}
86
		if (isset($parametres['txt_format'])) {
87
			$this->retour = $parametres['txt_format'];
88
		}
30 aurelien 89
	}
31 aurelien 90
 
91
	private function consulterPage($page) {
92
		$this->wiki = Registre::get('wikiApi');
93
		$this->wiki->setPageCourante($this->pageNom);
94
		$page = $this->wiki->LoadPage($page);
95
 
96
		// attention les wikis sont en ISO !
97
		if(Config::get('encodage_appli') != Config::get('encodage_wiki')) {
98
			$page["body"] = mb_convert_encoding($page['body'],Config::get('encodage_appli'),Config::get('encodage_wiki'));
99
		}
100
 
101
		if($this->section != null) {
102
			$page["body"] = $this->découperPageSection($page["body"], $this->section);
103
		}
104
 
105
		return $page;
106
	}
107
 
108
	private function découperPageSection($contenu_page, $section) {
109
 
110
		$section_retour = '';
111
 
112
		if(is_numeric($section)) {
113
			$section_retour =  $this->getSectionParNumero($contenu_page, $section);
114
		} else {
115
			$section_retour =  $this->getSectionParTitre($contenu_page, $section);
116
		}
117
 
118
		return $section_retour;
119
	}
120
 
121
	public function getSectionParNumero($page, $num) {
122
		preg_match_all('/(=[=]+[ ]*)(.[.^=]*)+[ ]*=[=]+[.]*/i', $page, $sections, PREG_OFFSET_CAPTURE);
123
		$sectionTxt = '';
124
		$debut_section = 0;
125
		$lg_page = strlen($page);
126
		$fin_section = $lg_page;
127
 
128
		if($num <= count($sections[1]) && $num > 0) {
129
 
130
			$debut_section = $sections[1][$num - 1][1];
131
			$separateur = trim($sections[1][$num - 1][0]);
132
			$separateur_trouve = false;
133
 
134
			for($i = $num; $i < count($sections[1]); $i++) {
135
				$fin_section = $sections[1][$i][1];
136
				if($separateur == trim($sections[1][$i][0])) {
137
					$separateur_trouve = true;
138
					break;
139
				}
140
			}
141
 
142
			$fin_section = $separateur_trouve ? $fin_section : $lg_page;
143
			$sectionTxt = substr($page, $debut_section, $fin_section - $debut_section);
144
		} else {
145
			$sectionTxt = '';
146
		}
147
 
148
		return $sectionTxt;
149
	}
150
 
151
	public function getSectionParTitre($page, $titre) {
152
		$section = '';
153
		$reg_exp = '/((=[=]+)[ ]*'.preg_quote(trim($titre), '/').'[ ]*=[=]+)[.]*/i';
154
		$match = preg_split($reg_exp, $page, 2, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);
155
 
156
		if(count($match) > 3) {
157
			$section = explode(trim($match[2]), $match[3], 2);
158
			$section = $match[1].' '.$section[0];
159
		} elseif(count($match) == 2) {
160
			$section = explode(trim($match[1]), $match[2], 2);
161
			$section = $match[0].' '.$section[0];
162
		} else {
163
			$section = "";
164
		}
165
 
166
		return $section;
167
	}
168
 
169
	private function formaterRetour($page) {
170
 
33 aurelien 171
		$mime = null;
172
		$texte = '';
173
 
31 aurelien 174
		switch($this->retour) {
175
			case 'html':
33 aurelien 176
				$texte = $this->wiki->Format($page["body"], "wakka");
177
				$mime = self::MIME_HTML;
31 aurelien 178
				break;
179
			default:
33 aurelien 180
				$texte = $page["body"];
181
				$mime = self::MIME_TEXT;
31 aurelien 182
		}
33 aurelien 183
 
184
		$retour = array('id' => $this->pageNom,
185
				'titre' => $this->pageNom,
186
				'mime' => $mime,
187
				'texte' => $texte,
188
				'href' => '');
189
 
31 aurelien 190
		return $retour;
191
	}
30 aurelien 192
}
193
?>