tiki-setup.php 28.9 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
		setCookieSection($prefs['cookie_consent_name'], 'y');	// set both real cookie and tiki_cookie_jar
141 142 143 144 145 146 147 148 149 150
		$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']) . '";');
		}
151
		foreach ($_COOKIE as $k => $v) {
152 153 154
			if (strpos($k, session_name()) === false) {
				setcookie($k, '', time() - 3600);        // unset any previously existing cookies except the session
			}
155
		}
156 157 158 159 160 161 162
		$cookie_consent_html = $smarty->fetch('cookie_consent.tpl');
	} else {
		$feature_no_cookie = false;
	}
}
$smarty->assign('cookie_consent_html', $cookie_consent_html);

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

// change $prefs['tikiIndex'] if feature_sefurl is enabled (e.g. tiki-index.php?page=HomePage becomes HomePage)
175
if ($prefs['feature_sefurl'] == 'y' && ! defined('TIKI_CONSOLE')) {
176 177 178
	//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
179
		$wikilib = TikiLib::lib('wiki');
180
		$prefs['tikiIndex'] = $wikilib->sefurl($userlib->best_multilingual_page($prefs['wikiHomePage']));
181 182
	} else if (substr($prefs['tikiIndex'], 0, strlen('tiki-view_blog.php')) == 'tiki-view_blog.php') {
		include_once('tiki-sefurl.php');
183
		$prefs['tikiIndex'] = filter_out_sefurl($prefs['tikiIndex'], 'blog');
184
	}
185
}
186

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

246

247 248
if ($prefs['feature_antibot'] == 'y' && empty($user)) {
	if ($prefs['recaptcha_enabled'] === 'y') {
249
		$headerlib->add_jsfile_cdn("$url_scheme://www.google.com/recaptcha/api/js/recaptcha_ajax.js");
250
	}
251 252
	$captchalib = TikiLib::lib('captcha');
	$smarty->assign('captchalib', $captchalib);
253
}
254

255 256 257 258
if ($prefs['feature_credits'] == 'y') {
	require_once('lib/setup/credits.php');
}

259
if ( $prefs['https_external_links_for_users'] == 'y' ) {
260
	$base_url_canonical_default = $base_url_https;
261
} else {
262 263 264 265 266 267 268
	$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;
269
}
270 271 272 273
// 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 .= '/';
}
274

275 276 277 278 279
$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);
280 281 282
$smarty->assign('edit_page', 'n');
$smarty->assign('forum_mode', 'n');
$smarty->assign('uses_tabs', 'n');
283
$smarty->assign('wiki_extras', 'n');
284 285 286 287 288 289
$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);
290
$smarty->assign('dir_level', $dir_level);
291 292 293 294
$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);
295
$smarty->assign('base_url_canonical', $base_url_canonical);
296
$smarty->assign('base_url_canonical_default', $base_url_canonical_default);
297 298
$smarty->assign('show_stay_in_ssl_mode', $show_stay_in_ssl_mode);
$smarty->assign('stay_in_ssl_mode', $stay_in_ssl_mode);
299 300
$smarty->assign('tiki_version', $TWV->version);
$smarty->assign('tiki_branch', $TWV->branch);
301
$smarty->assign('tiki_star', $TWV->getStar());
302
$smarty->assign('tiki_uses_svn', $TWV->svn);
303

304 305
$smarty->assign('symbols', TikiLib::symbols());

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

315 316 317 318 319 320 321 322 323
if ( isset( $_GET['msgtype'] ) ) {
	$smarty->assign('display_msgtype', $_GET['msgtype']);
} elseif ( isset( $_SESSION['msgtype'] ) ) {
	$smarty->assign('display_msgtype', $_SESSION['msgtype']);
	unset($_SESSION['msgtype']);
} else {
	$smarty->assign('display_msgtype', '');
}

324 325
require_once 'lib/setup/events.php';

326
if ( $prefs['rating_advanced'] == 'y' && $prefs['rating_recalculation'] == 'randomload' ) {
lphuberdeau's avatar
lphuberdeau committed
327
	$ratinglib = TikiLib::lib('rating');
328 329 330
	$ratinglib->attempt_refresh();
}

