Commit | Line | Data |
---|---|---|
b62f8858 | 1 | <?php |
2 | /*************************************************************************** | |
179afa7f | 3 | * Copyright (C) 2003-2008 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( | |
4c28beb2 | 27 | '403' => $this->make_hook('403', AUTH_PUBLIC), |
28 | '404' => $this->make_hook('404', AUTH_PUBLIC), | |
bb7af3cd | 29 | 'login' => $this->make_hook('login', AUTH_COOKIE), |
30 | 'send_bug' => $this->make_hook('bug', AUTH_COOKIE), | |
7b14a2a0 | 31 | 'purge_cache' => $this->make_hook('purge_cache', AUTH_COOKIE, 'admin'), |
05d5ce15 | 32 | 'kill_sessions' => $this->make_hook('kill_sessions', AUTH_COOKIE, 'admin'), |
e74411f7 | 33 | 'get_rights' => $this->make_hook('get_rights', AUTH_MDP, 'admin'), |
fdbeba4f | 34 | |
35 | 'wiki_help' => $this->make_hook('wiki_help', AUTH_PUBLIC), | |
36 | 'wiki_preview' => $this->make_hook('wiki_preview', AUTH_COOKIE, 'user', NO_AUTH), | |
7b14a2a0 | 37 | |
38 | 'valid.html' => $this->make_hook('valid', AUTH_PUBLIC), | |
dc41059a | 39 | 'favicon.ico' => $this->make_hook('favicon', AUTH_PUBLIC), |
f8eb84b7 | 40 | 'robots.txt' => $this->make_hook('robotstxt', AUTH_PUBLIC, 'user', NO_HTTPS), |
b62f8858 | 41 | ); |
42 | } | |
43 | ||
7b14a2a0 | 44 | function handler_valid(&$page) |
45 | { | |
46 | readfile($page->compile_dir.'/valid.html'); | |
47 | exit; | |
48 | } | |
49 | ||
b62f8858 | 50 | function handler_403(&$page) |
51 | { | |
338a5934 | 52 | global $globals; |
94c63478 | 53 | header($_SERVER['SERVER_PROTOCOL'] . ' 403 Forbidden'); |
7cb40d85 | 54 | $page->coreTpl('403.tpl'); |
b62f8858 | 55 | } |
56 | ||
57 | function handler_404(&$page) | |
58 | { | |
338a5934 | 59 | global $globals, $platal; |
94c63478 | 60 | header($_SERVER['SERVER_PROTOCOL'] . ' 404 Not Found'); |
7cb40d85 | 61 | $page->coreTpl('404.tpl'); |
6b8d257b | 62 | $page->assign('near', $platal->near_hook()); |
b62f8858 | 63 | } |
0889eb33 | 64 | |
bb7af3cd | 65 | function handler_login(&$page) |
66 | { | |
67 | $allkeys = func_get_args(); | |
68 | unset($allkeys[0]); | |
69 | $url = join('/',$allkeys); | |
70 | pl_redirect($url); | |
71 | } | |
72 | ||
dc41059a | 73 | function handler_favicon(&$page) |
74 | { | |
ce41a714 | 75 | $data = file_get_contents(dirname(__FILE__).'/../htdocs/images/favicon.ico'); |
76 | header('Content-Type: image/x-icon'); | |
dc41059a | 77 | echo $data; |
78 | exit; | |
79 | } | |
80 | ||
f8eb84b7 VZ |
81 | function handler_robotstxt(&$page) |
82 | { | |
83 | global $globals; | |
84 | if (!$globals->core->restricted_platal) { | |
85 | return PL_NOT_FOUND; | |
86 | } | |
87 | ||
88 | header('Content-Type: text/plain'); | |
89 | echo "User-agent: *\n"; | |
90 | echo "Disallow: /\n"; | |
91 | exit; | |
92 | } | |
93 | ||
0889eb33 | 94 | function handler_purge_cache(&$page) |
95 | { | |
40d428d8 | 96 | S::assert_xsrf_token(); |
0889eb33 | 97 | |
40d428d8 | 98 | $page->clear_compiled_tpl(); |
1f16638f | 99 | PlWikiPage::clearCache(); |
0889eb33 | 100 | |
40d428d8 | 101 | http_redirect(empty($_SERVER['HTTP_REFERER']) ? './' : $_SERVER['HTTP_REFERER']); |
0889eb33 | 102 | } |
e74411f7 | 103 | |
05d5ce15 FB |
104 | function handler_kill_sessions(&$page) |
105 | { | |
106 | kill_sessions(); | |
107 | } | |
108 | ||
e74411f7 | 109 | function handler_get_rights(&$page, $level) |
110 | { | |
111 | if (S::has('suid')) { | |
a7de4ef7 | 112 | $page->kill('Déjà en SUID'); |
e74411f7 | 113 | } |
114 | ||
115 | if (isset($_SESSION['log'])) { | |
732e5855 | 116 | S::logger()->log("suid_start", "login by ".S::v('forlife')); |
eaf30d86 | 117 | } |
732e5855 FB |
118 | Platal::session()->startSUID(S::i('uid')); |
119 | Platal::session()->makePerms($level); | |
e74411f7 | 120 | |
121 | pl_redirect('/'); | |
122 | } | |
8b1f8e12 | 123 | |
124 | function handler_bug(&$page) | |
125 | { | |
97af9556 | 126 | global $globals; |
4d68bcde FB |
127 | |
128 | if (empty($_SERVER['HTTP_REFERER'])) { | |
129 | // We don't have a valid referer, we need to use the url | |
130 | list($currentPage, $location) = explode('//', $_SERVER['REQUEST_URI'], 2); | |
131 | ||
132 | $location = 'http'.(empty($_SERVER['HTTPS']) ? '' : 's').'://'.$_SERVER['SERVER_NAME'].'/'.$location; | |
133 | } else { | |
134 | $location = $_SERVER['HTTP_REFERER']; | |
135 | } | |
136 | ||
7cb40d85 | 137 | $page->coreTpl('bug.tpl', SIMPLE); |
4d68bcde | 138 | $page->assign('location', $location); |
8b1f8e12 | 139 | $page->addJsLink('close_on_esc.js'); |
4d68bcde | 140 | |
40d428d8 VZ |
141 | if (Env::has('send') && trim(Env::v('detailed_desc'))) { |
142 | S::assert_xsrf_token(); | |
143 | ||
5486a0d3 | 144 | $body = wordwrap(Env::v('detailed_desc'), 78) . "\n\n" |
145 | . "----------------------------\n" | |
146 | . "Page : " . Env::v('page') . "\n\n" | |
147 | . "Utilisateur : " . S::v('forlife') . "\n" | |
5c50e351 | 148 | . "Navigateur : " . $_SERVER['HTTP_USER_AGENT'] . "\n" |
149 | . "Skin : " . S::v('skin') . "\n"; | |
8b1f8e12 | 150 | $page->assign('bug_sent',1); |
151 | $mymail = new PlMailer(); | |
1d55fe45 | 152 | $mymail->setFrom('"'.S::v('prenom').' '.S::v('nom').'" <'.S::v('bestalias').'@' . $globals->mail->domain . '>'); |
153 | $mymail->addTo('support+platal@' . $globals->mail->domain); | |
154 | $mymail->addCc('"'.S::v('prenom').' '.S::v('nom').'" <'.S::v('bestalias').'@' . $globals->mail->domain . '>'); | |
8b1f8e12 | 155 | $mymail->setSubject('Plat/al '.Env::v('task_type').' : '.Env::v('item_summary')); |
5486a0d3 | 156 | $mymail->setTxtBody($body); |
8b1f8e12 | 157 | $mymail->send(); |
e8dfa21c | 158 | } elseif (Env::has('send')) { |
a7d35093 | 159 | $page->trigError("Merci de remplir une explication du problème rencontré"); |
8b1f8e12 | 160 | } |
161 | } | |
72b2f8bb | 162 | |
163 | function handler_wiki_help(&$page, $action = 'title') | |
164 | { | |
7cb40d85 | 165 | $page->coreTpl('wiki.help.tpl', SIMPLE); |
72b2f8bb | 166 | $page->assign('wiki_help', MiniWiki::help($action == 'title')); |
167 | } | |
fdbeba4f | 168 | |
169 | /// Shared handler for wiki syntax result preview | |
170 | function handler_wiki_preview(&$page, $action = 'title') | |
171 | { | |
172 | header('Content-Type: text/html; charset=utf-8'); | |
173 | $text = Get::v('text'); | |
174 | echo MiniWiki::wikiToHtml($text, $action == 'title'); | |
175 | exit; | |
176 | } | |
b62f8858 | 177 | } |
178 | ||
a7de4ef7 | 179 | // vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8: |
b62f8858 | 180 | ?> |