tiki-setup.php 26.8 KB
Newer Older
1
<?php
changi67's avatar
changi67 committed
2
/**
kstingel's avatar
kstingel committed
3
 * contains the hooks for Tiki's internal functionality.
4
 *
kstingel's avatar
kstingel committed
5
 * this script may only be included, it will die if called directly.
6
 *
kstingel's avatar
kstingel committed
7
 * @package TikiWiki
8
 * @copyright (c) Copyright 2002-2015 by authors of the Tiki Wiki CMS Groupware Project. All Rights Reserved. See copyright.txt for details and a complete list of authors.
kstingel's avatar
kstingel committed
9
 * @licence Licensed under the GNU LESSER GENERAL PUBLIC LICENSE. See license.txt for details.
changi67's avatar
changi67 committed
10
 */
changi67's avatar
changi67 committed
11
// $Id$
changi67's avatar
changi67 committed
12

kstingel's avatar
kstingel committed
13
// die if called directly.
14
/**
kstingel's avatar
kstingel committed
15
 * @global array $prefs
16
 * @global array $tikilib
kstingel's avatar
kstingel committed
17
 */
sylvieg's avatar
sylvieg committed
18
global $prefs, $tikilib;
19 20
if (strpos($_SERVER['SCRIPT_NAME'], basename(__FILE__)) !== false) {
	header('location: index.php');
changi67's avatar
changi67 committed
21
	exit;
redflo's avatar
redflo committed
22
}
23
if (version_compare(PHP_VERSION, '5.5.0', '<') && php_sapi_name() != 'cli') {
24
	header('location: tiki-install.php');
changi67's avatar
changi67 committed
25
	exit;
26 27 28
} elseif (version_compare(PHP_VERSION, '5.5.0', '<') && php_sapi_name() == 'cli') {
	// This is command-line. No 'location' command make sense here. Let admins access what works and deal with the rest.
	echo "Warning: Tiki13 and above expects PHP 5.5.0 and above. You are running " . phpversion() . " at your own risk\n";
campbe13's avatar
campbe13 committed
29
}
30 31 32 33

// Be sure that the user is not already defined by PHP on hosts that still have the php.ini config "register_globals = On"
unset($user);

34
require_once 'lib/setup/third_party.php';
35 36 37
// Enable Versioning
include_once ('lib/setup/twversion.class.php');
$TWV = new TWVersion();
38 39 40 41 42
$num_queries = 0;
$elapsed_in_db = 0.0;
$server_load = '';
$area = 'tiki';
$crumbs = array();
changi67's avatar
changi67 committed
43 44
require_once ('lib/setup/tikisetup.class.php');
require_once ('lib/setup/timer.class.php');
45 46
$tiki_timer = new timer();
$tiki_timer->start();
changi67's avatar
changi67 committed
47
require_once ('tiki-setup_base.php');
48 49

// Attempt setting locales. This code is just a start, locales should be set per-user.
50
// Also, different operating systems use different locale strings. en_US.utf8 is valid on POSIX systems, maybe not on Windows, feel free to add alternative locale strings.
51
setlocale(LC_ALL, ''); // Attempt changing the locale to the system default.
52
// Since the system default may not be UTF-8 but we may be dealing with multilingual content, attempt ensuring the collations are intelligent by forcing a general UTF-8 collation.
53
// This will have no effect if the locale string is not valid or if the designated locale is not generated.
54

55
foreach (array('en_US.utf8') as $UnicodeLocale) {
56 57 58 59
	if (setlocale(LC_COLLATE, $UnicodeLocale)) {
		break;
	}
}
60

61 62 63
if ($prefs['feature_tikitests'] == 'y') {
	require_once ('tiki_tests/tikitestslib.php');
}
64
$crumbs[] = new Breadcrumb($prefs['browsertitle'], '', $prefs['tikiIndex']);
65 66 67
if ($prefs['site_closed'] == 'y') {
	require_once ('lib/setup/site_closed.php');
}
changi67's avatar
changi67 committed
68
require_once ('lib/setup/error_reporting.php');
69 70 71
if ($prefs['use_load_threshold'] == 'y') {
	require_once ('lib/setup/load_threshold.php');
}
changi67's avatar
changi67 committed
72
require_once ('lib/setup/sections.php');
73
$headerlib = TikiLib::lib('header');
74

75
$domain_map = array();
76 77 78 79 80 81 82 83 84 85
if ( isset($_SERVER['HTTP_HOST']) ) {
	$host = $_SERVER['HTTP_HOST'];
} else {
	$host = "";
}
if ( isset($_SERVER['REQUEST_URI']) ) {
	$requestUri = $_SERVER['REQUEST_URI'];
} else {
	$requestUri = "";
}
86