331
$headerlib->add_jsfile('lib/tiki-js.js');
332

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

335
if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'google' ) {
336 337 338
	$headerlib->add_jsfile_cdn("$url_scheme://ajax.googleapis.com/ajax/libs/jquery/$headerlib->jquery_version/jquery.min.js");
	// goggle is not hosting migrate so load from local
	$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate-min/jquery-migrate-1.2.1.min.js", true);
339
} else if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
340 341
	$headerlib->add_jsfile_cdn("$url_scheme://code.jquery.com/jquery-$headerlib->jquery_version.min.js");
	$headerlib->add_jsfile_cdn("$url_scheme://code.jquery.com/jquery-migrate-1.2.1.min.js");
342
} else {
343 344 345
	if ( isset($prefs['tiki_minify_javascript']) && $prefs['tiki_minify_javascript'] === 'y' ) {
		$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-min/jquery-$headerlib->jquery_version.min.js", true);
		$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate-min/jquery-migrate-1.2.1.min.js", true);
346
	} else {
347 348
		$headerlib->add_jsfile_dependancy("vendor/jquery/jquery/jquery-$headerlib->jquery_version.js", true);
		$headerlib->add_jsfile_dependancy("vendor/jquery/plugins/migrate/jquery-migrate-1.2.1.js", true);
349
	}
350
}
351

352
if ( isset($prefs['fgal_elfinder_feature']) && $prefs['fgal_elfinder_feature'] === 'y' ) {
353
	$str = $prefs['tiki_minify_javascript'] === 'y' ? 'min' : 'full';
354 355 356
	// elfinder is sensible to js compression - problem is inside elfinder
	// see http://stackoverflow.com/questions/11174170/js-invalid-left-hand-side-expression-in-postfix-operation for more general details
	$headerlib->add_jsfile('vendor_extra/elfinder/js/elfinder.' . $str . '.js', true)
357
			->add_cssfile('vendor_extra/elfinder/css/elfinder.' . $str . '.css')
358 359 360 361 362 363 364
			->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');
	}
365
}
366

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

369 370 371 372 373 374
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
375

376 377 378 379 380
if ($prefs['geo_openlayers_version'] === 'ol3') {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-maps-ol3.js');
} else {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-maps.js');
}
381
$headerlib->add_jsfile('vendor/jquery/plugins/jquery-json/src/jquery.json.js');
382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403

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;
}
');
}
404

405 406 407
if ($prefs['feature_syntax_highlighter'] == 'y') {
	//add codemirror stuff
	$headerlib
408 409
		->add_cssfile('vendor/codemirror/codemirror/lib/codemirror.css')
		->add_jsfile_dependancy('vendor/codemirror/codemirror/lib/codemirror.js')
410
		->add_jsfile('vendor/codemirror/codemirror/addon/search/searchcursor.js')
411
		->add_jsfile('vendor/codemirror/codemirror/addon/mode/overlay.js')
412 413
	//add tiki stuff
		->add_cssfile('lib/codemirror_tiki/codemirror_tiki.css')
414
		->add_jsfile('lib/codemirror_tiki/codemirror_tiki.js');
415

416
	require_once("lib/codemirror_tiki/tiki_codemirror.php");
417
	createCodemirrorModes();
418
}
419
if ($prefs['feature_wikilingo'] == 'y') {
420 421 422 423
	$headerlib
		//flp stuff
		->add_cssfile('vendor/jquery/plugins/tablesorter/css/theme.dropbox.css')
		->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.js');
424 425
}

