Commit | Line | Data |
---|---|---|
b62f8858 | 1 | <?php |
2 | /*************************************************************************** | |
e92ecb8c | 3 | * Copyright (C) 2003-2011 Polytechnique.org * |
b62f8858 | 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 | class CoreModule extends PLModule | |
23 | { | |
b62f8858 | 24 | function handlers() |
25 | { | |
26 | return array( | |
1547b0f6 | 27 | '400' => $this->make_hook('400', AUTH_PUBLIC), |
b631d803 SJ |
28 | '403' => $this->make_hook('403', AUTH_PUBLIC), |
29 | '404' => $this->make_hook('404', AUTH_PUBLIC), | |
30 | 'login' => $this->make_hook('login', AUTH_COOKIE), | |
31 | 'send_bug' => $this->make_hook('bug', AUTH_COOKIE), | |
32 | 'purge_cache' => $this->make_hook('purge_cache', AUTH_COOKIE, 'admin'), | |
05d5ce15 | 33 | 'kill_sessions' => $this->make_hook('kill_sessions', AUTH_COOKIE, 'admin'), |
7f6d1063 FB |
34 | 'sql_errors' => $this->make_hook('siteerror', AUTH_COOKIE, 'admin'), |
35 | 'assert_errors' => $this->make_hook('siteerror', AUTH_COOKIE, 'admin'), | |
36 | 'site_errors' => $this->make_hook('siteerror', AUTH_COOKIE, 'admin'), | |
ddc2d3fa | 37 | 'site_errors/rss' => $this->make_token_hook('siteerror_rss', AUTH_COOKIE, 'admin'), |
131a7c34 | 38 | 'site_errors/register' => $this->make_hook('register_error', AUTH_PUBLIC), |
fdbeba4f | 39 | |
7299bfce FB |
40 | 'embedded' => $this->make_hook('embedded', AUTH_PUBLIC), |
41 | ||
b631d803 SJ |
42 | 'wiki_help' => $this->make_hook('wiki_help', AUTH_PUBLIC), |
43 | 'wiki_preview' => $this->make_hook('wiki_preview', AUTH_COOKIE, 'user', NO_AUTH), | |
7b14a2a0 | 44 | |
d1bdef74 | 45 | 'validator' => $this->make_hook('validator', AUTH_PUBLIC), |
b631d803 SJ |
46 | 'valid.html' => $this->make_hook('valid', AUTH_PUBLIC), |
47 | 'favicon.ico' => $this->make_hook('favicon', AUTH_PUBLIC), | |
48 | 'robots.txt' => $this->make_hook('robotstxt', AUTH_PUBLIC, 'user', NO_HTTPS), | |
b62f8858 | 49 | ); |
50 | } | |
51 | ||
9e394323 | 52 | function handler_valid($page) |
7b14a2a0 | 53 | { |
54 | readfile($page->compile_dir.'/valid.html'); | |
55 | exit; | |
56 | } | |
57 | ||
d1bdef74 FB |
58 | function handler_validator($page) |
59 | { | |
60 | global $globals; | |
61 | exec($globals->spoolroot."/bin/devel/xhtml.validate.pl ".$page->compile_dir."/valid.html", $val); | |
62 | $url = "<a href='http://validator.w3.org/check?uri={$globals->baseurl}/valid.html&ss=1#result'>"; | |
63 | $replc = '<span style="color: #080;">HTML OK</span>'; | |
64 | foreach ($val as $h) { | |
65 | if (preg_match("/^X-W3C-Validator-Errors: (\d+)$/", $h, $m)) { | |
66 | if ($m[1]) { | |
67 | $replc = "<span class='erreur'>$url{$m[1]} ERREUR(S) !!!</a></span>"; | |
68 | } | |
69 | break; | |
70 | } | |
71 | } | |
72 | echo $replc; | |
73 | exit; | |
74 | } | |
75 | ||
ed4f7de0 | 76 | function handler_400(PlPage $page) |
1547b0f6 VZ |
77 | { |
78 | header($_SERVER['SERVER_PROTOCOL'] . ' 400 Bad Request'); | |
79 | $page->coreTpl('40x.tpl'); | |
80 | $page->trigError('Ta requête est invalide.'); | |
81 | } | |
82 | ||
ed4f7de0 | 83 | function handler_403(PlPage $page) |
b62f8858 | 84 | { |
94c63478 | 85 | header($_SERVER['SERVER_PROTOCOL'] . ' 403 Forbidden'); |
1547b0f6 | 86 | $page->coreTpl('40x.tpl'); |
2aad1481 | 87 | $page->trigError('Tu n\'as pas les permissions nécessaires pour accéder à cette page.'); |
b62f8858 | 88 | } |
89 | ||
ed4f7de0 | 90 | function handler_404(PlPage $page) |
b62f8858 | 91 | { |
1547b0f6 | 92 | global $platal; |
94c63478 | 93 | header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found'); |
7cb40d85 | 94 | $page->coreTpl('404.tpl'); |
6b8d257b | 95 | $page->assign('near', $platal->near_hook()); |
2aad1481 | 96 | $page->trigError('Cette page n\'existe pas !!!'); |
b62f8858 | 97 | } |
0889eb33 | 98 | |
9e394323 | 99 | function handler_login($page) |
bb7af3cd | 100 | { |
101 | $allkeys = func_get_args(); | |
102 | unset($allkeys[0]); | |
103 | $url = join('/',$allkeys); | |
104 | pl_redirect($url); | |
105 | } | |
106 | ||
9e394323 | 107 | function handler_favicon($page) |
dc41059a | 108 | { |
2b1ac5ab | 109 | global $globals; |
a286fc7a VZ |
110 | pl_cached_content_headers("image/x-icon"); |
111 | readfile($globals->spoolroot . '/htdocs/images/favicon.ico'); | |
dc41059a | 112 | exit; |
113 | } | |
114 | ||
9e394323 | 115 | function handler_robotstxt($page) |
f8eb84b7 VZ |
116 | { |
117 | global $globals; | |
a12a0ce3 VZ |
118 | |
119 | $disallowed_uris = array(); | |
120 | if ($globals->core->restricted_platal) { | |
121 | $disallowed_uris[] = '/'; | |
122 | } else if (!empty($globals->core->robotstxt_disallowed_uris)) { | |
123 | $disallowed_uris = preg_split('/[\s,]+/', | |
124 | $globals->core->robotstxt_disallowed_uris, | |
125 | -1, PREG_SPLIT_NO_EMPTY); | |
f8eb84b7 VZ |
126 | } |
127 | ||
a12a0ce3 | 128 | if (count($disallowed_uris) > 0) { |
a286fc7a | 129 | pl_cached_content_headers("text/plain"); |
a12a0ce3 VZ |
130 | echo "User-agent: *\n"; |
131 | foreach ($disallowed_uris as $uri) { | |
132 | echo "Disallow: $uri\n"; | |
133 | } | |
134 | exit; | |
135 | } | |
136 | return PL_NOT_FOUND; | |
f8eb84b7 VZ |
137 | } |
138 | ||
9e394323 | 139 | function handler_purge_cache($page) |
0889eb33 | 140 | { |
40d428d8 | 141 | S::assert_xsrf_token(); |
0889eb33 | 142 | |
40d428d8 | 143 | $page->clear_compiled_tpl(); |
1f16638f | 144 | PlWikiPage::clearCache(); |
c426670b | 145 | PlCache::clearAll(); |
0889eb33 | 146 | |
40d428d8 | 147 | http_redirect(empty($_SERVER['HTTP_REFERER']) ? './' : $_SERVER['HTTP_REFERER']); |
0889eb33 | 148 | } |
e74411f7 | 149 | |
9e394323 | 150 | function handler_kill_sessions($page) |
05d5ce15 FB |
151 | { |
152 | kill_sessions(); | |
153 | } | |
154 | ||
9e394323 | 155 | function handler_bug($page) |
8b1f8e12 | 156 | { |
97af9556 | 157 | global $globals; |
4d68bcde FB |
158 | |
159 | if (empty($_SERVER['HTTP_REFERER'])) { | |
160 | // We don't have a valid referer, we need to use the url | |
161 | list($currentPage, $location) = explode('//', $_SERVER['REQUEST_URI'], 2); | |
162 | ||
163 | $location = 'http'.(empty($_SERVER['HTTPS']) ? '' : 's').'://'.$_SERVER['SERVER_NAME'].'/'.$location; | |
164 | } else { | |
165 | $location = $_SERVER['HTTP_REFERER']; | |
166 | } | |
167 | ||
7cb40d85 | 168 | $page->coreTpl('bug.tpl', SIMPLE); |
4d68bcde | 169 | $page->assign('location', $location); |
8b1f8e12 | 170 | $page->addJsLink('close_on_esc.js'); |
4d68bcde | 171 | |
40d428d8 VZ |
172 | if (Env::has('send') && trim(Env::v('detailed_desc'))) { |
173 | S::assert_xsrf_token(); | |
174 | ||
5486a0d3 | 175 | $body = wordwrap(Env::v('detailed_desc'), 78) . "\n\n" |
176 | . "----------------------------\n" | |
177 | . "Page : " . Env::v('page') . "\n\n" | |
30f983a1 | 178 | . "Utilisateur : " . S::user()->login() . "\n" |
5c50e351 | 179 | . "Navigateur : " . $_SERVER['HTTP_USER_AGENT'] . "\n" |
180 | . "Skin : " . S::v('skin') . "\n"; | |
2aad1481 SJ |
181 | $page->assign('bug_sent', 1); |
182 | $page->trigSuccess('Ton message a bien été envoyé au support de ' . $globals->core->sitename | |
183 | . ', tu devrais en recevoir une copie d\'ici quelques minutes. Nous allons ' | |
184 | . 'le traiter et y répondre dans les plus brefs délais.'); | |
8b1f8e12 | 185 | $mymail = new PlMailer(); |
30f983a1 VZ |
186 | $mymail->setFrom(sprintf('"%s" <%s>', S::user()->fullName(), S::user()->bestEmail())); |
187 | $mymail->addCc(sprintf('"%s" <%s>', S::user()->fullName(), S::user()->bestEmail())); | |
1d55fe45 | 188 | $mymail->addTo('support+platal@' . $globals->mail->domain); |
8b1f8e12 | 189 | $mymail->setSubject('Plat/al '.Env::v('task_type').' : '.Env::v('item_summary')); |
5486a0d3 | 190 | $mymail->setTxtBody($body); |
8b1f8e12 | 191 | $mymail->send(); |
e8dfa21c | 192 | } elseif (Env::has('send')) { |
2aad1481 | 193 | $page->trigError("Merci de remplir une explication du problème rencontré."); |
8b1f8e12 | 194 | } |
195 | } | |
72b2f8bb | 196 | |
9e394323 | 197 | function handler_wiki_help($page, $action = 'title') |
72b2f8bb | 198 | { |
7cb40d85 | 199 | $page->coreTpl('wiki.help.tpl', SIMPLE); |
72b2f8bb | 200 | $page->assign('wiki_help', MiniWiki::help($action == 'title')); |
201 | } | |
fdbeba4f | 202 | |
203 | /// Shared handler for wiki syntax result preview | |
9e394323 | 204 | function handler_wiki_preview($page, $action = 'title') |
fdbeba4f | 205 | { |
a286fc7a | 206 | pl_content_headers("text/html"); |
8b6e9f4e | 207 | $text = Env::v('text'); |
fdbeba4f | 208 | echo MiniWiki::wikiToHtml($text, $action == 'title'); |
209 | exit; | |
210 | } | |
f8eaef22 | 211 | |
ddc2d3fa FB |
212 | function handler_siteerror($page) |
213 | { | |
f8eaef22 | 214 | global $globals; |
7f6d1063 | 215 | $page->coreTpl('site_errors.tpl'); |
ddc2d3fa FB |
216 | $page->setRssLink('Polytechnique.org :: Erreurs', |
217 | 'site_errors/rss/' . S::v('hruid') . '/' . S::user()->token . '/rss.xml'); | |
02c018dd | 218 | if (Post::has('clear')) { |
40b79bfc | 219 | PlErrorReport::clear(); |
7f6d1063 | 220 | $page->trigSuccess("Erreurs effacées."); |
ec60dba7 | 221 | } |
71c1196e | 222 | $page->assign('errors', PlErrorReport::iterate()); |
ec60dba7 | 223 | } |
7299bfce | 224 | |
131a7c34 FB |
225 | function handler_register_error($page) |
226 | { | |
227 | if (S::has_xsrf_token() && Post::has('error') && Post::has('url')) { | |
228 | PlErrorReport::report("Client error on " . Post::s('url') . ":\n\n" . Post::s('error')); | |
229 | } | |
230 | exit; | |
231 | } | |
232 | ||
ddc2d3fa FB |
233 | function handler_siteerror_rss(PlPage $page, PlUser $user) |
234 | { | |
235 | return PlErrorReport::feed($page, $user); | |
236 | } | |
237 | ||
7299bfce FB |
238 | function handler_embedded($page) |
239 | { | |
240 | global $platal, $globals; | |
241 | $allkeys = func_get_args(); | |
242 | $mode = $allkeys[1]; | |
243 | unset($allkeys[0]); | |
244 | unset($allkeys[1]); | |
bc02ceca | 245 | Env::set('display', $mode); |
7299bfce FB |
246 | $globals->baseurl .= '/embedded/' . $mode; |
247 | $platal->path = join('/', $allkeys); | |
248 | $platal->run(); | |
249 | } | |
b62f8858 | 250 | } |
251 | ||
a7de4ef7 | 252 | // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: |
b62f8858 | 253 | ?> |