87 88
if ( $prefs['tiki_domain_prefix'] == 'strip' && substr($host, 0, 4) == 'www.' ) {
	$domain_map[$host] = substr($host, 4);
89
} elseif ( $prefs['tiki_domain_prefix'] == 'force' && substr($host, 0, 4) != 'www.' ) {
90 91
	$domain_map[$host] = 'www.' . $host;
}
92

93
if (strpos($prefs['tiki_domain_redirects'], ',') !== false) {
94
	foreach (explode("\n", $prefs['tiki_domain_redirects']) as $row) {
95 96
		list($old, $new) = array_map('trim', explode(',', $row, 2));
		$domain_map[$old] = $new;
97
	}
98 99
	unset($old);
	unset($new);
100 101
}

102
if ( isset($domain_map[$host]) ) {
103
	$prefix = $tikilib->httpPrefix();
104
	$prefix = str_replace("://$host", "://{$domain_map[$host]}", $prefix);
105
	$url = $prefix . $requestUri;
106

107
	$access->redirect($url, null, 301);
108 109 110
	exit;
}

111 112 113
if (isset($_REQUEST['PHPSESSID'])) {
	$tikilib->setSessionId($_REQUEST['PHPSESSID']);
}
changi67's avatar
changi67 committed
114
elseif (function_exists('session_id')) $tikilib->setSessionId(session_id());
115

116 117 118 119 120
// Session info needs to be kept up to date if pref login_multiple_forbidden is set
if ( $prefs['login_multiple_forbidden'] == 'y' ) {
	$tikilib->update_session();
}

121 122
require_once ('lib/setup/cookies.php');

123
if ($prefs['mobile_feature'] === 'y') {
124
	require_once ('lib/setup/mobile.php');	// needs to be before js_detect but after cookies
125 126
} else {
	$prefs['mobile_mode'] = '';
127 128
}

changi67's avatar
changi67 committed
129 130
require_once ('lib/setup/user_prefs.php');
require_once ('lib/setup/language.php');
131
require_once ('lib/setup/javascript.php');
changi67's avatar
changi67 committed
132
require_once ('lib/setup/wiki.php');
133 134 135 136 137

/* Cookie consent setup, has to be after the JS decision and wiki setup */

$cookie_consent_html = '';
if ($prefs['cookie_consent_feature'] === 'y') {
138
	if (!empty($_REQUEST['cookie_consent_checkbox']) || $prefs['site_closed'] === 'y') {
139
		// js disabled
140 141 142 143 144 145 146 147 148 149
		$feature_no_cookie = false;
		setCookieSection($prefs['cookie_consent_name'], 'y');
	}
	$cookie_consent = getCookie($prefs['cookie_consent_name']);
	if (empty($cookie_consent)) {
		if ($prefs['javascript_enabled'] !== 'y') {
			$prefs['cookie_consent_mode'] = '';
		} else {
			$headerlib->add_js('jqueryTiki.no_cookie = true; jqueryTiki.cookie_consent_alert = "' . addslashes($prefs['cookie_consent_alert']) . '";');
		}
150
		foreach ($_COOKIE as $k => $v) {
151 152
			setcookie($k, '', time() - 3600);		// unset any previously existing cookies
		}
153 154 155 156 157 158 159
		$cookie_consent_html = $smarty->fetch('cookie_consent.tpl');
	} else {
		$feature_no_cookie = false;
	}
}
$smarty->assign('cookie_consent_html', $cookie_consent_html);

160 161 162 163 164 165
if ($prefs['feature_polls'] == 'y') {
	require_once ('lib/setup/polls.php');
}
if ($prefs['feature_mailin'] == 'y') {
	require_once ('lib/setup/mailin.php');
}
166
require_once ('lib/setup/tikiIndex.php');
167 168 169
if ($prefs['useGroupHome'] == 'y') {
	require_once ('lib/setup/default_homepage.php');
}
170 171

// change $prefs['tikiIndex'] if feature_sefurl is enabled (e.g. tiki-index.php?page=HomePage becomes HomePage)
172
if ($prefs['feature_sefurl'] == 'y' && ! defined('TIKI_CONSOLE')) {
173 174 175
	//TODO: need a better way to know which is the type of the tikiIndex URL (wiki page, blog, file gallery etc)
	//TODO: implement support for types other than wiki page and blog
	if ($prefs['tikiIndex'] == 'tiki-index.php' && $prefs['wikiHomePage']) {
lphuberdeau's avatar
lphuberdeau committed
176
		$wikilib = TikiLib::lib('wiki');
177
		$prefs['tikiIndex'] = $wikilib->sefurl($userlib->best_multilingual_page($prefs['wikiHomePage']));
178 179
	} else if (substr($prefs['tikiIndex'], 0, strlen('tiki-view_blog.php')) == 'tiki-view_blog.php') {
		include_once('tiki-sefurl.php');
180
		$prefs['tikiIndex'] = filter_out_sefurl($prefs['tikiIndex'], 'blog');
181
	}
182
}
183

