Switches the core to S::user() paradigm, while retaining older S::v('forlife') model,
[platal.git] / modules / core.php
CommitLineData
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
22class 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'])) {
99132dee
VZ
116 if (S::user()) {
117 S::logger()->log("suid_start", "login by " . S::user()->login());
118 } else {
119 // TODO(vzanotti): trash that code when support of forlife will be gone.
120 S::logger()->log("suid_start", "login by ".S::v('forlife'));
121 }
eaf30d86 122 }
732e5855
FB
123 Platal::session()->startSUID(S::i('uid'));
124 Platal::session()->makePerms($level);
e74411f7 125
126 pl_redirect('/');
127 }
8b1f8e12 128
129 function handler_bug(&$page)
130 {
97af9556 131 global $globals;
4d68bcde
FB
132
133 if (empty($_SERVER['HTTP_REFERER'])) {
134 // We don't have a valid referer, we need to use the url
135 list($currentPage, $location) = explode('//', $_SERVER['REQUEST_URI'], 2);
136
137 $location = 'http'.(empty($_SERVER['HTTPS']) ? '' : 's').'://'.$_SERVER['SERVER_NAME'].'/'.$location;
138 } else {
139 $location = $_SERVER['HTTP_REFERER'];
140 }
141
7cb40d85 142 $page->coreTpl('bug.tpl', SIMPLE);
4d68bcde 143 $page->assign('location', $location);
8b1f8e12 144 $page->addJsLink('close_on_esc.js');
4d68bcde 145
40d428d8
VZ
146 if (Env::has('send') && trim(Env::v('detailed_desc'))) {
147 S::assert_xsrf_token();
148
5486a0d3 149 $body = wordwrap(Env::v('detailed_desc'), 78) . "\n\n"
150 . "----------------------------\n"
151 . "Page : " . Env::v('page') . "\n\n"
152 . "Utilisateur : " . S::v('forlife') . "\n"
5c50e351 153 . "Navigateur : " . $_SERVER['HTTP_USER_AGENT'] . "\n"
154 . "Skin : " . S::v('skin') . "\n";
8b1f8e12 155 $page->assign('bug_sent',1);
156 $mymail = new PlMailer();
1d55fe45 157 $mymail->setFrom('"'.S::v('prenom').' '.S::v('nom').'" <'.S::v('bestalias').'@' . $globals->mail->domain . '>');
158 $mymail->addTo('support+platal@' . $globals->mail->domain);
159 $mymail->addCc('"'.S::v('prenom').' '.S::v('nom').'" <'.S::v('bestalias').'@' . $globals->mail->domain . '>');
8b1f8e12 160 $mymail->setSubject('Plat/al '.Env::v('task_type').' : '.Env::v('item_summary'));
5486a0d3 161 $mymail->setTxtBody($body);
8b1f8e12 162 $mymail->send();
e8dfa21c 163 } elseif (Env::has('send')) {
a7d35093 164 $page->trigError("Merci de remplir une explication du problème rencontré");
8b1f8e12 165 }
166 }
72b2f8bb 167
168 function handler_wiki_help(&$page, $action = 'title')
169 {
7cb40d85 170 $page->coreTpl('wiki.help.tpl', SIMPLE);
72b2f8bb 171 $page->assign('wiki_help', MiniWiki::help($action == 'title'));
172 }
fdbeba4f 173
174 /// Shared handler for wiki syntax result preview
175 function handler_wiki_preview(&$page, $action = 'title')
176 {
177 header('Content-Type: text/html; charset=utf-8');
178 $text = Get::v('text');
179 echo MiniWiki::wikiToHtml($text, $action == 'title');
180 exit;
181 }
b62f8858 182}
183
a7de4ef7 184// vim:set et sw=4 sts=4 sws=4 foldmethod=marker enc=utf-8:
b62f8858 185?>