426 427 428
if ( $prefs['feature_jquery_carousel'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/infinitecarousel/jquery.infinitecarousel3.js');
}
429

430
if ( $prefs['feature_ajax'] === 'y' ) {
431
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-ajax_services.js');
432 433
	if ( $prefs['ajax_autosave'] === 'y' ) {
		$headerlib->add_jsfile('lib/ajax/autosave.js');
434
	}
435
}
436

437 438
// $url_scheme is 'http' or 'https' depending on request type condsidering already a reverse proxy
// $https_mode is true / false depending on request type condsidering already a reverse proxy
439 440
if ( $prefs['feature_jquery_ui'] == 'y' ) {
	if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'google' ) {
441
		$headerlib->add_jsfile_cdn("$url_scheme://ajax.googleapis.com/ajax/libs/jqueryui/$headerlib->jqueryui_version/jquery-ui.min.js");
442
	} else if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
443
		$headerlib->add_jsfile_cdn("$url_scheme://code.jquery.com/ui/$headerlib->jqueryui_version/jquery-ui.min.js");
444 445
	} else {
		if ( $prefs['tiki_minify_javascript'] === 'y' ) {
446
			$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-ui/jquery-ui.min.js", true);
447
		} else {
448
			$headerlib->add_jsfile_dependancy("vendor/jquery/jquery-ui/jquery-ui.js");
449
		}
450
	}
451

452 453
	if ( $prefs['feature_jquery_ui_theme'] !== 'none' ) {
		if ( isset($prefs['javascript_cdn']) && $prefs['javascript_cdn'] == 'jquery' ) {
454 455 456
			// // cdn for css not working - this is the only css from a cdn anyway - so use local version 
			// $headerlib->add_cssfile("$url_scheme://code.jquery.com/ui/$headerlib->jqueryui_version/themes/{$prefs['feature_jquery_ui_theme']}/jquery-ui.css");
			$headerlib->add_cssfile('vendor/jquery/jquery-ui-themes/themes/' . $prefs['feature_jquery_ui_theme'] . '/jquery-ui.css');
457
		} else {
458
			$headerlib->add_cssfile('vendor/jquery/jquery-ui-themes/themes/' . $prefs['feature_jquery_ui_theme'] . '/jquery-ui.css');
459
		}
460
	}
461

462 463 464 465 466 467 468
	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');
469
	//	$headerlib->add_cssfile('vendor/jquery/plugins/chosen/chosen.css'); Replaced by github.com/alxlit/bootstrap-chosen
470 471 472
		$headerlib->add_css(
			'select { font-size: 16px; padding: 4px; border-color:#fff; /* this forces chrome to apply the font-size */ }'
		);
473
	}
474 475 476 477
	if ( $prefs['jquery_fitvidjs'] == 'y' ) {
		$headerlib->add_jsfile('vendor/jquery/plugins/fitvidjs/jquery.fitvids.js')
					->add_jq_onready('$("article").fitVids();');		// apply fitvid to any video in the middle section
	}
478 479 480
	$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');
}
481

482 483 484 485 486 487 488 489 490 491 492 493 494 495
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' ) {
496 497
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.js');
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/jquery.tablesorter.widgets.js');
498
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-pager.js');
499 500
	$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');
501
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/widgets/widget-columnSelector.js');
502 503
	$headerlib->add_jsfile('vendor/jquery/plugins/tablesorter/js/parsers/parser-input-select.js');
}
gezzzan's avatar
gezzzan committed
504 505 506 507 508

if ( $prefs['feature_jquery_tagcanvas'] == 'y' ) {
	$headerlib->add_jsfile('vendor/jquery/plugins/tagcanvas/jquery.tagcanvas.js');
}

509 510 511 512
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');
}
513

514 515 516 517 518 519 520
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)) {
521
	$themegenlib = TikiLib::lib('themegenerator');
522 523
	$themegenlib->setupEditor();
}
524 525

if ( $prefs['feature_jquery_validation'] == 'y' ) {
526
	$headerlib->add_jsfile('vendor/jquery/plugins/jquery-validation/dist/jquery.validate.js');
527
	$headerlib->add_jsfile('lib/validators/validator_tiki.js');
528 529
}

530 531
// note: jquery.async.js load a copy of jquery
$headerlib->add_jsfile('vendor/jquery/plugins/async/jquery.async.js');
532 533
$headerlib->add_jsfile('vendor/jquery/plugins/treetable/javascripts/src/jquery.treetable.js');
$headerlib->add_cssfile('vendor/jquery/plugins/treetable/stylesheets/jquery.treetable.css');
534

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