changi67's avatar
changi67 committed
184 185
require_once ('lib/setup/theme.php');
if (!empty($varcheck_errors)) {
186
	$smarty->assign('msg', $varcheck_errors);
187
	$smarty->display('error_raw.tpl');
188
	die;
189
}
changi67's avatar
changi67 committed
190 191 192
if ($prefs['feature_challenge'] == 'y') {
	require_once ('lib/setup/challenge.php');
}
193 194 195 196 197 198 199 200 201
if ($prefs['feature_usermenu'] == 'y') {
	require_once ('lib/setup/usermenu.php');
}
if ($prefs['feature_live_support'] == 'y') {
	require_once ('lib/setup/live_support.php');
}
if ($prefs['feature_referer_stats'] == 'y' || $prefs['feature_stats'] == 'y') {
	require_once ('lib/setup/stats.php');
}
changi67's avatar
changi67 committed
202 203 204
require_once ('lib/setup/dynamic_variables.php');
require_once ('lib/setup/output_compression.php');
if ($prefs['feature_debug_console'] == 'y') {
205 206 207
	// Include debugger class declaration. So use loggin facility in php files become much easier :)
	include_once ('lib/debug/debugger.php');
}
208 209 210 211 212 213 214 215 216
if ($prefs['feature_integrator'] == 'y') {
	require_once ('lib/setup/integrator.php');
}
if (isset($_REQUEST['comzone'])) {
	require_once ('lib/setup/comments_zone.php');
}
if ($prefs['feature_lastup'] == 'y') {
	require_once ('lib/setup/last_update.php');
}
changi67's avatar
changi67 committed
217
if (!empty($_SESSION['interactive_translation_mode']) && ($_SESSION['interactive_translation_mode'] == 'on')) {
218
	$cachelib->empty_cache('templates_c');
219
}
220 221 222
if ($prefs['feature_freetags'] == 'y') {
	require_once ('lib/setup/freetags.php');
}
223
if ($prefs['feature_areas'] == 'y' && $prefs['feature_categories'] == 'y' && $prefs['categories_used_in_tpl'] == 'y') {
224
	require_once ('lib/setup/categories.php');
225
	$areaslib = TikiLib::lib('areas');
226
	$areaslib->HandleObjectCategories($objectCategoryIdsNoJail);
227 228
} elseif ($prefs['feature_categories'] == 'y') {
	require_once ('lib/setup/categories.php');
oeversetten's avatar
 
oeversetten committed
229
}
230 231 232 233 234 235
if ($prefs['feature_userlevels'] == 'y') {
	require_once ('lib/setup/userlevels.php');
}
if ($prefs['auth_method'] == 'openid') {
	require_once ('lib/setup/openid.php');
}
changi67's avatar
changi67 committed
236
if ($prefs['feature_wysiwyg'] == 'y') {
237 238 239
	if (!isset($_SESSION['wysiwyg'])) {
		$_SESSION['wysiwyg'] = 'n';
	}
240
	$smarty->assign_by_ref('wysiwyg', $_SESSION['wysiwyg']);
241
}
242

243

244 245 246 247
if ($prefs['feature_antibot'] == 'y' && empty($user)) {
	if ($prefs['recaptcha_enabled'] === 'y') {
		$headerlib->add_jsfile('https://www.google.com/recaptcha/api/js/recaptcha_ajax.js');
	}
248 249
	$captchalib = TikiLib::lib('captcha');
	$smarty->assign('captchalib', $captchalib);
250
}
251

252 253 254 255
if ($prefs['feature_credits'] == 'y') {
	require_once('lib/setup/credits.php');
}

256
if ( $prefs['https_external_links_for_users'] == 'y' ) {
257
	$base_url_canonical_default = $base_url_https;
258
} else {
259 260 261 262 263 264 265
	$base_url_canonical_default = $base_url_http;
}

