1
|
|
|
<?php |
2
|
|
|
/*************************************************************************** |
3
|
|
|
* for license information see LICENSE.md |
4
|
|
|
* Inherit Smarty-Class and extend it |
5
|
|
|
***************************************************************************/ |
6
|
|
|
|
7
|
|
|
use Oc\GeoCache\Enum\GeoCacheType; |
8
|
|
|
use Oc\Util\CBench; |
9
|
|
|
|
10
|
|
|
require_once __DIR__ . '/../vendor/autoload.php'; |
11
|
|
|
require_once __DIR__ . '/db.inc.php'; |
12
|
|
|
require_once __DIR__ . '/logic/labels.inc.php'; |
13
|
|
|
|
14
|
|
|
/** |
15
|
|
|
* Class OcSmarty |
16
|
|
|
*/ |
17
|
|
|
class OcSmarty extends Smarty |
18
|
|
|
{ |
19
|
|
|
public $name = 'sys_nothing'; |
20
|
|
|
public $main_template = 'sys_main'; |
21
|
|
|
public $bench = null; |
22
|
|
|
public $compile_id = null; |
23
|
|
|
public $cache_id = null; // This is a smarty caching ID, not a caches.cache_id. |
24
|
|
|
public $title = ''; |
25
|
|
|
public $menuitem = null; |
26
|
|
|
public $nowpsearch = false; |
27
|
|
|
public $change_country_inpage = false; |
28
|
|
|
|
29
|
|
|
// no header, menu or footer |
30
|
|
|
public $popup = false; |
31
|
|
|
|
32
|
|
|
// show a thin border when using popup |
33
|
|
|
// disable popupmargin to appear fullscreen |
34
|
|
|
public $popupmargin = true; |
35
|
|
|
|
36
|
|
|
// url to call if login is required |
37
|
|
|
public $target = ''; |
38
|
|
|
|
39
|
|
|
public $header_javascript = []; |
40
|
|
|
public $body_load = []; |
41
|
|
|
public $body_unload = []; |
42
|
|
|
|
43
|
|
|
/** |
44
|
|
|
* OcSmarty constructor. |
45
|
|
|
*/ |
46
|
|
|
public function __construct() |
47
|
|
|
{ |
48
|
|
|
global $opt; |
49
|
|
|
$this->bench = new CBench(); |
50
|
|
|
$this->bench->start(); |
51
|
|
|
|
52
|
|
|
// configuration |
53
|
|
|
$this->template_dir = $opt['stylepath']; |
54
|
|
|
$this->compile_dir = __DIR__ . '/../var/cache2/smarty/compiled/'; |
55
|
|
|
$this->cache_dir = __DIR__ . '/../var/cache2/smarty/cache/'; |
56
|
|
|
$this->plugins_dir = [ |
57
|
|
|
'plugins', |
58
|
|
|
__DIR__ . '/../src/OcLegacy/SmartyPlugins', |
59
|
|
|
]; |
60
|
|
|
|
61
|
|
|
// disable caching ... if caching is enabled, 1 hour is default |
62
|
|
|
$this->caching = 0; |
63
|
|
|
$this->cache_lifetime = 3600; // default |
64
|
|
|
|
65
|
|
|
// register additional functions |
66
|
|
|
require_once __DIR__ . '/../src/OcLegacy/SmartyPlugins/block.nocache.php'; |
67
|
|
|
$this->register_block('nocache', 'smarty_block_nocache', false); |
68
|
|
|
$this->load_filter('pre', 't'); |
69
|
|
|
|
70
|
|
|
// cache control |
71
|
|
|
if (($opt['debug'] & DEBUG_TEMPLATES) == DEBUG_TEMPLATES) { |
72
|
|
|
$this->force_compile = true; |
73
|
|
|
} |
74
|
|
|
|
75
|
|
|
// site maintenance |
76
|
|
|
if (($opt['debug'] & DEBUG_OUTOFSERVICE) == DEBUG_OUTOFSERVICE) { |
77
|
|
|
$this->name = 'sys_outofservice'; |
78
|
|
|
$this->display(); |
79
|
|
|
} |
80
|
|
|
|
81
|
|
|
/* set login target |
82
|
|
|
*/ |
83
|
|
|
if (isset($_REQUEST['target'])) { |
84
|
|
|
$this->target = trim($_REQUEST['target']); |
85
|
|
|
if (preg_match('/^https?:/i', $this->target)) { |
86
|
|
|
$this->target = ''; |
87
|
|
|
} |
88
|
|
|
} else { |
89
|
|
|
$target = basename($_SERVER['PHP_SELF']) . '?'; |
90
|
|
|
|
91
|
|
|
// REQUEST-Variablen durchlaufen und an target anhaengen |
92
|
|
|
foreach ($_REQUEST as $varname => $varvalue) { |
93
|
|
|
if (in_array($varname, $opt['logic']['targetvars'])) { |
94
|
|
|
$target .= urlencode($varname) . '=' . urlencode($varvalue) . '&'; |
95
|
|
|
} |
96
|
|
|
} |
97
|
|
|
|
98
|
|
View Code Duplication |
if (mb_substr($target, -1) == '?' || mb_substr($target, -1) == '&') { |
99
|
|
|
$target = mb_substr($target, 0, -1); |
100
|
|
|
} |
101
|
|
|
|
102
|
|
|
$this->target = $target; |
103
|
|
|
} |
104
|
|
|
} |
105
|
|
|
|
106
|
|
|
/* ATTENTION: copied from internal implementation! |
107
|
|
|
* @param string $resource_name |
108
|
|
|
* @param string $compile_id |
109
|
|
|
*/ |
110
|
|
|
public function compile($resource_name, $compile_id = null): void |
111
|
|
|
{ |
112
|
|
|
if (!isset($compile_id)) { |
113
|
|
|
$compile_id = $this->compile_id; |
114
|
|
|
} |
115
|
|
|
|
116
|
|
|
$this->_compile_id = $compile_id; |
117
|
|
|
|
118
|
|
|
// load filters that are marked as autoload |
119
|
|
|
if (count($this->autoload_filters)) { |
120
|
|
|
foreach ($this->autoload_filters as $_filter_type => $_filters) { |
121
|
|
|
foreach ($_filters as $_filter) { |
122
|
|
|
$this->load_filter($_filter_type, $_filter); |
123
|
|
|
} |
124
|
|
|
} |
125
|
|
|
} |
126
|
|
|
|
127
|
|
|
$_smarty_compile_path = $this->_get_compile_path($resource_name); |
128
|
|
|
|
129
|
|
|
// if we just need to display the results, don't perform output |
130
|
|
|
// buffering - for speed |
131
|
|
|
$_cache_including = $this->_cache_including; |
132
|
|
|
$this->_cache_including = false; |
|
|
|
|
133
|
|
|
|
134
|
|
|
// compile the resource |
135
|
|
|
if (!$this->_is_compiled($resource_name, $_smarty_compile_path)) { |
136
|
|
|
$this->_compile_resource($resource_name, $_smarty_compile_path); |
137
|
|
|
} |
138
|
|
|
|
139
|
|
|
$this->_cache_including = $_cache_including; |
140
|
|
|
} |
141
|
|
|
|
142
|
|
|
/** |
143
|
|
|
* @param null|mixed $dummy1 |
144
|
|
|
* @param null|mixed $dummy2 |
145
|
|
|
* @param null|mixed $dummy3 |
146
|
|
|
*/ |
147
|
|
|
public function display($dummy1 = null, $dummy2 = null, $dummy3 = null): void |
148
|
|
|
{ |
149
|
|
|
global $opt, $db, $cookie, $login, $menu, $sqldebugger, $translate, $useragent_msie; |
150
|
|
|
$cookie->close(); |
151
|
|
|
|
152
|
|
|
// if the user is an admin, don't cache the content |
153
|
|
|
if (isset($login)) { |
154
|
|
|
if ($login->admin) { |
155
|
|
|
$this->caching = 0; |
156
|
|
|
} |
157
|
|
|
} |
158
|
|
|
|
159
|
|
|
//Give Smarty access to the whole options array. |
160
|
|
|
$this->assign('siteSettings', $opt); |
161
|
|
|
$this->assign('GeoCacheTypeEvent', GeoCacheType::EVENT); |
162
|
|
|
|
163
|
|
|
//Should we remove this whole block since we now have |
164
|
|
|
//access using the siteSettings above? |
165
|
|
|
// assign main template vars |
166
|
|
|
// ... and some of the $opt |
167
|
|
|
$locale = $opt['template']['locale']; |
168
|
|
|
|
169
|
|
|
$optn = []; |
170
|
|
|
$optn['debug'] = $opt['debug']; |
171
|
|
|
$optn['template']['locales'] = $opt['template']['locales']; |
172
|
|
|
$optn['template']['locale'] = $opt['template']['locale']; |
173
|
|
|
$optn['template']['style'] = $opt['template']['style']; |
174
|
|
|
$optn['template']['country'] = $login->getUserCountry(); |
|
|
|
|
175
|
|
|
$optn['page']['subtitle1'] = isset($opt['locale'][$locale]['page']['subtitle1']) ? $opt['locale'][$locale]['page']['subtitle1'] : $opt['page']['subtitle1']; |
176
|
|
|
$optn['page']['subtitle2'] = isset($opt['locale'][$locale]['page']['subtitle2']) ? $opt['locale'][$locale]['page']['subtitle2'] : $opt['page']['subtitle2']; |
177
|
|
|
$optn['page']['sitename'] = $opt['page']['sitename']; |
178
|
|
|
$optn['page']['headimagepath'] = $opt['page']['headimagepath']; |
179
|
|
|
$optn['page']['headoverlay'] = $opt['page']['headoverlay']; |
180
|
|
|
$optn['page']['max_logins_per_hour'] = $opt['page']['max_logins_per_hour']; |
181
|
|
|
$optn['page']['absolute_url'] = $opt['page']['absolute_url']; |
182
|
|
|
$optn['page']['absolute_urlpath'] = parse_url($opt['page']['absolute_url'], PHP_URL_PATH); |
183
|
|
|
$optn['page']['absolute_http_url'] = $opt['page']['absolute_http_url']; |
184
|
|
|
$optn['page']['default_absolute_url'] = $opt['page']['default_absolute_url']; |
185
|
|
|
$optn['page']['login_url'] = ($opt['page']['https']['force_login'] ? $opt['page']['absolute_https_url'] : '') . 'login.php'; |
186
|
|
|
$optn['page']['target'] = $this->target; |
187
|
|
|
$optn['page']['showdonations'] = $opt['page']['showdonations']; |
188
|
|
|
$optn['page']['title'] = $opt['page']['title']; |
189
|
|
|
$optn['page']['nowpsearch'] = $this->nowpsearch; |
190
|
|
|
$optn['page']['header_javascript'] = $this->header_javascript; |
191
|
|
|
$optn['page']['body_load'] = $this->body_load; |
192
|
|
|
$optn['page']['body_unload'] = $this->body_unload; |
193
|
|
|
$optn['page']['sponsor'] = $opt['page']['sponsor']; |
194
|
|
|
$optn['page']['showsocialmedia'] = $opt['page']['showsocialmedia']; |
195
|
|
|
$optn['page']['main_country'] = $opt['page']['main_country']; |
196
|
|
|
$optn['page']['main_locale'] = $opt['page']['main_locale']; |
197
|
|
|
$optn['page']['meta'] = $opt['page']['meta']; |
198
|
|
|
$optn['page']['teampic_url'] = $opt['page']['teampic_url']; |
199
|
|
|
$optn['page']['teammember_url'] = $opt['page']['teammember_url']; |
200
|
|
|
$optn['template']['title'] = $this->title; |
201
|
|
|
$optn['template']['caching'] = $this->caching; |
202
|
|
|
$optn['template']['popup'] = $this->popup; |
203
|
|
|
$optn['template']['popupmargin'] = $this->popupmargin; |
204
|
|
|
$optn['format'] = $opt['locale'][$opt['template']['locale']]['format']; |
205
|
|
|
$optn['mail'] = $opt['mail']; |
206
|
|
|
$optn['lib'] = $opt['lib']; |
207
|
|
|
$optn['tracking'] = $opt['tracking']; |
208
|
|
|
$optn['geokrety'] = $opt['geokrety']; |
209
|
|
|
$optn['template']['usercountrieslist'] = labels::getLabels('usercountrieslist'); |
210
|
|
|
$optn['help']['oconly'] = helppagelink('oconly', 'OConly'); |
|
|
|
|
211
|
|
|
$optn['msie'] = $useragent_msie; |
212
|
|
|
|
213
|
|
|
$loginn = [ |
214
|
|
|
'username' => '', |
215
|
|
|
'userid' => '', |
216
|
|
|
'admin' => '', |
217
|
|
|
]; |
218
|
|
|
|
219
|
|
|
if (isset($login)) { |
220
|
|
|
$loginn['username'] = $login->username; |
221
|
|
|
$loginn['userid'] = $login->userid; |
222
|
|
|
$loginn['admin'] = $login->admin; |
223
|
|
|
} |
224
|
|
|
|
225
|
|
|
// build menu |
226
|
|
|
if ($this->menuitem == null) { |
227
|
|
|
$menu->SetSelectItem(MNU_ROOT); |
228
|
|
|
} else { |
229
|
|
|
$menu->SetSelectItem($this->menuitem); |
230
|
|
|
} |
231
|
|
|
|
232
|
|
|
$this->assign('topmenu', $menu->getTopMenu()); |
233
|
|
|
$this->assign('submenu', $menu->getSubMenu()); |
234
|
|
|
$this->assign('breadcrumb', $menu->getBreadcrumb()); |
235
|
|
|
$this->assign('menucolor', $menu->getMenuColor()); |
236
|
|
|
$this->assign('helplink', helppagelink($this->name)); |
237
|
|
|
$this->assign('change_country_inpage', $this->change_country_inpage); |
238
|
|
|
|
239
|
|
|
if ($this->title == '') { |
240
|
|
|
$optn['template']['title'] = $menu->GetMenuTitle(); |
241
|
|
|
} |
242
|
|
|
|
243
|
|
|
// build address for switching locales and countries |
244
|
|
|
$base_pageadr = $_SERVER['REQUEST_URI']; |
245
|
|
|
|
246
|
|
|
// workaround for http://redmine.opencaching.de/issues/703 |
247
|
|
|
$strange_things_pos = strpos($base_pageadr, '.php/'); |
248
|
|
|
if ($strange_things_pos) { |
249
|
|
|
$base_pageadr = substr($base_pageadr, 0, $strange_things_pos + 4); |
250
|
|
|
} |
251
|
|
|
$lpos = strpos($base_pageadr, 'locale='); |
252
|
|
|
if ($this->change_country_inpage) { |
253
|
|
|
if (!$lpos) { |
254
|
|
|
$lpos = strpos($base_pageadr, 'usercountry='); |
255
|
|
|
} |
256
|
|
|
if (!$lpos) { |
257
|
|
|
$lpos = strpos($base_pageadr, 'country='); |
258
|
|
|
} |
259
|
|
|
} |
260
|
|
|
if ($lpos) { |
261
|
|
|
$base_pageadr = substr($base_pageadr, 0, $lpos); |
262
|
|
|
} else { |
263
|
|
|
$urx = explode('#', $base_pageadr); |
264
|
|
|
$base_pageadr = $urx[0]; |
265
|
|
|
if (strpos($base_pageadr, '?') == 0) { |
266
|
|
|
$base_pageadr .= '?'; |
267
|
|
|
} else { |
268
|
|
|
$base_pageadr .= '&'; |
269
|
|
|
} |
270
|
|
|
} |
271
|
|
|
$this->assign('base_pageadr', $base_pageadr); |
272
|
|
|
|
273
|
|
|
if ($opt['logic']['license']['disclaimer']) { |
274
|
|
View Code Duplication |
if (isset($opt['locale'][$locale]['page']['license_url'])) { |
275
|
|
|
$lurl = $opt['locale'][$locale]['page']['license_url']; |
276
|
|
|
} else { |
277
|
|
|
$lurl = $opt['locale']['EN']['page']['license_url']; |
278
|
|
|
} |
279
|
|
|
|
280
|
|
|
if (isset($opt['locale'][$locale]['page']['license'])) { |
281
|
|
|
$ltext = mb_ereg_replace( |
282
|
|
|
'{site}', |
283
|
|
|
$opt['page']['sitename'], |
284
|
|
|
$opt['locale'][$locale]['page']['license'] |
285
|
|
|
); |
286
|
|
|
} else { |
287
|
|
|
$ltext = $opt['locale']['EN']['page']['license']; |
288
|
|
|
} |
289
|
|
|
|
290
|
|
|
$this->assign('license_disclaimer', mb_ereg_replace('%1', $lurl, $ltext)); |
291
|
|
|
} else { |
292
|
|
|
$this->assign('license_disclaimer', ''); |
293
|
|
|
} |
294
|
|
|
|
295
|
|
|
$this->assign('opt', $optn); |
296
|
|
|
$this->assign('login', $loginn); |
297
|
|
|
|
298
|
|
|
if ($db['connected'] == true) { |
299
|
|
|
$this->assign('sys_dbconnected', true); |
300
|
|
|
} else { |
301
|
|
|
$this->assign('sys_dbconnected', false); |
302
|
|
|
} |
303
|
|
|
$this->assign('sys_dbslave', ($db['slave_id'] != -1)); |
304
|
|
|
|
305
|
|
|
if ($this->template_exists($this->name . '.tpl')) { |
306
|
|
|
$this->assign('template', $this->name); |
307
|
|
|
} elseif ($this->name != 'sys_error') { |
308
|
|
|
$this->error(ERROR_TEMPLATE_NOT_FOUND); |
309
|
|
|
} |
310
|
|
|
|
311
|
|
|
$this->bench->stop(); |
312
|
|
|
$this->assign('sys_runtime', $this->bench->diff()); |
313
|
|
|
|
314
|
|
|
$this->assign( |
315
|
|
|
'screen_css_time', |
316
|
|
|
filemtime(__DIR__ . '/../resource2/' . $opt['template']['style'] . '/css/style_screen.css') |
317
|
|
|
); |
318
|
|
|
$this->assign( |
319
|
|
|
'screen_msie_css_time', |
320
|
|
|
filemtime(__DIR__ . '/../resource2/' . $opt['template']['style'] . '/css/style_screen_msie.css') |
321
|
|
|
); |
322
|
|
|
$this->assign( |
323
|
|
|
'print_css_time', |
324
|
|
|
filemtime(__DIR__ . '/../resource2/' . $opt['template']['style'] . '/css/style_print.css') |
325
|
|
|
); |
326
|
|
|
|
327
|
|
|
// check if the template is compiled |
328
|
|
|
// if not, check if translation works correct |
329
|
|
|
$_smarty_compile_path = $this->_get_compile_path($this->name); |
330
|
|
|
if (!$this->_is_compiled($this->name, $_smarty_compile_path) && $this->name != 'error') { |
331
|
|
|
$internal_lang = $translate->t('INTERNAL_LANG', 'all', 'OcSmarty.class.php', ''); |
332
|
|
|
if (($internal_lang != $opt['template']['locale']) && ($internal_lang != 'INTERNAL_LANG')) { |
333
|
|
|
$this->error(ERROR_COMPILATION_FAILED); |
334
|
|
|
} |
335
|
|
|
} |
336
|
|
|
|
337
|
|
|
if ($this->is_cached() == true) { |
338
|
|
|
$this->assign('sys_cached', true); |
339
|
|
|
} else { |
340
|
|
|
$this->assign('sys_cached', false); |
341
|
|
|
} |
342
|
|
|
|
343
|
|
|
if ($db['debug'] === true) { |
344
|
|
|
parent::fetch($this->main_template . '.tpl', $this->get_cache_id(), $this->get_compile_id()); |
|
|
|
|
345
|
|
|
|
346
|
|
|
$this->clear_all_assign(); |
347
|
|
|
$this->main_template = 'sys_sqldebugger'; |
348
|
|
|
$this->assign('commands', $sqldebugger->getCommands()); |
349
|
|
|
$this->assign('cancel', $sqldebugger->getCancel()); |
350
|
|
|
unset($sqldebugger); |
351
|
|
|
|
352
|
|
|
$this->assign('opt', $optn); |
353
|
|
|
$this->assign('login', $loginn); |
354
|
|
|
|
355
|
|
|
$this->caching = 0; |
356
|
|
|
|
357
|
|
|
// unset sqldebugger to allow proper translation of sqldebugger template |
358
|
|
|
$opt['debug'] = $opt['debug'] & ~DEBUG_SQLDEBUGGER; |
359
|
|
|
|
360
|
|
|
$this->header(); |
361
|
|
|
parent::display($this->main_template . '.tpl'); |
362
|
|
|
} else { |
363
|
|
|
$this->header(); |
364
|
|
|
parent::display($this->main_template . '.tpl', $this->get_cache_id(), $this->get_compile_id()); |
365
|
|
|
} |
366
|
|
|
|
367
|
|
|
exit; |
368
|
|
|
} |
369
|
|
|
|
370
|
|
|
/** |
371
|
|
|
* show an error dialog |
372
|
|
|
* |
373
|
|
|
* @param int $id |
374
|
|
|
*/ |
375
|
|
|
public function error($id): void |
376
|
|
|
{ |
377
|
|
|
$this->clear_all_assign(); |
378
|
|
|
$this->caching = 0; |
379
|
|
|
|
380
|
|
|
$this->assign('page', $this->name); |
381
|
|
|
$this->assign('id', $id); |
382
|
|
|
|
383
|
|
|
if ($this->menuitem == null) { |
384
|
|
|
$this->menuitem = MNU_ERROR; |
385
|
|
|
} |
386
|
|
|
|
387
|
|
|
$args = func_get_args(); |
388
|
|
|
unset($args[0]); |
389
|
|
|
for ($i = 1; isset($args[$i]); $i++) { |
390
|
|
|
$this->assign('p' . $i, $args[$i]); |
391
|
|
|
} |
392
|
|
|
|
393
|
|
|
$this->name = 'error'; |
394
|
|
|
$this->display(); |
395
|
|
|
} |
396
|
|
|
|
397
|
|
|
/** |
398
|
|
|
* check if this template is valid |
399
|
|
|
* |
400
|
|
|
* @param null|mixed $dummy1 |
401
|
|
|
* @param null|mixed $dummy2 |
402
|
|
|
* @param null|mixed $dummy3 |
403
|
|
|
* @return bool|false|string |
404
|
|
|
*/ |
405
|
|
|
public function is_cached($dummy1 = null, $dummy2 = null, $dummy3 = null) |
406
|
|
|
{ |
407
|
|
|
global $login; |
408
|
|
|
|
409
|
|
|
// if the user is an admin, dont cache the content |
410
|
|
|
if (isset($login)) { |
411
|
|
|
if ($login->admin) { |
412
|
|
|
return false; |
413
|
|
|
} |
414
|
|
|
} |
415
|
|
|
|
416
|
|
|
return parent::is_cached($this->main_template . '.tpl', $this->get_cache_id(), $this->get_compile_id()); |
417
|
|
|
} |
418
|
|
|
|
419
|
|
|
/** |
420
|
|
|
* @return string |
421
|
|
|
*/ |
422
|
|
|
public function get_cache_id() |
423
|
|
|
{ |
424
|
|
|
// $cache_id can be directly supplied from unverified user input (URL params). |
425
|
|
|
// Probably this is no safety or stability issue, but to be sure we restrict |
426
|
|
|
// the ID to a reasonable set of characters: |
427
|
|
|
|
428
|
|
|
return $this->name . '|' . mb_ereg_replace('/[^A-Za-z0-9_\|\-\.]/', '', $this->cache_id); |
429
|
|
|
} |
430
|
|
|
|
431
|
|
|
/** |
432
|
|
|
* @return string |
433
|
|
|
*/ |
434
|
|
|
public function get_compile_id() |
435
|
|
|
{ |
436
|
|
|
global $opt; |
437
|
|
|
|
438
|
|
|
return $opt['template']['style'] . '|' . $opt['template']['locale'] . '|' . $this->compile_id; |
439
|
|
|
} |
440
|
|
|
|
441
|
|
|
/** |
442
|
|
|
* @param string $page |
443
|
|
|
*/ |
444
|
|
|
public function redirect($page): void |
445
|
|
|
{ |
446
|
|
|
global $cookie, $opt; |
447
|
|
|
$cookie->close(); |
448
|
|
|
|
449
|
|
|
// close db-connection |
450
|
|
|
sql_disconnect(); |
|
|
|
|
451
|
|
|
|
452
|
|
|
$this->header(); |
453
|
|
|
|
454
|
|
|
if (strpos($page, "\n") !== false) { |
455
|
|
|
$page = substr($page, 0, strpos($page, "\n")); |
456
|
|
|
} |
457
|
|
|
|
458
|
|
|
// redirect |
459
|
|
|
if (!preg_match('/^https?:/i', $page)) { |
460
|
|
|
if (substr($page, 0, 1) == '/') { |
461
|
|
|
$page = substr($page, 1); |
462
|
|
|
} |
463
|
|
|
$page = $opt['page']['absolute_url'] . $page; |
464
|
|
|
} |
465
|
|
|
|
466
|
|
|
|
467
|
|
|
header('Location: ' . $page); |
468
|
|
|
exit; |
469
|
|
|
} |
470
|
|
|
|
471
|
|
|
/** |
472
|
|
|
* redirect login function |
473
|
|
|
*/ |
474
|
|
|
public function redirect_login(): void |
475
|
|
|
{ |
476
|
|
|
global $opt; |
477
|
|
|
|
478
|
|
|
// we cannot redirect the POST-data |
479
|
|
|
if (count($_POST) > 0) { |
480
|
|
|
$this->error(ERROR_LOGIN_REQUIRED); |
481
|
|
|
} |
482
|
|
|
|
483
|
|
|
// ok ... redirect the get-data |
484
|
|
|
$target = ($opt['page']['https']['force_login'] ? 'https' : $opt['page']['protocol']) |
485
|
|
|
. '://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; |
486
|
|
|
$this->redirect('login.php?target=' . urlencode($target)); |
487
|
|
|
} |
488
|
|
|
|
489
|
|
|
/** |
490
|
|
|
* @param $name |
491
|
|
|
* @param $rs |
492
|
|
|
*/ |
493
|
|
View Code Duplication |
public function assign_rs($name, $rs): void |
|
|
|
|
494
|
|
|
{ |
495
|
|
|
$items = []; |
496
|
|
|
while ($r = sql_fetch_assoc($rs)) { |
|
|
|
|
497
|
|
|
$items[] = $r; |
498
|
|
|
} |
499
|
|
|
$this->assign($name, $items); |
500
|
|
|
} |
501
|
|
|
|
502
|
|
|
/** |
503
|
|
|
* @param $src |
504
|
|
|
*/ |
505
|
|
|
public function add_header_javascript($src): void |
506
|
|
|
{ |
507
|
|
|
$this->header_javascript[] = $src; |
508
|
|
|
} |
509
|
|
|
|
510
|
|
|
/** |
511
|
|
|
* @param $script |
512
|
|
|
*/ |
513
|
|
|
public function add_body_load($script): void |
514
|
|
|
{ |
515
|
|
|
$this->body_load[] = $script; |
516
|
|
|
} |
517
|
|
|
|
518
|
|
|
/** |
519
|
|
|
* @param $script |
520
|
|
|
*/ |
521
|
|
|
public function add_body_unload($script): void |
522
|
|
|
{ |
523
|
|
|
$this->body_unload[] = $script; |
524
|
|
|
} |
525
|
|
|
|
526
|
|
|
/** |
527
|
|
|
* setting http header |
528
|
|
|
*/ |
529
|
|
|
public function header(): void |
530
|
|
|
{ |
531
|
|
|
global $opt; |
532
|
|
|
global $cookie; |
533
|
|
|
|
534
|
|
|
if ($opt['gui'] == GUI_HTML) { |
535
|
|
|
// charset setzen |
536
|
|
|
header('Content-type: text/html; charset=utf-8'); |
537
|
|
|
|
538
|
|
|
// HTTP/1.1 |
539
|
|
|
header('Cache-Control: no-store, no-cache, must-revalidate'); |
540
|
|
|
header('Cache-Control: post-check=0, pre-check=0', false); |
541
|
|
|
// HTTP/1.0 |
542
|
|
|
header('Pragma: no-cache'); |
543
|
|
|
// Date in the past |
544
|
|
|
header('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); |
545
|
|
|
// always modified |
546
|
|
|
header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT'); |
547
|
|
|
|
548
|
|
|
// set the cookie |
549
|
|
|
$cookie->header(); |
550
|
|
|
} |
551
|
|
|
} |
552
|
|
|
|
553
|
|
|
/** |
554
|
|
|
* - trim target and strip newlines |
555
|
|
|
* - use sDefault if sTarget is absolute and sDefault!=null |
556
|
|
|
* |
557
|
|
|
* @param $sTarget |
558
|
|
|
* @param null|mixed $sDefault |
559
|
|
|
* @return null|string |
560
|
|
|
*/ |
561
|
|
|
public function checkTarget($sTarget, $sDefault = null) |
562
|
|
|
{ |
563
|
|
|
if (mb_strpos($sTarget, "\n") !== false) { |
564
|
|
|
$sTarget = mb_substr($sTarget, 0, mb_strpos($sTarget, "\n")); |
565
|
|
|
} |
566
|
|
|
|
567
|
|
|
$sTarget = mb_trim($sTarget); |
568
|
|
|
|
569
|
|
|
if (mb_strtolower(mb_substr($sTarget, 0, 7)) == 'http://' || $sTarget == '') { |
570
|
|
|
if ($sDefault != null) { |
571
|
|
|
return $sDefault; |
572
|
|
|
} |
573
|
|
|
} |
574
|
|
|
|
575
|
|
|
return $sTarget; |
576
|
|
|
} |
577
|
|
|
|
578
|
|
|
public function acceptsAndPurifiesHtmlInput(): void |
579
|
|
|
{ |
580
|
|
|
// Prevent false XSS detection of harmless HTML code |
581
|
|
|
// see https://redmine.opencaching.de/issues/1137 |
582
|
|
|
// see https://stackoverflow.com/questions/43249998/chrome-err-blocked-by-xss-auditor-details |
583
|
|
|
|
584
|
|
|
// XSS protection can be safely disabled if user-supplied content cannot inject JavaScript, |
585
|
|
|
// see https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-XSS-Protection |
586
|
|
|
// This is ensured by HTMLpurifier in OC code. |
587
|
|
|
|
588
|
|
|
header('X-XSS-Protection: 0'); |
589
|
|
|
} |
590
|
|
|
} |
591
|
|
|
|
This check looks for assignments to scalar types that may be of the wrong type.
To ensure the code behaves as expected, it may be a good idea to add an explicit type cast.