537 538 539 540
if ($prefs['feature_equal_height_rows_js'] == 'y'){
	$headerlib->add_jsfile("vendor/Sam152/Javascript-Equal-Height-Responsive-Rows/grids.min.js");
}

541
if (empty($user) && $prefs['feature_antibot'] == 'y') {
542
	$headerlib->add_jsfile_late('lib/captcha/captchalib.js');
543 544 545 546 547
}

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

549
if ( ! empty( $prefs['header_custom_css'] ) ) {
550
	$headerlib->add_css($prefs['header_custom_css']);
551 552
}

553
if ( ! empty( $prefs['header_custom_js'] ) ) {
554
	$headerlib->add_js($prefs['header_custom_js']);
555 556
}

557 558 559 560
if ($prefs['feature_file_galleries'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/files.js');
}

561 562
if ($prefs['feature_trackers'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-trackers.js');
563 564 565

	if ($prefs['feed_tracker'] === 'y') {
		$opts = TikiLib::lib('trk')->get_trackers_options(null, 'publishRSS', 'y');
566
		foreach ($opts as & $o) {
567 568 569 570 571
			$o = $o['trackerId'];
		}
		$trackers = TikiLib::lib('trk')->list_trackers();

		$rss_trackers = array();
572
		foreach ($trackers['data'] as $trk) {
573 574 575 576 577 578 579 580 581 582
			if (in_array($trk['trackerId'], $opts)) {
				$rss_trackers[] = array(
					'trackerId' => $trk['trackerId'],
					'name' => $trk['name'],
				);
			}
		}
		TikiLib::lib('smarty')->assign('rsslist_trackers', $rss_trackers);
	}

583 584
}

585
if ($prefs['feature_draw'] == 'y') {
586 587
	//svg-edit/empbedapi.js neededs to be external - why?
	$headerlib->add_jsfile("vendor/svg-edit/svg-edit/embedapi.js");
588 589 590 591
	$headerlib->add_jsfile("lib/svg-edit_tiki/draw.js");
	$headerlib->add_cssfile("lib/svg-edit_tiki/draw.css");
}

592 593 594 595
if ($prefs['geo_always_load_openlayers'] == 'y') {
	$headerlib->add_map();
}

596 597 598 599
if ($prefs['workspace_ui'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/tiki-workspace-ui.js');
}

600
if ($prefs['feature_sefurl'] != 'y') {
601
	$headerlib->add_js(
602
		'$.service = function (controller, action, query) {
603 604 605 606 607
		if (! query) {
			query = {};
		}
		query.controller = controller;

608
		if (action) {
609
			query.action = action;
610
		}
611

612
		return "tiki-ajax_services.php?" + $.buildParams(query);
613
	};'
614
	);
615 616
}

617
if ($prefs['feature_friends'] == 'y' || $prefs['monitor_enabled'] == 'y') {
618 619 620
	$headerlib->add_jsfile('lib/jquery_tiki/social.js');
}

621 622 623 624
if ($prefs['ajax_inline_edit'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/inline_edit.js');
}

625 626 627 628
if ($prefs['mustread_enabled'] == 'y') {
	$headerlib->add_jsfile('lib/jquery_tiki/mustread.js');
}

629 630 631
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.
632 633 634
	
	// This is not a very helpful comment...
	$headerlib->add_jsfile_dynamic('tiki-jsplugin.php?language='.$prefs['language']);
635
	if ($prefs['wikiplugin_module'] === 'y' && $prefs['wikiplugininline_module'] === 'n') {
636
		$headerlib->add_jsfile_dynamic('tiki-jsmodule.php?language='.$prefs['language']);
637 638 639
	}
}

640 641
if ( session_id() ) {
	if ( $prefs['tiki_cachecontrol_session'] ) {
642
		header('Cache-Control: ' . $prefs['tiki_cachecontrol_session']);
643 644
	}
} else {
645
	if ( $prefs['tiki_cachecontrol_nosession'] ) {
646
		header('Cache-Control: ' . $prefs['tiki_cachecontrol_nosession']);
647 648
	}
}
649

650 651 652 653 654 655 656 657
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");
	}
}