if ( !empty($prefs['feature_canonical_domain']) ) {
	$base_url_canonical = $prefs['feature_canonical_domain'];
} else {
	$base_url_canonical = $base_url_canonical_default;
266
}
267 268 269 270
// Since it's easier to be error-resistant than train users, ensure base_url_canonical ends with '/'
if ( substr($base_url_canonical,-1) != '/' ) {
	$base_url_canonical .= '/';
}
271

272 273 274 275 276
$smarty->assign_by_ref('phpErrors', $phpErrors);
$smarty->assign_by_ref('num_queries', $num_queries);
$smarty->assign_by_ref('elapsed_in_db', $elapsed_in_db);
$smarty->assign_by_ref('crumbs', $crumbs);
$smarty->assign('lock', false);
277 278 279
$smarty->assign('edit_page', 'n');
$smarty->assign('forum_mode', 'n');
$smarty->assign('uses_tabs', 'n');
280
$smarty->assign('wiki_extras', 'n');
281 282 283 284 285 286
$smarty->assign('tikipath', $tikipath);
$smarty->assign('tikiroot', $tikiroot);
$smarty->assign('url_scheme', $url_scheme);
$smarty->assign('url_host', $url_host);
$smarty->assign('url_port', $url_port);
$smarty->assign('url_path', $url_path);
287
$smarty->assign('dir_level', $dir_level);
288 289 290 291
$smarty->assign('base_host', $base_host);
$smarty->assign('base_url', $base_url);
$smarty->assign('base_url_http', $base_url_http);
$smarty->assign('base_url_https', $base_url_https);
292
$smarty->assign('base_url_canonical', $base_url_canonical);
293
$smarty->assign('base_url_canonical_default', $base_url_canonical_default);
294 295
$smarty->assign('show_stay_in_ssl_mode', $show_stay_in_ssl_mode);
$smarty->assign('stay_in_ssl_mode', $stay_in_ssl_mode);
296 297
$smarty->assign('tiki_version', $TWV->version);
$smarty->assign('tiki_branch', $TWV->branch);
298
$smarty->assign('tiki_star', $TWV->getStar());
299
$smarty->assign('tiki_uses_svn', $TWV->svn);
300

301 302
$smarty->assign('symbols', TikiLib::symbols());

303 304 305 306
if ( isset( $_GET['msg'] ) ) {
	$smarty->assign('display_msg', $_GET['msg']);
} elseif ( isset( $_SESSION['msg'] ) ) {
	$smarty->assign('display_msg', $_SESSION['msg']);
307 308
	unset($_SESSION['msg']);
} else {
309
	$smarty->assign('display_msg', '');
310 311
}

312 313
require_once 'lib/setup/events.php';

314
if ( $prefs['rating_advanced'] == 'y' && $prefs['rating_recalculation'] == 'randomload' ) {
lphuberdeau's avatar
lphuberdeau committed
315
	$ratinglib = TikiLib::lib('rating');
316 317 318
	$ratinglib->attempt_refresh();
}

319
$headerlib->add_jsfile('lib/tiki-js.js');
320

321
// using jquery-migrate-1.2.1.js plugin for tiki 11, still required in tiki 12 LTS to support some 3rd party plugins
322

323 324
if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'google' ) {
	$headerlib->add_jsfile_dependancy("$url_scheme://ajax.googleapis.com/ajax/libs/jquery/$headerlib->jquery_version/jquery.min.js");
325
	$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate-min/jquery-migrate-1.2.1.min.js");
326
} else if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
327 328
	$headerlib->add_jsfile_dependancy("//code.jquery.com/jquery-$headerlib->jquery_version.min.js");
	$headerlib->add_jsfile_dependancy("//code.jquery.com/jquery-migrate-1.2.1.min.js");
329 330
} else {
	if ( $prefs['tiki_minify_javascript'] === 'y' ) {
Jonny Bradley's avatar
Jonny Bradley committed
331
		$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-min/jquery-$headerlib->jquery_version.min.js");
332
		$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate-min/jquery-migrate-1.2.1.min.js");
333
	} else {
334
		$headerlib->add_jsfile_dependancy("vendor/jquery/jquery/jquery-$headerlib->jquery_version.js");
335
		$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate/jquery-migrate-1.2.1.js");
336
	}
337
}
338

339
if ( $prefs['fgal_elfinder_feature'] === 'y' ) {
340
	$str = $prefs['tiki_minify_javascript'] === 'y' ? 'min' : 'full';
341 342
	$headerlib->add_jsfile('vendor_extra/elfinder/js/elfinder.' . $str . '.js')
			->add_cssfile('vendor_extra/elfinder/css/elfinder.' . $str . '.css')
343 344 345 346 347 348 349
			->add_jsfile('lib/jquery_tiki/elfinder/tiki-elfinder.js');

	$elFinderLang = str_replace(array('cn', 'pt-br'), array('zh_CN', 'pt_BR'), $language);

	if (file_exists('vendor_extra/elfinder/js/i18n/elfinder.' . $elFinderLang . '.js')) {
		$headerlib->add_jsfile('vendor_extra/elfinder/js/i18n/elfinder.' . $elFinderLang . '.js');
	}
350
}
351

