Implements a dirty version of tokenAuth in XorgSession (waiting for hruid).
[platal.git] / include / wiki.inc.php
1 <?php
2 /***************************************************************************
3 * Copyright (C) 2003-2008 Polytechnique.org *
4 * http://opensource.polytechnique.org/ *
5 * *
6 * This program is free software; you can redistribute it and/or modify *
7 * it under the terms of the GNU General Public License as published by *
8 * the Free Software Foundation; either version 2 of the License, or *
9 * (at your option) any later version. *
10 * *
11 * This program is distributed in the hope that it will be useful, *
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
14 * GNU General Public License for more details. *
15 * *
16 * You should have received a copy of the GNU General Public License *
17 * along with this program; if not, write to the Free Software *
18 * Foundation, Inc., *
19 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
20 ***************************************************************************/
21
22 function wiki_pagename()
23 {
24 if (!Get::v('n')) {
25 return null;
26 }
27
28 $words = explode('/', trim(Get::v('n'), '/'));
29 if (count($words) == 2) {
30 return join('.', $words);
31 }
32
33 array_unshift($words, $words[0]);
34 $b = array_pop($words);
35 $a = array_pop($words);
36
37 pl_redirect($a.'/'.$b);
38 }
39
40 function wiki_filename($s)
41 {
42 if (@iconv('utf-8', 'utf-8', $s) == $s) {
43 return $s;
44 }
45 return utf8_encode($s);
46 }
47
48 function wiki_work_dir()
49 {
50 global $globals;
51 return $globals->spoolroot.'/spool/wiki.d';
52 }
53
54 function wiki_clear_all_cache()
55 {
56 system('rm -f '.wiki_work_dir().'/cache_*');
57 }
58
59 function wiki_perms_options() {
60 return array('public' => 'Public', 'logged' => 'Connecté',
61 'mdp' => 'Authentifié', 'admin' => 'Admin');
62 }
63
64 function wiki_get_perms($n)
65 {
66 $file = wiki_work_dir().'/'.wiki_filename(str_replace('/', '.', $n));
67 $lines = explode("\n", @file_get_contents($file));
68 foreach ($lines as $line) {
69 @list($k, $v) = explode('=', $line, 2);
70 if ($k == 'platal_perms') {
71 return explode(':', $v);
72 }
73 }
74 return array('logged', 'admin');
75 }
76
77 function wiki_putfile($f, $s)
78 {
79 $fp = fopen($f, 'w');
80 fputs($fp, $s);
81 fclose($fp);
82 }
83
84 function wiki_set_perms($n, $pr, $pw)
85 {
86 $file = wiki_work_dir().'/'.wiki_filename(str_replace('/', '.', $n));
87 if (!file_exists($file)) {
88 return false;
89 }
90
91 $p = $pr . ':' . $pw;
92
93 $lines = explode("\n", file_get_contents($file));
94 foreach ($lines as $i => $line) {
95 list($k, $v) = explode('=', $line, 2);
96 if ($k == 'platal_perms') {
97 $lines[$i] = 'platal_perms='.$p;
98 wiki_putfile($file, join("\n", $lines));
99 return true;
100 }
101 }
102
103 array_splice($lines, 1, 0, array('platal_perms='.$p));
104 wiki_putfile($file, join("\n", $lines));
105 return true;
106 }
107
108 function wiki_may_have_perms($perm) {
109 switch ($perm) {
110 case 'public': return true;
111 case 'logged': return S::logged();
112 case 'mdp': return S::logged();
113 default: return S::has_perms();
114 }
115 }
116
117 function wiki_apply_feed_perms($perm)
118 {
119 if ($perm == 'public') {
120 return;
121 }
122
123 require_once 'rss.inc.php';
124 $uid = init_rss(null, Env::v('user'), Env::v('hash'));
125 if (is_null($uid)) {
126 exit;
127 }
128 if ($perm == 'logged' || S::has_perms()) {
129 return;
130 }
131 exit;
132 }
133
134 function wiki_apply_perms($perm)
135 {
136 global $platal, $globals;
137 $page =& Platal::page();
138
139 switch ($perm) {
140 case 'public':
141 return;
142
143 case 'logged':
144 if (!call_user_func(array($globals->session, 'doAuthCookie'))) {
145 $platal = empty($GLOBALS['IS_XNET_SITE']) ? new Platal() : new Xnet();
146 $platal->force_login($page);
147 }
148 return;
149
150 default:
151 if (!call_user_func(array($globals->session, 'doAuth'))) {
152 $platal = empty($GLOBALS['IS_XNET_SITE']) ? new Platal() : new Xnet();
153 $platal->force_login($page);
154 }
155 if ($perm == 'admin') {
156 check_perms();
157 }
158 return;
159 }
160 }
161
162 function wiki_require_page($pagename)
163 {
164 global $globals;
165 $pagename_slashes = str_replace('.','/',$pagename);
166 $pagename_dots = str_replace('/','.',$pagename);
167 if (is_file(wiki_work_dir().'/cache_'.$pagename_dots.'.tpl')) {
168 return;
169 }
170 system('wget --no-check-certificate '. escapeshellarg($globals->baseurl.'/'.$pagename_slashes) . ' -O /dev/null');
171 }
172
173 function wiki_delete_page($pagename)
174 {
175 $pagename_dots = str_replace('/','.',$pagename);
176 if (!strpos($pagename_dots, '.')) {
177 return false;
178 }
179 $file = wiki_work_dir().'/'.wiki_filename($pagename_dots);
180 $cachefile = wiki_work_dir().'/cache_'.$pagename_dots.'.tpl';
181 if (is_file($cachefile)) {
182 unlink($cachefile);
183 }
184 if (!is_file($file)) {
185 return false;
186 }
187 unlink($file);
188 return true;
189 }
190
191 function wiki_links_in_line($line, $groupname)
192 {
193 $links = array();
194 if (preg_match_all('@\[\[([^~][^\]\|\?#]*)((\?|#)[^\]\|]+)?(\\|[^\]]+)?\]\]@', $line, $matches, PREG_OFFSET_CAPTURE)) {
195 foreach ($matches[1] as $j => $link) if (!preg_match('@http://@', $link[0])) {
196 $mylink = str_replace('/','.',trim($link[0]));
197 $sup = trim(substr($matches[2][$j][0],1));
198 $alt = trim(substr($matches[4][$j][0],1));
199 $newlink = str_replace(' ','',ucwords($mylink));
200 if (strpos($newlink,'.') === false) {
201 $newlink = $groupname.'.'.$newlink;
202 }
203 if (!$alt && $mylink != $newlink) {
204 $alt = trim($link[0]);
205 }
206 $links[] = array(
207 'pos' => $matches[0][$j][1],
208 'size' => strlen($matches[0][$j][0]),
209 'href' => $newlink,
210 'sup' => $sup,
211 'alt' => $alt,
212 'group' => substr($mylink, 0, strpos($mylink, '.')));
213 }
214 }
215 return $links;
216 }
217
218 function wiki_rename_page($pagename, $newname, $changeLinks = true)
219 {
220 $pagename_dots = str_replace('/','.',$pagename);
221 $newname_dots = str_replace('/','.',$newname);
222 if (!strpos($pagename_dots, '.') || !strpos($newname_dots, '.')) {
223 return false;
224 }
225 $groupname = substr($pagename_dots, 0, strpos($pagename_dots,'.'));
226 $newgroupname = substr($newname_dots, 0, strpos($pagename_dots,'.'));
227
228 $file = wiki_work_dir().'/'.wiki_filename($pagename_dots);
229 $newfile = wiki_work_dir().'/'.wiki_filename($newname_dots);
230 if (!is_file($file)) {
231 // old page doesn't exist
232 return false;
233 }
234 if (!rename($file, $newfile)) {
235 // impossible to renama page
236 return false;
237 }
238
239 if (!$changeLinks) {
240 return true;
241 }
242
243 $changedLinks = 0;
244 // change name inside this folder and ingroup links if changing group
245 $lines = explode("\n", file_get_contents($newfile));
246 $changed = false;
247 foreach ($lines as $i => $line) {
248 list($k, $v) = explode('=', $line, 2);
249 if ($k == 'name' && $v == $pagename_dots) {
250 $lines[$i] = 'name='.$newname_dots;
251 $changed = true;
252 } else if ($groupname != $newgroupname) {
253 $links = wiki_links_in_line($line, $groupname);
254 $newline = ''; $last = 0;
255 foreach ($links as $link) if ($link['group'] == $groupname) {
256 $newline .= substr($line, $last, $link['pos']);
257 $newline .= '[['.$link['href'].$link['sup'].($link['alt']?(' |'.$link['alt']):'').']]';
258 $last = $link['pos']+$link['size'];
259 $changedLinks++;
260 }
261 if ($last != 0) {
262 $newline .= substr($line, $last);
263 $lines[$i] = $newline;
264 $changed = true;
265 }
266 }
267 }
268 wiki_putfile($newfile, join("\n", $lines));
269
270 // change wiki links in all wiki pages
271 $endname = substr($pagename_dots, strpos($pagename_dots,'.')+1);
272 $pages = array();
273 exec("grep ".$endname." ".wiki_work_dir()."/* -sc", $pages);
274 foreach($pages as $line) {
275 if (preg_match('%/([^/:]+):([0-9]+)$%', $line, $vals) && $vals[2] > 0) {
276 $inpage = $vals[1];
277 $lines = explode("\n", file_get_contents(wiki_work_dir().'/'.$inpage));
278 $changed = false;
279 // find all wiki links in page and change if linked to this page
280 foreach ($lines as $i => $line) {
281 $links = wiki_links_in_line($line, substr($inpage, 0, strpos($inpage, '.')));
282 $newline = ''; $last = 0;
283 foreach ($links as $link) {
284 if ($link['href'] == $pagename_dots) {
285 $newline .= substr($line, $last, $link['pos']);
286 $newline .= '[['.$newname_dots.$link['sup'].($link['alt']?(' |'.$link['alt']):'').']]';
287 $last = $link['pos']+$link['size'];
288 $changedLinks++;
289 }
290 }
291 if ($last != 0) {
292 $newline .= substr($line, $last);
293 $lines[$i] = $newline;
294 $changed = true;
295 }
296 }
297 if ($changed)
298 {
299 wiki_putfile(wiki_work_dir().'/'.$inpage, join("\n", $lines));
300 }
301 }
302 }
303 if ($changedLinks > 0) {
304 return $changedLinks;
305 }
306 return true;
307 }
308
309 function wiki_rename_folder($pagename, $newname, $changeLinks = true)
310 {
311 }
312
313 // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
314 ?>