658 659 660 661 662 663
if ( isset($token_error) ) {
	$smarty->assign('token_error', $token_error);
	$smarty->display('error.tpl');
	die;
}

664 665
require_once( 'lib/setup/plugins_actions.php' );

666
if ($tiki_p_admin == 'y') {
667
	$headerlib->add_jsfile_late('lib/jquery_tiki/tiki-admin.js');
668 669
}

670 671 672 673
if ($prefs['wikiplugin_addtocart'] == 'y') {
	$headerlib->add_jsfile('lib/payment/cartlib.js');
}

674
//////////////////////////////////////////////////////////////////////////
kstingel's avatar
kstingel committed
675 676 677 678 679 680 681 682 683 684 685
// ******************************************************************** //
// ** 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       ** //
686
// ** CONFIGURED TIKI-SENDER KEYPAIR (PRIVATE/PUBLIC) AND ALL USER   ** //
kstingel's avatar
kstingel committed
687 688 689
// ** ACCOUNT-RELATED PUBLIC KEYS                                    ** //
// **                                                                ** //
// ** DO NOT SWITCH THIS VARIABLE TO TRUE FOR THIS EXPERIMENTAL      ** //
690
// ** FULLY PGP/MIME-ENCRYPTION COMPLIANT EMAIL FUNCTIONALITY, IF    ** //
kstingel's avatar
kstingel committed
691 692 693
// ** YOU ARE **NOT ABSOLUTE SURE HOW TO CONFIGURE IT**!             ** //
// **                                                                ** //
// ** ONCE PROPERLY CONFIGURED, SUCH 100% OPAQUE FUNCTIONALITY       ** //
694
// ** DELIVERS ROBUST END-TO-END PRIVACY WITH HIGH DEGREE OF TESTED  ** //
kstingel's avatar
kstingel committed
695 696 697 698 699 700
// ** ROBUSTNESS FOR THE FOLLOWING MAIL TRAFFIC:                     ** //
// **                                                                ** //
// **   - all webmail-based messaging from messu-compose.php         ** //
// **   - all admin notifications                                    ** //
// **   - all newsletters                                            ** //
// **                                                                ** //
701 702 703 704
// ** 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
705 706 707 708 709
// ** 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.      ** //
// **                                                                ** //
710
if ($prefs['openpgp_gpg_pgpmimemail'] == 'y') {
711 712 713 714
	// hollmeer 2012-11-03:
	// TURNED ON openPGP support from a lib based class
	require_once( 'lib/openpgp/openpgplib.php' );
}
kstingel's avatar
kstingel committed
715 716
// **                                                                ** //
// ******************************************************************** //
717 718
//////////////////////////////////////////////////////////////////////////

719
if( $prefs['feature_hidden_links'] == 'y' && isset($jitRequest['wysiwyg']) && $jitRequest['wysiwyg'] != 'y') {
720 721 722 723 724 725
	$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>');
		}
	});");
726 727
}

728 729 730
// any furher $headerlib->add_js() call not using rank = 'external' will be put into rank 'late'
// this should separate the overall JS from page specific JS
$headerlib->forceJsRankLate();
731 732

if ( $prefs['conditions_enabled'] == 'y' ) {
733 734 735 736 737 738
	if (! Services_User_ConditionsController::hasRequiredAge($user)) {
		$servicelib = TikiLib::lib('service');
		$broker = $servicelib->getBroker();
		$broker->process('user_conditions', 'age_validation', $jitRequest);
		exit;
	}
739 740 741 742 743 744 745
	if (Services_User_ConditionsController::requiresApproval($user)) {
		$servicelib = TikiLib::lib('service');
		$broker = $servicelib->getBroker();
		$broker->process('user_conditions', 'approval', $jitRequest);
		exit;
	}
}