352
$headerlib->add_jsfile('lib/jquery_tiki/tiki-jquery.js');
353

354 355 356 357 358 359
if (isset($_REQUEST['geo_zoomlevel_to_found_location'])) {
	$zoomToFoundLocation = $_REQUEST['geo_zoomlevel_to_found_location'];
} else {
	$zoomToFoundLocation = isset($prefs['geo_zoomlevel_to_found_location']) ? $prefs['geo_zoomlevel_to_found_location'] : 'street';
}
$headerlib->add_js('var zoomToFoundLocation = "'.$zoomToFoundLocation.'";');	// Set the zoom option after searching for a location
360

361
$headerlib->add_jsfile('lib/jquery_tiki/tiki-maps.js');
362
$headerlib->add_jsfile('vendor/jquery/plugins/jquery-json/src/jquery.json.js');
363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384

if ($prefs['feature_jquery_zoom'] === 'y') {
	$headerlib->add_jsfile('vendor/jquery/plugins/zoom/jquery.zoom.js')
		->add_css('
.img_zoom {
	display:inline-block;
}
.img_zoom:after {
	content:"";
	display:block;
	width:33px;
	height:33px;
	position:absolute;
	top:0;
	right:0;
	background:url(vendor/jquery/plugins/zoom/icon.png);
}
.img_zoom img {
	display:block;
}
');
}
385

386 387 388
if ($prefs['feature_syntax_highlighter'] == 'y') {
	//add codemirror stuff
	$headerlib
389 390
		->add_cssfile('vendor/codemirror/codemirror/lib/codemirror.css')
		->add_jsfile_dependancy('vendor/codemirror/codemirror/lib/codemirror.js')
391
		->add_jsfile('vendor/codemirror/codemirror/addon/search/searchcursor.js', 3)
392
		->add_jsfile('vendor/codemirror/codemirror/addon/mode/overlay.js')
393 394
	//add tiki stuff
		->add_cssfile('lib/codemirror_tiki/codemirror_tiki.css')
395
		->add_jsfile('lib/codemirror_tiki/codemirror_tiki.js', 5);
396

397 398 399
	require_once("lib/codemirror_tiki/tiki_codemirror.php");
	codemirrorModes($prefs['tiki_minify_javascript'] === 'y');
}
400
if ($prefs['feature_wikilingo'] == 'y') {
401 402 403 404
	$headerlib
		//flp stuff
		->add_cssfile('vendor/jquery/plugins/tablesorter/css/theme.dropbox.css')
		->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.js');
405 406
}

407 408 409
if ( $prefs['feature_jquery_carousel'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/infinitecarousel/jquery.infinitecarousel3.js');
}
410

411
if ( $prefs['feature_ajax'] === 'y' ) {
412
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-ajax_services.js');
413 414
	if ( $prefs['ajax_autosave'] === 'y' ) {
		$headerlib->add_jsfile('lib/ajax/autosave.js');
415
	}
416
}
417

418 419 420 421 422 423 424
if ( $prefs['feature_jquery_ui'] == 'y' ) {
	if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'google' ) {
		$headerlib->add_jsfile_dependancy("$url_scheme://ajax.googleapis.com/ajax/libs/jqueryui/$headerlib->jqueryui_version/jquery-ui.min.js");
	} else if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
		$headerlib->add_jsfile_dependancy("//code.jquery.com/ui/$headerlib->jqueryui_version/jquery-ui.min.js");
	} else {
		if ( $prefs['tiki_minify_javascript'] === 'y' ) {
425
			$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-ui/jquery-ui.min.js");
426
		} else {
427
			$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-ui/jquery-ui.js");
428
		}
429
	}
430

431 432 433
	if ( $prefs['feature_jquery_ui_theme'] !== 'none' ) {
		if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
			$headerlib->add_cssfile("//code.jquery.com/ui/$headerlib->jqueryui_version/themes/{$prefs['feature_jquery_ui_theme']}/jquery-ui.css");
434
		} else {
435
			$headerlib->add_cssfile('vendor/jquery/jquery-ui-themes/themes/' . $prefs['feature_jquery_ui_theme'] . '/jquery-ui.css');
436
		}
437
	}
438

439 440 441 442 443 444 445
	if ( $prefs['feature_jquery_autocomplete'] == 'y' ) {
		$headerlib->add_css(
			'.ui-autocomplete-loading { background: white url("img/spinner.gif") right center no-repeat; }'
		);
	}
	if ( $prefs['jquery_ui_chosen'] == 'y' ) {
		$headerlib->add_jsfile('vendor/jquery/plugins/chosen/chosen.jquery.js');
446
	//	$headerlib->add_cssfile('vendor/jquery/plugins/chosen/chosen.css'); Replaced by github.com/alxlit/bootstrap-chosen
447 448 449
		$headerlib->add_css(
			'select { font-size: 16px; padding: 4px; border-color:#fff; /* this forces chrome to apply the font-size */ }'
		);
450
	}
451 452 453
	$headerlib->add_jsfile('vendor/jquery/jquery-timepicker-addon/dist/jquery-ui-timepicker-addon.js');
	$headerlib->add_cssfile('vendor/jquery/jquery-timepicker-addon/dist/jquery-ui-timepicker-addon.css');
}
454

455 456 457 458 459 460 461 462 463 464 465 466 467 468
if ( $prefs['feature_jquery_superfish'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/superfish/dist/js/superfish.js');
	$headerlib->add_jsfile('vendor/jquery/plugins/superfish/dist/js/supersubs.js');
}
if ( $prefs['feature_jquery_tooltips'] === 'y' || $prefs['feature_jquery_superfish'] === 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/superfish/dist/js/hoverIntent.js');
}
if ( $prefs['feature_jquery_reflection'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/reflection-jquery/js/reflection.js');
}
if ( $prefs['feature_jquery_media'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/media/jquery.media.js');
}
if ( $prefs['feature_jquery_tablesorter'] == 'y' ) {
469 470
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.js');
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.widgets.js');
471
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-pager.js');
472 473
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-filter-formatter-jui.js');
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-grouping.js');
474
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-columnSelector.js');
475 476 477 478 479 480
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/parsers/parser-input-select.js');
}
if ( $prefs['feature_shadowbox'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/colorbox/jquery.colorbox.js');
	$headerlib->add_cssfile('vendor/jquery/plugins/colorbox/' . $prefs['jquery_colorbox_theme'] . '/colorbox.css');
}
481

482 483 484 485 486 487 488
if ( $prefs['wikiplugin_flash'] == 'y' ) {
	$headerlib->add_jsfile('lib/swfobject/swfobject.js');
}

// include and setup themegen editor if already open
if (! empty($tiki_p_admin) && $tiki_p_admin === 'y' && !empty($prefs['themegenerator_feature']) && $prefs['themegenerator_feature'] === 'y' && !empty($_COOKIE['themegen']) &&
		(strpos($_SERVER['SCRIPT_NAME'], 'tiki-admin.php') === false || strpos($_SERVER['QUERY_STRING'], 'page=look') === false)) {
489
	$themegenlib = TikiLib::lib('themegenerator');
490 491
	$themegenlib->setupEditor();
}
492 493

if ( $prefs['feature_jquery_validation'] == 'y' ) {
494
	$headerlib->add_jsfile('vendor/jquery/plugins/jquery-validation/dist/jquery.validate.js');
495
	$headerlib->add_jsfile('lib/validators/validator_tiki.js');
496 497
}

Jonny Bradley's avatar
Jonny Bradley committed
498
$headerlib->add_jsfile('vendor/jquery/plugins/async/jquery.async.js', 10);
499 500
$headerlib->add_jsfile('vendor/jquery/plugins/treetable/javascripts/src/jquery.treetable.js');
$headerlib->add_cssfile('vendor/jquery/plugins/treetable/stylesheets/jquery.treetable.css');
501

502 503
$headerlib->add_jsfile('vendor/cwspear/bootstrap-hover-dropdown/bootstrap-hover-dropdown.js');

504 505 506 507 508 509 510
if (empty($user) && $prefs['feature_antibot'] == 'y') {
	$headerlib->add_jsfile('lib/captcha/captchalib.js');
}

if ( $prefs['feature_jcapture'] === 'y' ) {
	$headerlib->add_jsfile('lib/jcapture_tiki/tiki-jcapture.js');
}
511

512
if ( ! empty( $prefs['header_custom_css'] ) ) {
513
	$headerlib->add_css($prefs['header_custom_css']);
514 515
}

516
if ( ! empty( $prefs['header_custom_js'] ) ) {
517
	$headerlib->add_js($prefs['header_custom_js']);
518 519
}

520 521 522 523
if ($prefs['feature_file_galleries'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/files.js');
}

524 525
if ($prefs['feature_trackers'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-trackers.js');
526 527 528

	if ($prefs['feed_tracker'] === 'y') {
		$opts = TikiLib::lib('trk')->get_trackers_options(null, 'publishRSS', 'y');
529
		foreach ($opts as & $o) {
530 531 532 533 534
			$o = $o['trackerId'];
		}
		$trackers = TikiLib::lib('trk')->list_trackers();

		$rss_trackers = array();
535
		foreach ($trackers['data'] as $trk) {
536 537 538 539 540 541 542 543 544 545
			if (in_array($trk['trackerId'], $opts)) {
				$rss_trackers[] = array(
					'trackerId' => $trk['trackerId'],
					'name' => $trk['name'],
				);
			}
		}
		TikiLib::lib('smarty')->assign('rsslist_trackers', $rss_trackers);
	}

546 547
}

548
if ($prefs['feature_draw'] == 'y') {
549 550
	//svg-edit/empbedapi.js neededs to be external - why?
	$headerlib->add_jsfile("vendor/svg-edit/svg-edit/embedapi.js");
551 552 553 554
	$headerlib->add_jsfile("lib/svg-edit_tiki/draw.js");
	$headerlib->add_cssfile("lib/svg-edit_tiki/draw.css");
}

555 556 557 558
if ($prefs['geo_always_load_openlayers'] == 'y') {
	$headerlib->add_map();
}

559 560 561 562
if ($prefs['workspace_ui'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-workspace-ui.js');
}

563
if ($prefs['feature_sefurl'] != 'y') {
564
	$headerlib->add_js(
565
		'$.service = function (controller, action, query) {
566 567 568 569 570
		if (! query) {
			query = {};
		}
		query.controller = controller;

571
		if (action) {
572
			query.action = action;
573
		}
574

575
		return "tiki-ajax_services.php?" + $.buildParams(query);
576
	};'
577
	);
578 579
}

580
if ($prefs['feature_friends'] == 'y' || $prefs['monitor_enabled'] == 'y') {
581 582 583
	$headerlib->add_jsfile('lib/jquery_tiki/social.js');
}

584 585 586 587
if ($prefs['ajax_inline_edit'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/inline_edit.js');
}

588 589 590 591
if ($prefs['mustread_enabled'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/mustread.js');
}

592 593 594 595 596 597 598 599 600
if (true) {
	// Before being clever and moving this close to where you think it's needed (again),
	// consider there are more places that you think.
	$headerlib->add_jsfile('tiki-jsplugin.php?language='.$prefs['language'], 'dynamic');
	if ($prefs['wikiplugin_module'] === 'y' && $prefs['wikiplugininline_module'] === 'n') {
		$headerlib->add_jsfile('tiki-jsmodule.php?language='.$prefs['language'], 'dynamic');
	}
}

601 602
if ( session_id() ) {
	if ( $prefs['tiki_cachecontrol_session'] ) {
603
		header('Cache-Control: ' . $prefs['tiki_cachecontrol_session']);
604 605
	}
} else {
606
	if ( $prefs['tiki_cachecontrol_nosession'] ) {
607
		header('Cache-Control: ' . $prefs['tiki_cachecontrol_nosession']);
608 609
	}
}
610

611 612 613 614 615 616 617 618
if ( !empty($prefs['access_control_allow_origin']) && !empty($_SERVER['HTTP_ORIGIN']) && $base_host !== $_SERVER['HTTP_ORIGIN']) {
	$http_origin = $_SERVER['HTTP_ORIGIN'];

	if (in_array($http_origin, preg_split('/[\s,]+/', $prefs['access_control_allow_origin']))) {
	    header("Access-Control-Allow-Origin: $http_origin");
	}
}

619 620 621 622 623 624
if ( isset($token_error) ) {
	$smarty->assign('token_error', $token_error);
	$smarty->display('error.tpl');
	die;
}

625 626
require_once( 'lib/setup/plugins_actions.php' );

627
if ($tiki_p_admin == 'y') {
628
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-admin.js');
629 630
}

631 632 633 634
if ($prefs['wikiplugin_addtocart'] == 'y') {
	$headerlib->add_jsfile('lib/payment/cartlib.js');
}

635
//////////////////////////////////////////////////////////////////////////
kstingel's avatar
kstingel committed
636 637 638 639 640 641 642 643 644 645 646
// ******************************************************************** //
// ** IMPORTANT NOTE:                                                ** //
// ** USE THE GLOBAL VARIABLE BELOW TO CONTROL THE VERSION OF EMAIL  ** //
// ** WHICH IS USED                                                  ** //
// **   $prefs['openpgp_gpg_pgpmimemail'] == 'y'                     ** //
// **       USE TIKI OpenPGP Enabled PGP/MIME-standard mail          ** //
// **   $prefs['openpgp_gpg_pgpmimemail'] == 'n'                     ** //
// **       USE TIKI normal mail functionality                       ** //
// **                                                                ** //
// ** SETTING THIS PREFERENCES VARIABLE TO "y" NEED PROPER           ** //
// ** CONFIGURATION OF gnupg AND RELATED KEYRING WITH PROPERLY       ** //
647
// ** CONFIGURED TIKI-SENDER KEYPAIR (PRIVATE/PUBLIC) AND ALL USER   ** //
kstingel's avatar
kstingel committed
648 649 650
// ** ACCOUNT-RELATED PUBLIC KEYS                                    ** //
// **                                                                ** //
// ** DO NOT SWITCH THIS VARIABLE TO TRUE FOR THIS EXPERIMENTAL      ** //
651
// ** FULLY PGP/MIME-ENCRYPTION COMPLIANT EMAIL FUNCTIONALITY, IF    ** //
kstingel's avatar
kstingel committed
652 653 654
// ** YOU ARE **NOT ABSOLUTE SURE HOW TO CONFIGURE IT**!             ** //
// **                                                                ** //
// ** ONCE PROPERLY CONFIGURED, SUCH 100% OPAQUE FUNCTIONALITY       ** //
655
// ** DELIVERS ROBUST END-TO-END PRIVACY WITH HIGH DEGREE OF TESTED  ** //
kstingel's avatar
kstingel committed
656 657 658 659 660 661
// ** ROBUSTNESS FOR THE FOLLOWING MAIL TRAFFIC:                     ** //
// **                                                                ** //
// **   - all webmail-based messaging from messu-compose.php         ** //
// **   - all admin notifications                                    ** //
// **   - all newsletters                                            ** //
// **                                                                ** //
662 663 664 665
// ** PLEASE NOTE THAT ALL SITE ACCOUNTS **MUST** HAVE PROPERLY	     ** //
// ** CONFIGURED OpenPGP-COMPLIANT PUBLIC-KEY IN THE SYSTEM's	     ** //
// ** KEYRING, SO IT IS NOT THEN WISE/POSSIBLE TO ALLOW ANONYMOUS    ** //
// ** SUBSCRIPTIONS TO NEWSLETTERS ETC, OR USE NOT FULLY PGP/MIME    ** //
kstingel's avatar
kstingel committed
666 667 668 669 670
// ** READY ACCOUNTS IN SUCH SYSTEM.                                 ** //
// **                                                                ** //
// ** IT IS ASSUMED, THAT IF AND WHEN YOU TURN SUCH PGP/MIME ON      ** //
// ** YOU ARE FULLY AWARE OF THE REQUIREMENTS AND CONSEQUENCES.      ** //
// **                                                                ** //
671
if ($prefs['openpgp_gpg_pgpmimemail'] == 'y') {
672 673 674 675
	// hollmeer 2012-11-03:
	// TURNED ON openPGP support from a lib based class
	require_once( 'lib/openpgp/openpgplib.php' );
}
kstingel's avatar
kstingel committed
676 677
// **                                                                ** //
// ******************************************************************** //
678 679
//////////////////////////////////////////////////////////////////////////

680
if( $prefs['feature_hidden_links'] == 'y' && isset($jitRequest['wysiwyg']) && $jitRequest['wysiwyg'] != 'y') {
681 682 683 684 685 686
	$headerlib->add_js("$('body').find('h1, h2, h3, h4, h5, h6').each(function() {
	var headerid = $(this).attr('id');
		if(headerid != undefined) {
			$(this).append('<a class=\"tiki_anchor\" href=\"#'+headerid+'\"></a>');
		}
	});");
687 688 689 690 691
}

$headerlib->lockMinifiedJs();

if ( $prefs['conditions_enabled'] == 'y' ) {
692 693 694 695 696 697
	if (! Services_User_ConditionsController::hasRequiredAge($user)) {
		$servicelib = TikiLib::lib('service');
		$broker = $servicelib->getBroker();
		$broker->process('user_conditions', 'age_validation', $jitRequest);
		exit;
	}
698 699 700 701 702 703 704
	if (Services_User_ConditionsController::requiresApproval($user)) {
		$servicelib = TikiLib::lib('service');
		$broker = $servicelib->getBroker();
		$broker->process('user_conditions', 'approval', $jitRequest);
		exit;
	}
}