2007-03-31 01:18:33 +00:00
< ? php
2006-12-02 04:36:16 +00:00
/*
2008-12-22 03:15:04 +00:00
* e107 website system
*
2010-05-13 15:47:31 +00:00
* Copyright ( C ) 2008 - 2010 e107 Inc ( e107 . org )
2008-12-22 03:15:04 +00:00
* Released under the terms and conditions of the
* GNU General Public License ( http :// www . gnu . org / licenses / gpl . txt )
*
* General purpose file
*
2010-05-13 15:47:31 +00:00
* $URL $
* $Id $
2008-12-22 03:15:04 +00:00
*
2006-12-02 04:36:16 +00:00
*/
//
// *** Code sequence for startup ***
// IMPORTANT: These items are in a carefully constructed order. DO NOT REARRANGE
// without checking with experienced devs! Various subtle things WILL break.
//
// A Get the current CPU time so we know how long all of this takes
// B Remove output buffering so we are in control of text sent to user
// C Remove registered globals (SECURITY for all following code)
// D Setup PHP error handling (now we can see php errors ;))
// E Setup other PHP essentials
// F Grab e107_config to get directory paths
// G Retrieve Query from URI (i.e. what are the request parameters?!)
// H Initialize debug handling (NOTE: A-G cannot use debug tools!)
// I: Sanity check to ensure e107_config is ok
// J: MYSQL setup (NOTE: A-I cannot use database!)
// K: Compatibility mode
// L: Retrieve core prefs
// M: Subdomain and language selection
// N: Other misc setups (NOTE: Put most 'random' things here that don't require user session or theme
// O: Start user session
// P: Load theme
// Q: Other setups
2009-12-13 21:52:32 +00:00
/**
* @ package e107
*/
2006-12-02 04:36:16 +00:00
//
// A: Honest global beginning point for processing time
//
$eTimingStart = microtime (); // preserve these when destroying globals in step C
2007-03-04 21:47:15 +00:00
if ( function_exists ( 'getrusage' ) ) { $eTimingStartCPU = getrusage (); }
2006-12-02 04:36:16 +00:00
$oblev_before_start = ob_get_level ();
//
// B: Remove all output buffering
//
2008-01-22 00:39:08 +00:00
if ( ! isset ( $_E107 ) || ! is_array ( $_E107 )) { $_E107 = array (); }
2009-08-05 19:58:32 +00:00
if ( isset ( $_E107 [ 'cli' ]) && ! isset ( $_E107 [ 'debug' ]) && isset ( $_SERVER [ " HTTP_USER_AGENT " ]))
2008-01-22 00:39:08 +00:00
{
2009-10-30 20:58:52 +00:00
exit ();
2008-01-22 00:39:08 +00:00
}
2008-11-27 02:18:25 +00:00
2009-09-15 13:34:09 +00:00
if ( ! isset ( $_E107 [ 'cli' ]))
2008-01-21 03:54:10 +00:00
{
while ( @ ob_end_clean ()); // destroy all ouput buffering
ob_start (); // start our own.
$oblev_at_start = ob_get_level (); // preserve when destroying globals in step C
}
2006-12-02 04:36:16 +00:00
//
// C: Find out if register globals is enabled and destroy them if so
// (DO NOT use the value of any variables before this point! They could have been set by the user)
//
2009-11-24 16:30:08 +00:00
// Can't be moved to e107, required here for e107_config vars security
2006-12-02 04:36:16 +00:00
$register_globals = true ;
2008-11-27 02:18:25 +00:00
if ( function_exists ( 'ini_get' ))
{
2006-12-02 04:36:16 +00:00
$register_globals = ini_get ( 'register_globals' );
}
// Destroy! (if we need to)
2008-11-27 02:18:25 +00:00
if ( $register_globals == true )
{
2008-01-06 22:16:37 +00:00
if ( isset ( $_REQUEST [ '_E107' ])) { unset ( $_E107 ); }
2008-11-27 02:18:25 +00:00
while ( list ( $global ) = each ( $GLOBALS ))
{
if ( ! preg_match ( '/^(_POST|_GET|_COOKIE|_SERVER|_FILES|_SESSION|GLOBALS|HTTP.*|_REQUEST|_E107|retrieve_prefs|eplug_admin|eTimingStart.*|oblev_.*)$/' , $global ))
{
2006-12-02 04:36:16 +00:00
unset ( $$global );
}
}
unset ( $global );
}
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->prepare_request()
2009-09-29 17:45:06 +00:00
// TODO - better ajax detection method (headers when possible)
2009-11-24 16:30:08 +00:00
//define('e_AJAX_REQUEST', isset($_REQUEST['ajax_used']));
2010-02-10 21:53:56 +00:00
//unset($_REQUEST['ajax_used']); // removed because it's auto-appended from JS (AJAX), could break something...
2009-11-24 16:30:08 +00:00
//
//if(isset($_E107['minimal']) || e_AJAX_REQUEST)
//{
// $_e107vars = array('forceuserupdate', 'online', 'theme', 'menus', 'prunetmp');
// foreach($_e107vars as $v)
// {
// $noname = 'no_'.$v;
// if(!isset($_E107[$v]))
// {
// $_E107[$noname] = 1;
// }
// unset($_E107[$v]);
// }
//}
// MOVED TO $e107->prepare_request()
2007-02-05 10:54:44 +00:00
// e107 uses relative url's, which are broken by "pretty" URL's. So for now we don't support / after .php
2009-11-24 16:30:08 +00:00
//if(($pos = strpos($_SERVER['PHP_SELF'], '.php/')) !== false) // redirect bad URLs to the correct one.
//{
// $new_url = substr($_SERVER['PHP_SELF'], 0, $pos+4);
// $new_loc = ($_SERVER['QUERY_STRING']) ? $new_url.'?'.$_SERVER['QUERY_STRING'] : $new_url;
// header('Location: '.$new_loc);
// exit();
//}
2006-12-02 04:36:16 +00:00
// If url contains a .php in it, PHP_SELF is set wrong (imho), affecting all paths. We need to 'fix' it if it does.
2009-11-24 16:30:08 +00:00
//$_SERVER['PHP_SELF'] = (($pos = strpos($_SERVER['PHP_SELF'], '.php')) !== false ? substr($_SERVER['PHP_SELF'], 0, $pos+4) : $_SERVER['PHP_SELF']);
2006-12-02 04:36:16 +00:00
//
// D: Setup PHP error handling
2006-12-05 09:33:20 +00:00
// (Now we can see PHP errors) -- but note that DEBUG is not yet enabled!
2006-12-02 04:36:16 +00:00
//
$error_handler = new error_handler ();
2008-11-27 02:18:25 +00:00
set_error_handler ( array ( & $error_handler , 'handle_error' ));
2006-12-02 04:36:16 +00:00
//
// E: Setup other essential PHP parameters
//
2008-11-27 02:18:25 +00:00
define ( 'e107_INIT' , true );
2006-12-02 04:36:16 +00:00
2016-02-14 12:15:55 -08:00
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->prepare_request()
2006-12-02 04:36:16 +00:00
// setup some php options
2009-11-24 16:30:08 +00:00
//e107_ini_set('magic_quotes_runtime', 0);
//e107_ini_set('magic_quotes_sybase', 0);
//e107_ini_set('arg_separator.output', '&');
//e107_ini_set('session.use_only_cookies', 1);
//e107_ini_set('session.use_trans_sid', 0);
2006-12-02 04:36:16 +00:00
2009-11-24 16:30:08 +00:00
// DEPRECATED, use e107::getConfig() and e107::getPlugConfig()
2008-11-27 02:18:25 +00:00
if ( isset ( $retrieve_prefs ) && is_array ( $retrieve_prefs ))
{
foreach ( $retrieve_prefs as $key => $pref_name )
{
2006-12-02 04:36:16 +00:00
$retrieve_prefs [ $key ] = preg_replace ( " / \ W/ " , '' , $pref_name );
}
2008-11-27 02:18:25 +00:00
}
else
{
2006-12-02 04:36:16 +00:00
unset ( $retrieve_prefs );
}
2009-11-24 16:30:08 +00:00
// MOVED TO e107->set_constants()
//define("MAGIC_QUOTES_GPC", (ini_get('magic_quotes_gpc') ? true : false));
//
//// Define the domain name and subdomain name.
//if($_SERVER['HTTP_HOST'] && is_numeric(str_replace(".","",$_SERVER['HTTP_HOST'])))
//{
// $srvtmp = ''; // Host is an IP address.
//}
//else
//{
// $srvtmp = explode('.',str_replace('www.', '', $_SERVER['HTTP_HOST']));
//}
//
//define('e_SUBDOMAIN', (count($srvtmp)>2 && $srvtmp[2] ? $srvtmp[0] : false)); // needs to be available to e107_config.
//
//if(e_SUBDOMAIN)
//{
// unset($srvtmp[0]);
//}
//
//define('e_DOMAIN',(count($srvtmp) > 1 ? (implode('.', $srvtmp)) : false)); // if it's an IP it must be set to false.
//
//unset($srvtmp);
2007-03-31 01:18:33 +00:00
2006-12-02 04:36:16 +00:00
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->prepare_request()
2006-12-02 04:36:16 +00:00
// Ensure thet '.' is the first part of the include path
2009-11-24 16:30:08 +00:00
//$inc_path = explode(PATH_SEPARATOR, ini_get('include_path'));
//if($inc_path[0] != '.')
//{
// array_unshift($inc_path, '.');
// $inc_path = implode(PATH_SEPARATOR, $inc_path);
// e107_ini_set('include_path', $inc_path);
//}
//unset($inc_path);
2006-12-02 04:36:16 +00:00
//
// F: Grab e107_config, get directory paths and create $e107 object
//
2012-05-14 11:07:04 +00:00
@ include ( realpath ( dirname ( __FILE__ ) . '/e107_config.php' ));
2009-11-22 23:36:23 +00:00
2012-10-16 07:35:42 +00:00
if ( ! defined ( 'e_POWEREDBY_DISABLE' ))
{
define ( 'e_POWEREDBY_DISABLE' , false );
}
2010-08-20 09:25:10 +00:00
if ( isset ( $CLASS2_INCLUDE ) && ( $CLASS2_INCLUDE != '' ))
2011-06-07 12:40:34 +00:00
{
require_once ( realpath ( dirname ( __FILE__ ) . '/' . $CLASS2_INCLUDE ));
2010-08-20 00:00:54 +00:00
}
2009-11-24 16:30:08 +00:00
//define("MPREFIX", $mySQLprefix); moved to $e107->set_constants()
2009-11-22 23:36:23 +00:00
2008-08-03 08:00:19 +00:00
if ( ! isset ( $ADMIN_DIRECTORY ))
{
// e107_config.php is either empty, not valid or doesn't exist so redirect to installer..
2008-11-27 02:18:25 +00:00
header ( 'Location: install.php' );
2008-08-03 08:00:19 +00:00
exit ();
2006-12-02 04:36:16 +00:00
}
//
2008-11-24 18:06:03 +00:00
// clever stuff that figures out where the paths are on the fly.. no more need for hard-coded e_HTTP :)
2006-12-02 04:36:16 +00:00
//
2009-08-05 19:58:32 +00:00
$tmp = realpath ( dirname ( __FILE__ ) . '/' . $HANDLERS_DIRECTORY );
2009-08-28 15:21:23 +00:00
//Core functions - now API independent
2009-08-05 19:58:32 +00:00
@ require_once ( $tmp . '/core_functions.php' );
e107_require_once ( $tmp . '/e107_class.php' );
unset ( $tmp );
2014-07-03 19:45:50 -07:00
$e107_paths = compact ( 'ADMIN_DIRECTORY' , 'FILES_DIRECTORY' , 'IMAGES_DIRECTORY' , 'THEMES_DIRECTORY' , 'PLUGINS_DIRECTORY' , 'HANDLERS_DIRECTORY' , 'LANGUAGES_DIRECTORY' , 'HELP_DIRECTORY' , 'DOWNLOADS_DIRECTORY' , 'UPLOADS_DIRECTORY' , 'SYSTEM_DIRECTORY' , 'MEDIA_DIRECTORY' , 'CACHE_DIRECTORY' , 'LOGS_DIRECTORY' , 'CORE_DIRECTORY' , 'WEB_DIRECTORY' );
2016-07-07 15:09:38 -07:00
$sql_info = compact ( 'mySQLserver' , 'mySQLuser' , 'mySQLpassword' , 'mySQLdefaultdb' , 'mySQLprefix' , 'mySQLport' );
2010-03-08 10:02:22 +00:00
$e107 = e107 :: getInstance () -> initCore ( $e107_paths , realpath ( dirname ( __FILE__ )), $sql_info , varset ( $E107_CONFIG , array ()));
2009-11-24 16:30:08 +00:00
2011-12-28 10:01:25 +00:00
e107 :: getSingleton ( 'eIPHandler' ); // This auto-handles bans etc
2011-11-25 17:17:09 +00:00
### NEW Register Autoload - do it asap
if ( ! function_exists ( 'spl_autoload_register' ))
{
// PHP >= 5.1.2 required
die ( 'Fatal exception - spl_autoload_* required.' );
}
2014-05-28 18:56:55 -07:00
2011-11-25 17:17:09 +00:00
// allow disable of autoloading - may be removed as e107::autoload_register() is flexible enough
if ( ! defset ( 'E107_DISABLE_AUTOLOAD' , false ))
{
2014-05-28 18:56:55 -07:00
/**
* Generic autoloader . ( didn ' t work while in e107_class . php )
* @ example if your plugin calls 'use Xxxxx\Yyyyy\Zzzzz;' it will attempt to load : ./ vendor / Xxxxx / Yyyyy / Zzzzz . php
*/
function autoloadPsr0 ( $className )
{
$className = str_replace ( " _ " , " \\ " , $className );
$className = ltrim ( $className , '\\' );
$fileName = '' ;
$namespace = '' ;
if ( $lastNsPos = strripos ( $className , '\\' ))
{
$namespace = substr ( $className , 0 , $lastNsPos );
$className = substr ( $className , $lastNsPos + 1 );
$fileName = str_replace ( '\\' , DIRECTORY_SEPARATOR , $namespace ) . DIRECTORY_SEPARATOR ;
}
$fileName .= str_replace ( '_' , DIRECTORY_SEPARATOR , $className ) . '.php' ;
$fullPath = 'vendor' . DIRECTORY_SEPARATOR . $fileName ;
if ( file_exists ( $fullPath ))
{
e107_require_once ( $fullPath );
}
else
{
return false ;
}
}
2011-11-25 17:17:09 +00:00
e107 :: autoload_register ( array ( 'e107' , 'autoload' ));
2014-05-28 18:56:55 -07:00
// e107::autoload_register('autoloadPsr0'); // Generic 'use xxxx\yyyy\zzzz;' fix/solution for plugin developers.
2011-11-25 17:17:09 +00:00
}
2014-05-28 18:56:55 -07:00
function genericAutoload ( $className )
{
$className = str_replace ( " _ " , " \\ " , $className );
$className = ltrim ( $className , '\\' );
$fileName = '' ;
$namespace = '' ;
if ( $lastNsPos = strripos ( $className , '\\' ))
{
$namespace = substr ( $className , 0 , $lastNsPos );
$className = substr ( $className , $lastNsPos + 1 );
$fileName = str_replace ( '\\' , DIRECTORY_SEPARATOR , $namespace ) . DIRECTORY_SEPARATOR ;
}
$fileName .= str_replace ( '_' , DIRECTORY_SEPARATOR , $className ) . '.php' ;
e107_require_once ( $fileName );
}
2010-10-26 07:41:20 +00:00
/**
* NEW - system security levels
* Could be overridden by e107_config . php OR $CLASS2_INCLUDE script ( if not set earlier )
2011-06-07 12:40:34 +00:00
*
2010-10-26 07:41:20 +00:00
* 0 disabled
* 5 safe mode ( balanced )
* 7 high
2011-06-07 12:40:34 +00:00
* 9 paranoid
2010-10-26 07:41:20 +00:00
* 10 insane
* for more detailed info see e_session SECURITY_LEVEL_ * constants
* default is e_session :: SECURITY_LEVEL_BALANCED ( 5 )
*/
2011-06-07 12:40:34 +00:00
if ( ! defined ( 'e_SECURITY_LEVEL' ))
2010-10-26 07:41:20 +00:00
{
require_once ( e_HANDLER . 'session_handler.php' );
define ( 'e_SECURITY_LEVEL' , e_session :: SECURITY_LEVEL_BALANCED );
}
2010-09-10 01:01:48 +00:00
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->set_request()
//$inArray = array("'", ';', '/**/', '/UNION/', '/SELECT/', 'AS ');
//if (strpos($_SERVER['PHP_SELF'], 'trackback') === false)
//{
// foreach($inArray as $res)
// {
// if(stristr($_SERVER['QUERY_STRING'], $res))
// {
// die('Access denied.');
// }
// }
//}
2006-12-02 04:36:16 +00:00
2009-07-19 11:44:30 +00:00
2006-12-02 04:36:16 +00:00
//
// Start the parser; use it to grab the full query string
//
2009-08-28 15:21:23 +00:00
//DEPRECATED, BC
2009-07-23 15:29:07 +00:00
//$e107->url = e107::getUrl(); - caught by __get()
//TODO - find & replace $e107->url
//DEPRECATED, BC, $e107->tp caught by __get()
$tp = e107 :: getParser (); //TODO - find & replace $tp, $e107->tp
2006-12-02 04:36:16 +00:00
//define("e_QUERY", $matches[2]);
//define("e_QUERY", $_SERVER['QUERY_STRING']);
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->set_request()
//$e_QUERY = str_replace("&","&",$tp->post_toForm($e_QUERY));
//define('e_QUERY', $e_QUERY);
2006-12-02 04:36:16 +00:00
//$e_QUERY = e_QUERY;
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->set_request()
//define('e_TBQS', $_SERVER['QUERY_STRING']);
//$_SERVER['QUERY_STRING'] = e_QUERY;
// MOVED TO $e107->set_constants()
//define('e_UC_PUBLIC', 0);
//define('e_UC_MAINADMIN', 250);
//define('e_UC_READONLY', 251);
//define('e_UC_GUEST', 252);
//define('e_UC_MEMBER', 253);
//define('e_UC_ADMIN', 254);
//define('e_UC_NOBODY', 255);
2006-12-02 04:36:16 +00:00
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->set_urls() - DEPRECATED, use e107->getFolder()
//define('ADMINDIR', $ADMIN_DIRECTORY);
2006-12-02 04:36:16 +00:00
//
// H: Initialize debug handling
// (NO E107 DEBUG CONSTANTS OR CODE ARE AVAILABLE BEFORE THIS POINT)
// All debug objects and constants are defined in the debug handler
// i.e. from here on you can use E107_DEBUG_LEVEL or any
// E107_DBG_* constant for debug testing.
2010-10-26 07:41:20 +00:00
// TODO - rewrite the debug init phase, add e107 class getters
2006-12-02 04:36:16 +00:00
//
2008-11-27 02:18:25 +00:00
require_once ( e_HANDLER . 'debug_handler.php' );
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
if ( E107_DEBUG_LEVEL && isset ( $db_debug ) && is_object ( $db_debug ))
{
2016-05-28 07:59:00 -07:00
$db_debug -> Mark_Time ( 'Init ErrHandler' );
2006-12-02 04:36:16 +00:00
}
//
// I: Sanity check on e107_config.php
// e107_config.php upgrade check
2010-10-26 07:41:20 +00:00
// FIXME - obsolete check, rewrite it
2008-11-27 02:18:25 +00:00
if ( ! $ADMIN_DIRECTORY && ! $DOWNLOADS_DIRECTORY )
{
message_handler ( 'CRITICAL_ERROR' , 8 , ': generic, ' , 'e107_config.php' );
2006-12-02 04:36:16 +00:00
exit ;
}
//
// J: MYSQL INITIALIZATION
//
2009-09-13 10:29:56 +00:00
e107 :: getSingleton ( 'e107_traffic' ); // We start traffic counting ASAP
2010-02-10 21:53:56 +00:00
//$eTraffic->Calibrate($eTraffic);
2006-12-02 04:36:16 +00:00
2010-10-26 07:41:20 +00:00
// e107_require_once(e_HANDLER.'mysql_class.php');
2006-12-02 04:36:16 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, $e107->sql caught by __get()
$sql = e107 :: getDb (); //TODO - find & replace $sql, $e107->sql
2016-06-02 08:38:39 -07:00
$sql -> db_SetErrorReporting ( false );
2006-12-02 04:36:16 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'SQL Connect' );
2006-12-02 04:36:16 +00:00
$merror = $sql -> db_Connect ( $mySQLserver , $mySQLuser , $mySQLpassword , $mySQLdefaultdb );
2009-07-23 15:29:07 +00:00
2009-07-22 00:49:35 +00:00
// create after the initial connection.
2009-08-28 15:21:23 +00:00
//DEPRECATED, BC, call the method only when needed
2009-07-23 15:29:07 +00:00
$sql2 = e107 :: getDb ( 'sql2' ); //TODO find & replace all $sql2 calls
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Prefs, misc tables' );
2006-12-30 03:07:50 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->admin_log caught by __get()
$admin_log = e107 :: getAdminLog (); //TODO - find & replace $admin_log, $e107->admin_log
2006-12-02 04:36:16 +00:00
2009-08-28 15:21:23 +00:00
if ( $merror === 'e1' )
2009-07-22 00:49:35 +00:00
{
2008-11-27 02:18:25 +00:00
message_handler ( 'CRITICAL_ERROR' , 6 , ': generic, ' , 'class2.php' );
2006-12-02 04:36:16 +00:00
exit ;
}
2008-11-27 02:18:25 +00:00
elseif ( $merror === 'e2' )
{
message_handler ( " CRITICAL_ERROR " , 7 , ': generic, ' , 'class2.php' );
2006-12-02 04:36:16 +00:00
exit ;
}
//
// K: Load compatability mode.
//
2008-01-06 22:16:37 +00:00
/* PHP Compatabilty should *always* be on. */
2008-11-27 02:18:25 +00:00
e107_require_once ( e_HANDLER . 'php_compatibility_handler.php' );
2006-12-02 04:36:16 +00:00
//
// L: Extract core prefs from the database
//
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Extract Core Prefs' );
2006-12-02 04:36:16 +00:00
2009-11-24 16:30:08 +00:00
// TODO - remove it from here, auto-loaded when required
2006-12-02 04:36:16 +00:00
e107_require_once ( e_HANDLER . 'cache_handler.php' );
2009-07-22 00:49:35 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->arrayStorage caught by __get()
2013-03-22 20:06:23 -07:00
e107_require_once ( e_HANDLER . 'arraystorage_class.php' ); // ArrayData(); BC Fix only.
$eArrayStorage = e107 :: getArrayStorage (); //TODO - find & replace $eArrayStorage with e107::getArrayStorage();
2006-12-02 04:36:16 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->e_event caught by __get()
$e_event = e107 :: getEvent (); //TODO - find & replace $e_event, $e107->e_event
2008-12-03 00:43:00 +00:00
2009-11-24 16:30:08 +00:00
// TODO - DEPRECATED - remove
2009-08-05 19:58:32 +00:00
e107_require_once ( e_HANDLER . " pref_class.php " );
$sysprefs = new prefs ;
// Check core preferences
//FIXME - message_handler is dying after message_handler(CRITICAL_ERROR) call
2010-10-28 13:33:05 +00:00
e107 :: getConfig () -> load (); // extra load, required if mysql handler already called e107::getConfig()
2009-08-05 19:58:32 +00:00
if ( ! e107 :: getConfig () -> hasData ())
{
// Core prefs error - admin log
e107 :: getAdminLog () -> log_event ( 'CORE_LAN8' , 'CORE_LAN7' , E_LOG_WARNING );
2009-08-28 15:21:23 +00:00
2009-08-05 19:58:32 +00:00
// Try for the automatic backup..
if ( e107 :: getConfig ( 'core_backup' ) -> hasData ())
{
// auto backup found, use backup to restore the core
e107 :: getConfig () -> loadData ( e107 :: getConfig ( 'core_backup' ) -> getPref (), false )
-> save ( false , true );
2009-08-28 15:21:23 +00:00
2009-08-05 19:58:32 +00:00
message_handler ( 'CRITICAL_ERROR' , 3 , __LINE__ , __FILE__ );
}
2009-08-28 15:21:23 +00:00
else
2009-08-05 19:58:32 +00:00
{
// No auto backup, try for the 'old' prefs system.
if ( ! e107 :: getConfig ( 'core_old' ) -> hasData ())
{
// Core could not restore from automatic backup. Execution halted.
2009-08-28 15:21:23 +00:00
e107 :: getAdminLog () -> log_event ( 'CORE_LAN8' , 'CORE_LAN9' , E_LOG_FATAL );
2009-08-05 19:58:32 +00:00
message_handler ( 'CRITICAL_ERROR' , 3 , __LINE__ , __FILE__ );
// No old system, so point in the direction of resetcore :(
2009-08-28 15:21:23 +00:00
message_handler ( 'CRITICAL_ERROR' , 4 , __LINE__ , __FILE__ ); //this will never appear till message_handler() is fixed
2009-08-05 19:58:32 +00:00
exit ;
}
2009-08-28 15:21:23 +00:00
else
2009-08-05 19:58:32 +00:00
{
// resurrect core from old prefs
e107 :: getConfig () -> loadData ( e107 :: getConfig ( 'core_old' ) -> getPref (), false )
-> save ( false , true );
2009-08-28 15:21:23 +00:00
2009-08-05 19:58:32 +00:00
// resurrect core_backup from old prefs
e107 :: getConfig ( 'core_backup' ) -> loadData ( e107 :: getConfig ( 'core_old' ) -> getPref (), false )
-> save ( false , true );
}
}
2009-08-28 15:21:23 +00:00
2009-08-05 19:58:32 +00:00
}
2010-10-26 07:41:20 +00:00
//DEPRECATED, BC, call e107::getPref/findPref() instead
2009-08-05 19:58:32 +00:00
$pref = e107 :: getPref ();
2009-11-24 16:30:08 +00:00
//this could be part of e107->init() method now, prefs will be auto-initialized
2009-08-05 19:58:32 +00:00
//when proper called (e107::getPref())
2010-02-10 21:53:56 +00:00
// $e107->set_base_path(); moved to init().
2006-12-02 04:36:16 +00:00
2009-08-05 19:58:32 +00:00
//DEPRECATED, BC, call e107::getConfig('menu')->get('pref_name') only when needed
$menu_pref = e107 :: getConfig ( 'menu' ) -> getPref (); //extract menu prefs
2010-11-21 12:49:36 +00:00
// NEW - force ssl
if ( e107 :: getPref ( 'ssl_enabled' ) && ! deftrue ( 'e_SSL_DISABLE' ))
{
// NOTE: e_SSL_DISABLE check is here to help webmasters fix 'ssl_enabled'
// if set by accident on site with no SSL support - just define it in e107_config.php
if ( strpos ( e_REQUEST_URL , 'http://' ) === 0 )
{
// e_REQUEST_URL and e_REQUEST_URI introduced
2011-06-07 12:40:34 +00:00
$url = 'https://' . substr ( e_REQUEST_URL , 7 );
2010-11-21 12:49:36 +00:00
header ( 'Location: ' . $url );
exit ;
}
}
2009-07-16 02:55:19 +00:00
2010-09-10 01:01:48 +00:00
// $sql->db_Mark_Time('(Extracting Core Prefs Done)');
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Init Language and detect changes' );
2012-06-22 00:29:15 +00:00
$lng = e107 :: getLanguage (); // required for v1.0 BC.
$lng -> detect ();
2006-12-02 04:36:16 +00:00
//
// M: Subdomain and Language Selection
//
2008-05-19 09:42:28 +00:00
2008-11-27 02:18:25 +00:00
// if a cookie name pref isn't set, make one :)
2010-10-26 07:41:20 +00:00
// e_COOKIE used as unique session cookie name now (see session handler)
2008-11-27 02:18:25 +00:00
if ( ! $pref [ 'cookie_name' ]) { $pref [ 'cookie_name' ] = 'e107cookie' ; }
define ( 'e_COOKIE' , $pref [ 'cookie_name' ]);
2008-05-19 09:42:28 +00:00
2009-11-24 16:30:08 +00:00
// MOVED TO $e107->set_urls()
//define('SITEURLBASE', ($pref['ssl_enabled'] == '1' ? 'https://' : 'http://').$_SERVER['HTTP_HOST']);
//define('SITEURL', SITEURLBASE.e_HTTP);
2006-12-02 04:36:16 +00:00
// if the option to force users to use a particular url for the site is enabled, redirect users there as needed
// Now matches RFC 2616 (sec 3.2): case insensitive, https/:443 and http/:80 are equivalent.
// And, this is robust against hack attacks. Malignant users can put **anything** in HTTP_HOST!
2016-02-14 19:00:12 -08:00
if ( ! empty ( $pref [ 'redirectsiteurl' ]) && ! empty ( $pref [ 'siteurl' ])) {
2008-04-26 02:12:13 +00:00
if ( isset ( $pref [ 'multilanguage_subdomain' ]) && $pref [ 'multilanguage_subdomain' ])
{
2011-12-06 08:00:42 +00:00
if ( substr ( e_REQUEST_URL , 7 , 4 ) == 'www.' || substr ( e_REQUEST_URL , 8 , 4 ) == 'www.' )
2008-04-26 02:12:13 +00:00
{
2011-12-06 08:00:42 +00:00
$self = e_REQUEST_URL ;
//if(e_QUERY){ $self .= '?'.e_QUERY; }
2008-11-27 02:18:25 +00:00
$location = str_replace ( '://www.' , '://' , $self );
2016-02-14 19:00:12 -08:00
if ( defined ( 'e_DEBUG' ) && e_DEBUG === true )
{
echo " Redirecting to location: " . $location ;
}
e107 :: getRedirect () -> go ( $location , true , 301 );
// header("Location: {$location}", true, 301); // send 301 header, not 302
2008-04-26 02:12:13 +00:00
exit ();
2006-12-02 04:36:16 +00:00
}
2008-04-26 02:12:13 +00:00
}
2016-02-14 19:00:12 -08:00
elseif ( deftrue ( 'e_DOMAIN' ))
2008-04-26 02:12:13 +00:00
{
// Find domain and port from user and from pref
list ( $urlbase , $urlport ) = explode ( ':' , $_SERVER [ 'HTTP_HOST' ] . ':' );
if ( ! $urlport ) { $urlport = $_SERVER [ 'SERVER_PORT' ]; }
if ( ! $urlport ) { $urlport = 80 ; }
$aPrefURL = explode ( '/' , $pref [ 'siteurl' ], 4 );
2008-11-27 02:18:25 +00:00
if ( count ( $aPrefURL ) > 2 ) // we can do this -- there's at least http[s]://dom.ain/whatever
2008-12-02 18:27:35 +00:00
{
2008-04-26 02:12:13 +00:00
$PrefRoot = $aPrefURL [ 2 ];
list ( $PrefSiteBase , $PrefSitePort ) = explode ( ':' , $PrefRoot . ':' );
2008-11-27 02:18:25 +00:00
if ( ! $PrefSitePort )
{
$PrefSitePort = ( $aPrefURL [ 0 ] == 'https:' ) ? 443 : 80 ; // no port so set port based on 'scheme'
2008-04-26 02:12:13 +00:00
}
2006-12-02 04:36:16 +00:00
2008-04-26 02:12:13 +00:00
// Redirect only if
// -- ports do not match (http <==> https)
// -- base domain does not match (case-insensitive)
// -- NOT admin area
2011-12-06 08:00:42 +00:00
if (( $urlport != $PrefSitePort || stripos ( $PrefSiteBase , $urlbase ) === false ) && strpos ( e_REQUEST_SELF , ADMINDIR ) === false )
2008-11-27 02:18:25 +00:00
{
2011-12-06 08:00:42 +00:00
$aeSELF = explode ( '/' , e_REQUEST_SELF , 4 );
2008-04-26 02:12:13 +00:00
$aeSELF [ 0 ] = $aPrefURL [ 0 ]; // Swap in correct type of query (http, https)
$aeSELF [ 1 ] = '' ; // Defensive code: ensure http:// not http:/<garbage>/
$aeSELF [ 2 ] = $aPrefURL [ 2 ]; // Swap in correct domain and possibly port
2011-12-06 08:00:42 +00:00
$location = implode ( '/' , $aeSELF ) . ( $_SERVER [ 'QUERY_STRING' ] ? '?' . $_SERVER [ 'QUERY_STRING' ] : '' );
2008-04-26 02:12:13 +00:00
2016-02-14 19:00:12 -08:00
//
// header("Location: {$location}", true, 301); // send 301 header, not 302
if ( defined ( 'e_DEBUG' ) && e_DEBUG === true )
{
echo " DEBUG INFO: site-redirect preference enabled.<br />Redirecting to: <a hre=' " . $location . " '> " . $location . " </a> " ;;
echo " <br />e_DOMAIN: " . e_DOMAIN ;
echo " <br />e_SUBDOMAIN: " . e_SUBDOMAIN ;
}
else
{
e107 :: getRedirect () -> go ( $location , true , 301 );
}
exit ();
2008-04-26 02:12:13 +00:00
}
}
2006-12-02 04:36:16 +00:00
}
}
2010-09-10 01:01:48 +00:00
/**
* Set the User ' s Language
*/
2011-06-07 12:40:34 +00:00
// SESSION Needs to be started after:
// - Site preferences are available
// - Language detection (because of session.cookie_domain)
2010-10-26 07:41:20 +00:00
// to avoid multi-language 'access-denied' issues.
//session_start(); see e107::getSession() above
e107 :: getSession (); //init core _SESSION - actually here for reference only, it's done by language handler set() method
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Set User Language Session' );
2011-06-07 12:40:34 +00:00
e107 :: getLanguage () -> set (); // set e_LANGUAGE, USERLAN, Language Session / Cookies etc. requires $pref;
2006-12-02 04:36:16 +00:00
2010-09-10 01:01:48 +00:00
if ( varset ( $pref [ 'multilanguage' ]) && ( e_LANGUAGE != $pref [ 'sitelanguage' ]))
2008-11-27 02:18:25 +00:00
{
2010-09-10 01:01:48 +00:00
$sql -> mySQLlanguage = e_LANGUAGE ;
$sql2 -> mySQLlanguage = e_LANGUAGE ;
2006-12-02 04:36:16 +00:00
}
2010-10-31 14:50:40 +00:00
//do it only once and with the proper function
// e107_include_once(e_LANGUAGEDIR.e_LANGUAGE.'/'.e_LANGUAGE.'.php');
// e107_include_once(e_LANGUAGEDIR.e_LANGUAGE.'/'.e_LANGUAGE.'_custom.php');
2015-06-05 12:25:32 -07:00
// v1 Custom language File Path.
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Include Global Core Language Files' );
2015-06-05 12:25:32 -07:00
if (( e_ADMIN_AREA === true ) && ! empty ( $pref [ 'adminlanguage' ]))
{
include ( e_LANGUAGEDIR . $pref [ 'adminlanguage' ] . '/' . $pref [ 'adminlanguage' ] . '.php' );
}
else
{
include ( e_LANGUAGEDIR . e_LANGUAGE . '/' . e_LANGUAGE . '.php' ); // FASTEST - ALWAYS load
}
2010-10-31 14:50:40 +00:00
$customLan = e_LANGUAGEDIR . e_LANGUAGE . '/' . e_LANGUAGE . '_custom.php' ;
if ( is_readable ( $customLan )) // FASTER - if exist, should be done 'once' by the core
{
2011-06-07 12:40:34 +00:00
include ( $customLan );
2010-10-31 14:50:40 +00:00
}
2013-11-03 03:12:09 -08:00
// v2 Custom language File Path.
$customLan2 = e_SYSTEM . '/lans/' . e_LANGUAGE . '_custom.php' ;
if ( is_readable ( $customLan2 )) // FASTER - if exist, should be done 'once' by the core
{
include ( $customLan2 );
}
unset ( $customLan , $customLan2 );
2015-07-10 15:41:07 -07:00
$lng -> bcDefs (); // defined v1.x definitions for old templates.
2006-12-02 04:36:16 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Include Global Plugin Language Files' );
2012-12-12 18:46:34 -08:00
if ( isset ( $pref [ 'lan_global_list' ]))
{
foreach ( $pref [ 'lan_global_list' ] as $path )
{
e107 :: plugLan ( $path , 'global' , true );
}
}
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'CHAP challenge' );
2012-12-12 18:46:34 -08:00
2013-06-22 18:11:10 -07:00
$die = ( e_AJAX_REQUEST == true ) ? false : true ;
2010-10-26 07:41:20 +00:00
e107 :: getSession ()
2013-06-09 20:53:44 +01:00
-> challenge () // Make sure there is a unique challenge string for CHAP login
2013-06-19 19:54:29 -07:00
-> check ( $die ); // Token protection
unset ( $die );
2012-12-12 18:46:34 -08:00
2006-12-02 04:36:16 +00:00
//
// N: misc setups: online user tracking, cache
//
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Misc resources. Online user tracking, cache' );
2006-12-02 04:36:16 +00:00
2015-02-15 16:07:27 -08:00
/**
* @ deprecated BC , call the method only when needed , $e107 -> ecache caught by __get ()
*/
2009-07-23 15:29:07 +00:00
$e107cache = e107 :: getCache (); //TODO - find & replace $e107cache, $e107->ecache
2006-12-02 04:36:16 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->override caught by __get()
2010-04-24 11:39:14 +00:00
$override = e107 :: getSingleton ( 'override' , true ); //TODO - find & replace $override, $e107->override
2006-12-02 04:36:16 +00:00
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->user_class caught by __get()
$e_userclass = e107 :: getUserClass (); //TODO - find & replace $e_userclass, $e107->user_class
2008-11-30 23:15:15 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Init Event Handler' );
2016-04-08 15:22:26 -07:00
e107 :: getEvent () -> init ();
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Register Core Events' );
2015-03-07 16:30:46 -08:00
e107 :: getNotify () -> registerEvents ();
2006-12-02 04:36:16 +00:00
//
// O: Start user session
//
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'User session' );
2013-06-09 20:53:44 +01:00
init_session (); // Set up a lot of the user-related constants
2006-12-02 04:36:16 +00:00
2015-02-15 16:07:27 -08:00
/**
* @ deprecated but necessary . BC Fix .
* @ return string
*/
2010-02-10 21:53:56 +00:00
function getip ()
2009-11-19 10:07:32 +00:00
{
2012-01-02 22:06:22 +00:00
return e107 :: getIPHandler () -> ipDecode ( USERIP );
2009-11-19 10:07:32 +00:00
}
2015-05-30 17:06:22 -07:00
$developerMode = ( vartrue ( $pref [ 'developer' ], false ) || E107_DEBUG_LEVEL > 0 );
2006-12-02 04:36:16 +00:00
// for multi-language these definitions needs to come after the language loaded.
2013-10-31 19:10:46 -07:00
define ( 'SITENAME' , trim ( $tp -> toHTML ( $pref [ 'sitename' ], '' , 'USER_TITLE,er_on,defs' )));
2013-04-29 13:28:01 -07:00
define ( 'SITEBUTTON' , $tp -> replaceConstants ( $pref [ 'sitebutton' ], 'abs' ));
2010-01-02 21:42:51 +00:00
define ( 'SITETAG' , $tp -> toHTML ( $pref [ 'sitetag' ], false , 'emotes_off,defs' ));
define ( 'SITEDESCRIPTION' , $tp -> toHTML ( $pref [ 'sitedescription' ], '' , 'emotes_off,defs' ));
2008-11-27 02:18:25 +00:00
define ( 'SITEADMIN' , $pref [ 'siteadmin' ]);
define ( 'SITEADMINEMAIL' , $pref [ 'siteadminemail' ]);
2010-01-02 21:42:51 +00:00
define ( 'SITEDISCLAIMER' , $tp -> toHTML ( $pref [ 'sitedisclaimer' ], '' , 'emotes_off,defs' ));
define ( 'SITECONTACTINFO' , $tp -> toHTML ( $pref [ 'sitecontactinfo' ], true , 'emotes_off,defs' ));
2012-07-12 01:43:38 +00:00
define ( 'SITEEMAIL' , vartrue ( $pref [ 'replyto_email' ], $pref [ 'siteadminemail' ]));
2015-05-25 14:35:15 -07:00
define ( 'USER_REGISTRATION' , vartrue ( $pref [ 'user_reg' ], false )); // User Registration System Active or Not.
2015-05-30 17:06:22 -07:00
define ( 'e_DEVELOPER' , $developerMode );
unset ( $developerMode );
2012-07-12 01:43:38 +00:00
2015-08-24 17:39:28 -07:00
if ( ! empty ( $pref [ 'xurl' ]) && is_array ( $pref [ 'xurl' ]))
2013-03-16 03:58:12 -07:00
{
define ( 'XURL_FACEBOOK' , vartrue ( $pref [ 'xurl' ][ 'facebook' ], false ));
define ( 'XURL_TWITTER' , vartrue ( $pref [ 'xurl' ][ 'twitter' ], false ));
define ( 'XURL_YOUTUBE' , vartrue ( $pref [ 'xurl' ][ 'youtube' ], false ));
define ( 'XURL_GOOGLE' , vartrue ( $pref [ 'xurl' ][ 'google' ], false ));
define ( 'XURL_LINKEDIN' , vartrue ( $pref [ 'xurl' ][ 'linkedin' ], false ));
2013-03-22 22:06:12 -07:00
define ( 'XURL_GITHUB' , vartrue ( $pref [ 'xurl' ][ 'github' ], false ));
2013-05-01 01:50:41 -07:00
define ( 'XURL_FLICKR' , vartrue ( $pref [ 'xurl' ][ 'flickr' ], false ));
define ( 'XURL_INSTAGRAM' , vartrue ( $pref [ 'xurl' ][ 'instagram' ], false ));
2013-11-04 18:35:26 -08:00
define ( 'XURL_PINTEREST' , vartrue ( $pref [ 'xurl' ][ 'pinterest' ], false ));
define ( 'XURL_VIMEO' , vartrue ( $pref [ 'xurl' ][ 'vimeo' ], false ));
2013-03-16 03:58:12 -07:00
}
else
{
define ( 'XURL_FACEBOOK' , false );
define ( 'XURL_TWITTER' , false );
define ( 'XURL_YOUTUBE' , false );
define ( 'XURL_GOOGLE' , false );
2013-05-01 01:50:41 -07:00
define ( 'XURL_LINKEDIN' , false );
define ( 'XURL_GITHUB' , false );
define ( 'XURL_FLICKR' , false );
define ( 'XURL_INSTAGRAM' , false );
2013-11-04 18:35:26 -08:00
define ( 'XURL_PINTEREST' , false );
define ( 'XURL_VIMEO' , false );
2013-03-16 03:58:12 -07:00
}
2006-12-02 04:36:16 +00:00
2014-10-23 04:35:42 -07:00
if ( ! defined ( 'MAIL_IDENTIFIER' ))
{
define ( 'MAIL_IDENTIFIER' , 'X-e107-id' );
}
2008-10-11 11:55:18 +00:00
/* Withdrawn 0.8
2006-12-02 04:36:16 +00:00
// legacy module.php file loading.
if ( isset ( $pref [ 'modules' ]) && $pref [ 'modules' ]) {
$mods = explode ( " , " , $pref [ 'modules' ]);
foreach ( $mods as $mod ) {
if ( is_readable ( e_PLUGIN . " { $mod } /module.php " )) {
require_once ( e_PLUGIN . " { $mod } /module.php " );
}
}
}
2008-10-11 11:55:18 +00:00
*/
2007-09-27 20:58:11 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Load Plugin Modules' );
2014-01-12 05:34:48 -08:00
2007-09-27 20:58:11 +00:00
$js_body_onload = array (); // Initialise this array in case a module wants to add to it
2006-12-02 04:36:16 +00:00
// Load e_modules after all the constants, but before the themes, so they can be put to use.
2008-11-27 02:18:25 +00:00
if ( isset ( $pref [ 'e_module_list' ]) && $pref [ 'e_module_list' ])
{
foreach ( $pref [ 'e_module_list' ] as $mod )
{
if ( is_readable ( e_PLUGIN . " { $mod } /e_module.php " ))
{
2006-12-02 04:36:16 +00:00
require_once ( e_PLUGIN . " { $mod } /e_module.php " );
}
}
}
2012-06-14 04:13:16 +00:00
2006-12-02 04:36:16 +00:00
//
// P: THEME LOADING
//
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Load Theme' );
2006-12-02 04:36:16 +00:00
2016-09-12 10:09:33 -07:00
if ( ! defined ( " USERTHEME " ))
{
define ( 'USERTHEME' , ( e107 :: getUser () -> getPref ( 'sitetheme' ) && file_exists ( e_THEME . e107 :: getUser () -> getPref ( 'sitetheme' ) . " /theme.php " ) ? e107 :: getUser () -> getPref ( 'sitetheme' ) : false ));
}
2006-12-02 04:36:16 +00:00
//########### Module redefinable functions ###############
2008-11-27 02:18:25 +00:00
if ( ! function_exists ( 'checkvalidtheme' ))
{
2009-07-12 14:44:57 +00:00
2008-11-27 02:18:25 +00:00
function checkvalidtheme ( $theme_check )
{
2006-12-02 04:36:16 +00:00
// arg1 = theme to check
2011-01-03 10:54:08 +00:00
//global $ADMIN_DIRECTORY, $tp, $e107;
$e107 = e107 :: getInstance ();
$tp = e107 :: getParser ();
$ADMIN_DIRECTORY = $e107 -> getFolder ( 'admin' );
2011-11-25 17:17:09 +00:00
// e_QUERY not set when in single entry mod
if ( ADMIN && strpos ( $_SERVER [ 'QUERY_STRING' ], 'themepreview' ) !== false )
2008-11-27 02:18:25 +00:00
{
2012-11-28 02:23:01 -08:00
list ( $action , $id ) = explode ( '.' , $_SERVER [ 'QUERY_STRING' ]);
2009-07-12 14:44:57 +00:00
2009-07-06 05:59:42 +00:00
require_once ( e_HANDLER . 'theme_handler.php' );
2009-07-12 14:44:57 +00:00
$themeobj = new themeHandler ;
$themeArray = $themeobj -> getThemes ( 'id' );
$themeDef = $themeobj -> findDefault ( $themeArray [ $id ]);
2012-11-28 02:23:01 -08:00
$id = intval ( $id );
2009-07-12 14:44:57 +00:00
define ( 'THEME_LAYOUT' , $themeDef );
2009-07-06 05:59:42 +00:00
2008-11-27 02:18:25 +00:00
define ( 'PREVIEWTHEME' , e_THEME . $themeArray [ $id ] . '/' );
define ( 'PREVIEWTHEMENAME' , $themeArray [ $id ]);
define ( 'THEME' , e_THEME . $themeArray [ $id ] . '/' );
define ( 'THEME_ABS' , e_THEME_ABS . $themeArray [ $id ] . '/' );
2012-11-28 02:23:01 -08:00
2006-12-02 04:36:16 +00:00
return ;
}
2008-11-27 02:18:25 +00:00
if ( @ fopen ( e_THEME . $theme_check . '/theme.php' , 'r' ))
{
define ( 'THEME' , e_THEME . $theme_check . '/' );
define ( 'THEME_ABS' , e_THEME_ABS . $theme_check . '/' );
2006-12-02 04:36:16 +00:00
$e107 -> site_theme = $theme_check ;
2008-11-27 02:18:25 +00:00
}
else
{
function search_validtheme ()
{
2011-01-03 10:54:08 +00:00
$e107 = e107 :: getInstance ();
2008-11-27 02:18:25 +00:00
$th = substr ( e_THEME , 0 , - 1 );
$handle = opendir ( $th );
while ( $file = readdir ( $handle ))
{
if ( is_dir ( e_THEME . $file ) && is_readable ( e_THEME . $file . '/theme.php' ))
{
2006-12-02 04:36:16 +00:00
closedir ( $handle );
$e107 -> site_theme = $file ;
return $file ;
}
}
closedir ( $handle );
}
2015-08-24 17:39:28 -07:00
$e107tmp_theme = 'bootstrap3' ; // set to bootstrap3 by default. search_validtheme();
2008-11-27 02:18:25 +00:00
define ( 'THEME' , e_THEME . $e107tmp_theme . '/' );
define ( 'THEME_ABS' , e_THEME_ABS . $e107tmp_theme . '/' );
if ( ADMIN && strpos ( e_SELF , $ADMIN_DIRECTORY ) === false )
{
2006-12-02 04:36:16 +00:00
echo '<script>alert("' . $tp -> toJS ( CORE_LAN1 ) . '")</script>' ;
2012-12-08 00:36:34 -08:00
$tm = e107 :: getSingleton ( 'themeHandler' );
$tm -> setTheme ( $e107tmp_theme );
// $config = e107::getConfig();
// $config->set('sitetheme','core');
2006-12-02 04:36:16 +00:00
}
}
2011-01-03 10:54:08 +00:00
$themes_dir = $e107 -> getFolder ( 'themes' );
2006-12-02 04:36:16 +00:00
$e107 -> http_theme_dir = " { $e107 -> server_path } { $themes_dir } { $e107 -> site_theme } / " ;
}
}
//
// Q: ALL OTHER SETUP CODE
//
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Misc Setup' );
2006-12-02 04:36:16 +00:00
//------------------------------------------------------------------------------------------------------------------------------------//
2009-10-20 16:00:38 +00:00
if ( ! class_exists ( 'e107table' , false ))
2008-11-27 02:18:25 +00:00
{
2009-12-13 21:52:32 +00:00
/**
* @ package e107
*/
2008-11-27 02:18:25 +00:00
class e107table
{
2009-08-14 15:57:45 +00:00
2013-05-08 17:11:17 -07:00
public $eMenuCount = 0 ;
public $eMenuArea ;
public $eMenuTotal = array ();
public $eSetStyle ;
private $themeClass = '' ;
private $adminThemeClass = '' ;
2013-05-09 00:24:02 -07:00
public $frontend = null ;
2013-05-08 17:11:17 -07:00
function __construct ()
{
// $this->themeClass = e107::getPref('sitetheme')."_theme"; // disabled at the moment.
$this -> adminThemeClass = e107 :: getPref ( 'admintheme' ) . " _admintheme " ; // Check for a class.
}
2015-04-01 11:52:50 -07:00
/**
* @ param $style
*/
function setStyle ( $style )
{
$this -> eSetStyle = $style ;
}
2012-11-26 03:23:20 -08:00
/**
2013-05-08 17:11:17 -07:00
* @ param $caption string caption text
2015-02-15 16:07:27 -08:00
* @ param $text string
2013-05-08 17:11:17 -07:00
* @ param $mode unique identifier
2012-11-26 03:23:20 -08:00
* @ param $return boolean : return the html instead of echo it .
2013-05-08 17:11:17 -07:00
* @ return null
2012-11-26 03:23:20 -08:00
*/
2013-05-08 17:11:17 -07:00
public function tablerender ( $caption , $text , $mode = 'default' , $return = false )
2008-11-27 02:18:25 +00:00
{
2009-07-22 00:49:35 +00:00
$override_tablerender = e107 :: getSingleton ( 'override' , e_HANDLER . 'override_class.php' ) -> override_check ( 'tablerender' );
2006-12-02 04:36:16 +00:00
2009-07-22 00:49:35 +00:00
if ( $override_tablerender )
2008-11-27 02:18:25 +00:00
{
$result = call_user_func ( $override_tablerender , $caption , $text , $mode , $return );
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
if ( $result == 'return' )
{
2009-07-22 00:49:35 +00:00
return '' ;
2006-12-02 04:36:16 +00:00
}
extract ( $result );
}
2008-11-27 02:18:25 +00:00
if ( $return )
{
2009-08-14 15:57:45 +00:00
if ( ! empty ( $text ) && $this -> eMenuArea )
{
$this -> eMenuCount ++ ;
}
2013-05-08 17:11:17 -07:00
2006-12-02 04:36:16 +00:00
ob_start ();
2013-05-08 17:11:17 -07:00
$this -> tablestyle ( $caption , $text , $mode );
2006-12-02 04:36:16 +00:00
$ret = ob_get_contents ();
ob_end_clean ();
2009-08-14 15:57:45 +00:00
2006-12-02 04:36:16 +00:00
return $ret ;
2009-08-14 15:57:45 +00:00
2008-11-27 02:18:25 +00:00
}
else
{
2009-08-14 15:57:45 +00:00
if ( ! empty ( $text ) && $this -> eMenuArea )
{
$this -> eMenuCount ++ ;
}
2013-05-08 17:11:17 -07:00
$this -> tablestyle ( $caption , $text , $mode );
2009-07-22 00:49:35 +00:00
return '' ;
2006-12-02 04:36:16 +00:00
}
}
2013-05-08 17:11:17 -07:00
2013-05-09 00:24:02 -07:00
2013-05-08 17:11:17 -07:00
/**
* Output the styled template .
* @ param $caption
* @ param $text
* @ param $mode
*/
private function tablestyle ( $caption , $text , $mode )
{
2013-05-09 00:24:02 -07:00
if ( class_exists ( $this -> adminThemeClass ) && ( $this -> frontend == false ))
2013-05-08 17:11:17 -07:00
{
$thm = new $this -> adminThemeClass ();
}
elseif ( class_exists ( $this -> themeClass )) // disabled at the moment.
{
$thm = new $this -> themeClass ();
}
2013-05-24 18:40:29 +02:00
if ( is_object ( vartrue ( $thm )))
2013-05-08 17:11:17 -07:00
{
$thm -> tablestyle ( $caption , $text , $mode , array ( 'menuArea' => $this -> eMenuArea , 'menuCount' => $this -> eMenuCount , 'menuTotal' => varset ( $this -> eMenuTotal [ $this -> eMenuArea ]), 'setStyle' => $this -> eSetStyle ));
}
else
{
tablestyle ( $caption , $text , $mode , array ( 'menuArea' => $this -> eMenuArea , 'menuCount' => $this -> eMenuCount , 'menuTotal' => varset ( $this -> eMenuTotal [ $this -> eMenuArea ]), 'setStyle' => $this -> eSetStyle ));
}
}
2006-12-02 04:36:16 +00:00
}
2013-05-08 17:11:17 -07:00
2006-12-02 04:36:16 +00:00
}
//#############################################################
2009-07-23 15:29:07 +00:00
//DEPRECATED, BC, call the method only when needed, $e107->ns caught by __get()
$ns = e107 :: getRender (); //TODO - find & replace $ns, $e107->ns
2006-12-02 04:36:16 +00:00
2010-10-27 11:26:21 +00:00
// EONE-134 - bad e_module could destroy e107 instance
2011-12-28 10:01:25 +00:00
$e107 = e107 :: getInstance (); // Is this needed now?
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'IP Handler and Ban Check' );
2011-12-28 10:01:25 +00:00
e107 :: getIPHandler () -> ban ();
2006-12-02 04:36:16 +00:00
2012-06-01 14:31:02 +00:00
if ( varset ( $pref [ 'force_userupdate' ]) && USER && ! isset ( $_E107 [ 'no_forceuserupdate' ]) && $_SERVER [ 'QUERY_STRING' ] !== 'logout' )
2008-01-06 22:16:37 +00:00
{
2009-12-07 20:47:37 +00:00
if ( force_userupdate ( $currentUser ))
2008-08-03 08:00:19 +00:00
{
2012-06-01 14:31:02 +00:00
header ( 'Location: ' . SITEURL . 'usersettings.php?update' );
2008-08-03 08:00:19 +00:00
exit ();
2006-12-02 04:36:16 +00:00
}
}
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Signup/splash/admin' );
2006-12-02 04:36:16 +00:00
2014-11-19 17:13:08 -08:00
if (( $pref [ 'membersonly_enabled' ] && ! isset ( $_E107 [ 'allow_guest' ])) || ( $pref [ 'maintainance_flag' ] && empty ( $_E107 [ 'cli' ]) && empty ( $_E107 [ 'no_maintenance' ])))
2008-01-06 22:16:37 +00:00
{
2009-08-20 13:54:42 +00:00
//XXX move force_userupdate() also?
2009-11-22 14:10:09 +00:00
e107 :: getRedirect () -> checkMaintenance ();
e107 :: getRedirect () -> checkMembersOnly ();
2006-12-02 04:36:16 +00:00
}
2008-05-19 08:54:38 +00:00
// ------------------------------------------------------------------------
2008-01-06 22:16:37 +00:00
if ( ! isset ( $_E107 [ 'no_prunetmp' ]))
{
2016-02-15 00:56:08 -08:00
$sql -> delete ( 'tmp' , 'tmp_time < ' . ( time () - 300 ) . " AND tmp_ip!='data' AND tmp_ip!='submitted_link' " );
2008-01-06 22:16:37 +00:00
}
2006-12-02 04:36:16 +00:00
2009-01-04 16:00:19 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Login/logout/ban/tz' );
2006-12-02 04:36:16 +00:00
2009-01-04 16:00:19 +00:00
2008-11-25 16:26:03 +00:00
if ( isset ( $_POST [ 'userlogin' ]) || isset ( $_POST [ 'userlogin_x' ]))
2008-06-13 20:20:23 +00:00
{
2010-05-14 18:45:51 +00:00
e107 :: getUser () -> login ( $_POST [ 'username' ], $_POST [ 'userpass' ], $_POST [ 'autologin' ], varset ( $_POST [ 'hashchallenge' ], '' ), false );
// e107_require_once(e_HANDLER.'login.php');
// $usr = new userlogin($_POST['username'], $_POST['userpass'], $_POST['autologin'], varset($_POST['hashchallenge'],''));
2006-12-02 04:36:16 +00:00
}
2013-06-09 20:53:44 +01:00
2010-10-26 07:41:20 +00:00
// $_SESSION['ubrowser'] check not needed anymore - see session handler
2011-11-25 17:17:09 +00:00
// e_QUERY not defined in single entry mod
if (( $_SERVER [ 'QUERY_STRING' ] == 'logout' ) /* || (($pref['user_tracking'] == 'session') && isset($_SESSION['ubrowser']) && ($_SESSION['ubrowser'] != $ubrowser))*/ )
2007-12-15 15:06:40 +00:00
{
2009-01-04 16:00:19 +00:00
if ( USER )
{
2016-03-16 13:53:57 -07:00
if ( check_class ( varset ( $pref [ 'user_audit_class' ], '' ))) // Need to note in user audit trail
{
e107 :: getLog () -> user_audit ( USER_AUDIT_LOGOUT , '' , USERID , USERNAME );
2009-01-04 16:00:19 +00:00
}
2007-12-15 15:06:40 +00:00
}
2012-01-02 22:06:22 +00:00
// $ip = e107::getIPHandler()->getIP(FALSE); Appears to not be used, so removed
2008-11-27 02:18:25 +00:00
$udata = ( USER === true ? USERID . '.' . USERNAME : '0' );
2011-06-07 12:40:34 +00:00
2010-10-26 07:41:20 +00:00
// TODO - should be done inside online handler, more core areas need it (session handler for example)
2011-08-12 19:27:13 +00:00
if ( isset ( $pref [ 'track_online' ]) && $pref [ 'track_online' ])
{
2016-02-15 00:56:08 -08:00
$sql -> update ( 'online' , " online_user_id = 0, online_pagecount=online_pagecount+1 WHERE online_user_id = ' { $udata } ' " );
2011-08-12 19:27:13 +00:00
}
2011-12-06 08:00:42 +00:00
// earlier event trigger with user data still available
e107 :: getEvent () -> trigger ( 'logout' );
2012-06-15 11:30:37 +00:00
// first model logout and session destroy..
e107 :: getUser () -> logout ();
// it might be removed soon
2009-08-28 15:21:23 +00:00
if ( $pref [ 'user_tracking' ] == 'session' )
2009-01-04 16:00:19 +00:00
{
2006-12-02 04:36:16 +00:00
session_destroy ();
2008-11-27 02:18:25 +00:00
$_SESSION [ e_COOKIE ] = '' ;
2013-06-09 20:53:44 +01:00
// @TODO: Need to destroy the session cookie as well (not done by session_destroy()
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
cookie ( e_COOKIE , '' , ( time () - 2592000 ));
2011-09-14 11:30:58 +00:00
2011-11-25 17:17:09 +00:00
e107 :: getRedirect () -> redirect ( SITEURL );
2009-11-22 14:10:09 +00:00
// header('location:'.e_BASE.'index.php');
2009-05-26 20:18:07 +00:00
exit ();
2006-12-02 04:36:16 +00:00
}
/*
* Calculate time zone offset , based on session cookie set in e107 . js .
* ( Buyer beware : this may be wrong for the first pageview in a session ,
* which is while the user is logged out , so not a problem ... )
*
* Time offset is SECONDS . Seconds is much better than hours as a base ,
* as some places have 30 and 45 minute time zones .
* It matches user clock time , instead of only time zones .
* Add the offset to MySQL / server time to get user time .
* Subtract the offset from user time to get server time .
*
*/
2014-01-17 07:20:11 -08:00
$tz = vartrue ( $pref [ 'timezone' ], 'GMT' ); //TODO Adjust on the front-end based on user timezone value.
date_default_timezone_set ( $tz ); // Must be set or PHP Warning thrown.
unset ( $tz );
2006-12-02 04:36:16 +00:00
$e_deltaTime = 0 ;
2008-11-27 02:18:25 +00:00
if ( isset ( $_COOKIE [ 'e107_tdOffset' ]))
{
2006-12-02 04:36:16 +00:00
// Actual seconds of delay. See e107.js and footer_default.php
2012-08-10 11:37:20 +00:00
$e_deltaTime = ( 15 * floor (( intval ( $_COOKIE [ 'e107_tdOffset' ]) / 60 ) / 15 )) * 60 ; // Delay in seconds rounded to the lowest quarter hour
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
if ( isset ( $_COOKIE [ 'e107_tzOffset' ]))
{
2006-12-02 04:36:16 +00:00
// Relative client-to-server time zone offset in seconds.
2012-08-10 11:37:20 +00:00
$e_deltaTime += ( - ( intval ( $_COOKIE [ 'e107_tzOffset' ]) * 60 + date ( " Z " )));
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
define ( 'TIMEOFFSET' , $e_deltaTime );
2006-12-02 04:36:16 +00:00
2014-01-17 07:20:11 -08:00
2009-07-07 16:04:51 +00:00
// ----------------------------------------------------------------------------
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Find/Load Theme' );
2009-07-12 14:44:57 +00:00
2009-11-22 14:10:09 +00:00
if ( e_ADMIN_AREA ) // Load admin phrases ASAP
2010-02-10 21:53:56 +00:00
{
2009-11-22 14:10:09 +00:00
e107 :: includeLan ( e_LANGUAGEDIR . e_LANGUAGE . '/admin/lan_admin.php' );
}
2009-07-12 14:44:57 +00:00
if ( ! defined ( 'THEME' ))
{
2010-02-10 21:53:56 +00:00
2015-02-14 23:34:15 -08:00
if ( e_ADMIN_AREA && vartrue ( $pref [ 'admintheme' ]))
2009-07-12 14:44:57 +00:00
{
2009-08-19 14:39:57 +00:00
//We have now e_IFRAME mod and USER_AREA force
// && (strpos(e_SELF.'?'.e_QUERY, 'menus.php?configure') === FALSE)
2009-08-28 15:21:23 +00:00
2009-07-12 14:44:57 +00:00
/* if ( strpos ( e_SELF , " newspost.php " ) !== FALSE )
{
define ( " MAINTHEME " , e_THEME . $pref [ 'sitetheme' ] . " / " ); MAINTHEME no longer used in core distribution
} */
2009-07-18 10:17:56 +00:00
checkvalidtheme ( $pref [ 'admintheme' ]);
2009-07-12 14:44:57 +00:00
}
2009-09-29 17:45:06 +00:00
elseif ( USERTHEME !== false /* && USERTHEME != 'USERTHEME'*/ && ! e_ADMIN_AREA )
2009-07-12 14:44:57 +00:00
{
2009-07-18 10:17:56 +00:00
checkvalidtheme ( USERTHEME );
2009-07-12 14:44:57 +00:00
}
else
{
2009-07-18 10:17:56 +00:00
checkvalidtheme ( $pref [ 'sitetheme' ]);
2009-07-12 14:44:57 +00:00
}
}
$theme_pref = varset ( $pref [ 'sitetheme_pref' ]);
// --------------------------------------------------------------
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Find/Load Theme-Layout' ); // needs to run after checkvalidtheme() (for theme previewing).
2009-07-07 16:04:51 +00:00
if ( ! defined ( " THEME_LAYOUT " ))
{
$def = " " ; // no custom pages found yet.
2009-09-06 22:12:39 +00:00
$cusPagePref = ( varset ( $user_pref [ 'sitetheme_custompages' ])) ? $user_pref [ 'sitetheme_custompages' ] : varset ( $pref [ 'sitetheme_custompages' ]);
2009-07-07 16:04:51 +00:00
2009-07-24 12:54:39 +00:00
if ( is_array ( $cusPagePref ) && count ( $cusPagePref ) > 0 ) // check if we match a page in layout custompages.
2009-07-07 16:04:51 +00:00
{
2011-06-07 12:40:34 +00:00
//e_SELF.(e_QUERY ? '?'.e_QUERY : '');
2011-12-02 16:33:31 +00:00
$c_url = str_replace ( array ( '&' ), array ( '&' ), e_REQUEST_URL ); //.(e_QUERY ? '?'.e_QUERY : '');// mod_rewrite support
2012-06-11 10:35:21 +00:00
// FIX - check against urldecoded strings
2014-07-24 20:44:17 +03:00
$c_url = rtrim ( rawurldecode ( $c_url ), '?' );
2011-12-02 16:33:31 +00:00
2009-07-07 22:56:13 +00:00
foreach ( $cusPagePref as $lyout => $cusPageArray )
2009-07-07 16:04:51 +00:00
{
2009-09-25 20:21:30 +00:00
if ( ! is_array ( $cusPageArray )) { continue ; }
2011-12-02 16:33:31 +00:00
// NEW - Front page template check - early
if ( in_array ( 'FRONTPAGE' , $cusPageArray ) && ( $c_url == SITEURL || rtrim ( $c_url , '/' ) == SITEURL . 'index.php' ))
{
$def = $lyout ;
break ;
}
2009-07-07 16:04:51 +00:00
foreach ( $cusPageArray as $kpage )
{
2009-09-25 20:21:30 +00:00
if ( substr ( $kpage , - 1 ) === '!' )
{
$kpage = rtrim ( $kpage , '!' );
if ( substr ( $c_url , - strlen ( $kpage )) === $kpage )
{
$def = $lyout ;
break 2 ;
}
continue ;
}
2011-12-06 09:44:28 +00:00
if ( $kpage && ( $kpage == defset ( 'e_PAGE' ) || strpos ( $c_url , $kpage ) !== false ))
2009-07-07 16:04:51 +00:00
{
2009-07-09 08:31:38 +00:00
// $def = ($lyout) ? $lyout : "legacyCustom";
$def = $lyout ;
2009-08-27 12:56:23 +00:00
break 2 ;
2009-07-07 16:04:51 +00:00
}
}
}
}
2009-08-19 14:39:57 +00:00
/* Done via e_IFRAME and USER_AREA force combination , check moved to menu . php
2009-07-09 08:31:38 +00:00
if ( strpos ( e_SELF . '?' . e_QUERY , $ADMIN_DIRECTORY . 'menus.php?configure' ) !== FALSE )
{
$menus_equery = explode ( '.' , e_QUERY );
$def = $menus_equery [ 1 ];
}
2009-08-19 14:39:57 +00:00
*/
2009-08-28 15:21:23 +00:00
2013-06-17 15:40:39 -07:00
if ( varset ( $pref [ 'themecss' ]) && file_exists ( THEME . $pref [ 'themecss' ]))
{
define ( " THEME_STYLE " , $pref [ 'themecss' ]);
}
else
{
define ( " THEME_STYLE " , 'style.css' );
}
2009-07-07 16:04:51 +00:00
if ( $def ) // custom-page layout.
{
define ( " THEME_LAYOUT " , $def );
}
else // default layout.
{
2009-07-09 08:31:38 +00:00
$deflayout = ( ! isset ( $user_pref [ 'sitetheme_deflayout' ])) ? varset ( $pref [ 'sitetheme_deflayout' ]) : $user_pref [ 'sitetheme_deflayout' ];
2009-12-13 21:52:32 +00:00
/**
* @ ignore
*/
2009-07-07 22:56:13 +00:00
define ( " THEME_LAYOUT " , $deflayout ); // default layout.
2009-07-07 16:04:51 +00:00
}
2009-07-09 08:31:38 +00:00
unset ( $def , $lyout , $cusPagePref , $menus_equery , $deflayout );
2009-07-07 22:56:13 +00:00
2009-07-07 16:04:51 +00:00
}
// -----------------------------------------------------------------------
2016-06-01 10:41:47 -07:00
2008-01-06 22:16:37 +00:00
if ( ! isset ( $_E107 [ 'no_menus' ]))
{
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Init Menus' );
2009-08-16 16:30:56 +00:00
e107 :: getMenu () -> init ();
2009-07-06 05:59:42 +00:00
}
2008-01-06 22:16:37 +00:00
// here we USE the theme
2016-02-26 12:50:48 -08:00
if ( e_ADMIN_AREA )
2008-01-06 22:16:37 +00:00
{
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Loading Admin Theme' );
2016-02-26 12:50:48 -08:00
if ( file_exists ( THEME . 'admin_theme.php' ) && ( strpos ( e_SELF . '?' . e_QUERY , $ADMIN_DIRECTORY . 'menus.php?configure' ) === FALSE )) // no admin theme when previewing.
2009-08-19 14:39:57 +00:00
{
2016-02-26 12:50:48 -08:00
require_once ( THEME . 'admin_theme.php' );
2009-08-19 14:39:57 +00:00
}
else
{
require_once ( THEME . 'theme.php' );
}
2008-11-25 16:26:03 +00:00
}
2016-02-26 12:50:48 -08:00
else
{
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Loading Site Theme' );
2016-02-26 12:50:48 -08:00
require_once ( THEME . 'theme.php' );
if ( isset ( $SC_WRAPPER ))
{
e107 :: scStyle ( $SC_WRAPPER );
}
}
2008-05-29 21:12:55 +00:00
2008-08-14 13:18:26 +00:00
//----------------------------
// Load shortcode handler
//----------------------------
// ********* This is probably a bodge! Work out what to do properly. Has to be done when $pref valid
//FIXED - undefined $register_sc
2009-07-23 15:29:07 +00:00
//$tp->sch_load(); - will be auto-initialized by first $tp->e_sc call - see e_parse->__get()
2008-05-29 21:12:55 +00:00
2009-08-28 16:15:57 +00:00
/*
2008-11-27 02:18:25 +00:00
$exclude_lan = array ( 'lan_signup.php' ); // required for multi-language.
2006-12-02 04:36:16 +00:00
2008-05-29 21:12:55 +00:00
if ( $inAdminDir )
{
2009-08-19 14:39:57 +00:00
e107_include_once ( e_LANGUAGEDIR . e_LANGUAGE . '/admin/lan_' . e_PAGE );
e107_include_once ( e_LANGUAGEDIR . 'English/admin/lan_' . e_PAGE );
2008-11-25 16:26:03 +00:00
}
2008-11-27 02:18:25 +00:00
elseif ( ! in_array ( 'lan_' . e_PAGE , $exclude_lan ) && ! $isPluginDir )
2008-05-29 21:12:55 +00:00
{
2009-08-19 14:39:57 +00:00
e107_include_once ( e_LANGUAGEDIR . e_LANGUAGE . '/lan_' . e_PAGE );
e107_include_once ( e_LANGUAGEDIR . 'English/lan_' . e_PAGE );
2006-12-02 04:36:16 +00:00
}
2009-08-28 16:15:57 +00:00
*/
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
if ( $pref [ 'anon_post' ] ? define ( 'ANON' , true ) : define ( 'ANON' , false ));
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
if ( empty ( $pref [ 'newsposts' ]) ? define ( 'ITEMVIEW' , 15 ) : define ( 'ITEMVIEW' , $pref [ 'newsposts' ]));
2006-12-02 04:36:16 +00:00
2013-11-06 15:28:50 -08:00
if ( $pref [ 'antiflood1' ] == 1 && ! defined ( 'FLOODPROTECT' ))
2007-09-18 21:15:41 +00:00
{
2009-08-19 14:39:57 +00:00
define ( 'FLOODPROTECT' , TRUE );
define ( 'FLOODTIMEOUT' , max ( varset ( $pref [ 'antiflood_timeout' ], 10 ), 3 ));
2007-09-18 21:15:41 +00:00
}
else
{
2009-12-13 21:52:32 +00:00
/**
* @ ignore
*/
define ( 'FLOODPROTECT' , FALSE );
2006-12-02 04:36:16 +00:00
}
$layout = isset ( $layout ) ? $layout : '_default' ;
2013-03-20 16:58:39 -07:00
define ( 'HEADERF' , e_CORE . " templates/header { $layout } .php " );
define ( 'FOOTERF' , e_CORE . " templates/footer { $layout } .php " );
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
if ( ! file_exists ( HEADERF ))
{
message_handler ( 'CRITICAL_ERROR' , 'Unable to find file: ' . HEADERF , __LINE__ - 2 , __FILE__ );
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
if ( ! file_exists ( FOOTERF ))
{
message_handler ( 'CRITICAL_ERROR' , 'Unable to find file: ' . FOOTERF , __LINE__ - 2 , __FILE__ );
2006-12-02 04:36:16 +00:00
}
2012-02-07 16:37:44 +00:00
//define('LOGINMESSAGE', ''); - not needed, breaks login messages
2008-11-27 02:18:25 +00:00
define ( 'OPEN_BASEDIR' , ( ini_get ( 'open_basedir' ) ? true : false ));
define ( 'SAFE_MODE' , ( ini_get ( 'safe_mode' ) ? true : false ));
define ( 'FILE_UPLOADS' , ( ini_get ( 'file_uploads' ) ? true : false ));
define ( 'INIT' , true );
if ( isset ( $_SERVER [ 'HTTP_REFERER' ]))
{
2006-12-02 04:36:16 +00:00
$tmp = explode ( " ? " , $_SERVER [ 'HTTP_REFERER' ]);
2011-12-06 09:44:28 +00:00
define ( 'e_REFERER_SELF' ,( $tmp [ 0 ] == e_REQUEST_SELF ));
unset ( $tmp );
2008-11-27 02:18:25 +00:00
}
else
{
2009-12-13 21:52:32 +00:00
/**
* @ ignore
*/
2006-12-02 04:36:16 +00:00
define ( 'e_REFERER_SELF' , FALSE );
}
2009-10-20 16:00:38 +00:00
//BC, DEPRECATED - use e107::getDateConvert(), catched by __autoload as well
/* if ( ! class_exists ( 'convert' ))
2006-12-02 04:36:16 +00:00
{
2008-11-27 02:18:25 +00:00
require_once ( e_HANDLER . 'date_handler.php' );
2009-10-20 16:00:38 +00:00
} */
2006-12-02 04:36:16 +00:00
//@require_once(e_HANDLER."IPB_int.php");
//@require_once(e_HANDLER."debug_handler.php");
2009-08-03 19:51:24 +00:00
//-------------------------------------------------------------------------------------------------------------------------------------------
2008-11-27 02:18:25 +00:00
function js_location ( $qry )
{
2006-12-05 09:33:20 +00:00
global $error_handler ;
2008-11-27 02:18:25 +00:00
if ( count ( $error_handler -> errors ))
{
2006-12-05 09:33:20 +00:00
echo $error_handler -> return_errors ();
exit ;
2008-11-27 02:18:25 +00:00
}
else
{
2008-12-02 18:27:35 +00:00
echo " <script type='text/javascript'>document.location.href=' { $qry } '</script> \n " ;
2008-11-27 02:18:25 +00:00
exit ;
2007-12-26 13:21:34 +00:00
}
2006-12-05 09:33:20 +00:00
}
2006-12-02 04:36:16 +00:00
2008-11-27 02:18:25 +00:00
function check_email ( $email )
2015-08-25 13:00:53 -07:00
{
if ( empty ( $email ))
{
return false ;
}
if ( is_numeric ( substr ( $email , - 1 ))) // fix for eCaptcha accidently typed on wrong line.
{
return false ;
}
2014-05-22 18:16:44 -07:00
if ( filter_var ( $email , FILTER_VALIDATE_EMAIL ))
{
return $email ;
}
return false ;
// return preg_match("/^([_a-zA-Z0-9-+]+)(\.[_a-zA-Z0-9-]+)*@([a-zA-Z0-9-]+)(\.[a-zA-Z0-9-]+)*(\.[a-zA-Z]{2,6})$/" , $email) ? $email : false;
2006-12-02 04:36:16 +00:00
}
2009-08-03 19:51:24 +00:00
//---------------------------------------------------------------------------------------------------------------------------------------------
2014-01-12 08:05:12 -08:00
/**
* @ param $var is a single class number or name , or a comma - separated list of the same .
* @ param $userclass a custom list of userclasses or leave blank for the current user ' s permissions .
* If a class is prefixed with '-' this means 'exclude' - returns FALSE if the user is in this class ( overrides 'includes' ) .
* Otherwise returns TRUE if the user is in any of the classes listed in $var .
*/
2007-01-12 02:36:18 +00:00
function check_class ( $var , $userclass = USERCLASS_LIST , $uid = 0 )
2006-12-02 04:36:16 +00:00
{
2009-08-03 19:51:24 +00:00
$e107 = e107 :: getInstance ();
2009-08-05 19:58:32 +00:00
if ( $var == e_LANGUAGE )
{
return TRUE ;
}
2007-12-15 09:55:37 +00:00
2015-04-16 15:23:57 -07:00
if ( e107 :: isCli ())
{
return true ;
}
2007-01-12 02:36:18 +00:00
if ( is_numeric ( $uid ) && $uid > 0 )
2009-08-03 19:51:24 +00:00
{ // userid has been supplied, go build that user's class list
2007-01-12 02:36:18 +00:00
$userclass = class_list ( $uid );
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
if ( $userclass == '' )
2006-12-02 04:36:16 +00:00
{
2009-08-08 23:09:08 +00:00
return FALSE ;
2006-12-02 04:36:16 +00:00
}
2010-05-02 18:41:20 +00:00
$class_array = ! is_array ( $userclass ) ? explode ( ',' , $userclass ) : $userclass ;
2006-12-02 04:36:16 +00:00
2010-05-02 18:41:20 +00:00
$varList = ! is_array ( $var ) ? explode ( ',' , $var ) : $var ;
2009-08-03 19:51:24 +00:00
$latchedAccess = FALSE ;
2008-11-25 16:26:03 +00:00
2007-01-12 02:36:18 +00:00
foreach ( $varList as $v )
{
2009-08-08 23:09:08 +00:00
$v = trim ( $v );
2009-08-03 19:51:24 +00:00
$invert = FALSE ;
2009-08-08 23:09:08 +00:00
//value to test is a userclass name (or garbage, of course), go get the id
if ( ! is_numeric ( $v ))
2006-12-02 04:36:16 +00:00
{
2009-08-08 23:09:08 +00:00
if ( substr ( $v , 0 , 1 ) == '-' )
2009-08-03 19:51:24 +00:00
{
$invert = TRUE ;
2009-08-08 23:09:08 +00:00
$v = substr ( $v , 1 );
2009-08-03 19:51:24 +00:00
}
$v = $e107 -> user_class -> ucGetClassIDFromName ( $v );
2006-12-02 04:36:16 +00:00
}
2009-08-03 19:51:24 +00:00
elseif ( $v < 0 )
2007-01-12 02:36:18 +00:00
{
2009-08-03 19:51:24 +00:00
$invert = TRUE ;
$v = - $v ;
}
if ( $v !== FALSE )
2009-08-08 23:09:08 +00:00
{
// Ignore non-valid userclass names
if ( in_array ( $v , $class_array ) || ( $v === '0' ) || ( $v === 0 ))
2007-01-12 02:36:18 +00:00
{
2009-08-03 19:51:24 +00:00
if ( $invert )
2007-01-12 02:36:18 +00:00
{
2009-08-03 19:51:24 +00:00
return FALSE ;
2006-12-02 04:36:16 +00:00
}
2009-08-03 19:51:24 +00:00
$latchedAccess = TRUE ;
2007-01-12 02:36:18 +00:00
}
2009-08-03 19:51:24 +00:00
elseif ( $invert && count ( $varList ) == 1 )
2007-01-12 02:36:18 +00:00
{
2009-08-08 23:09:08 +00:00
// Handle scenario where only an 'exclude' class is passed
$latchedAccess = TRUE ;
2006-12-02 04:36:16 +00:00
}
}
}
2009-08-03 19:51:24 +00:00
return $latchedAccess ;
2006-12-02 04:36:16 +00:00
}
2009-08-03 19:51:24 +00:00
2008-11-27 02:18:25 +00:00
function getperms ( $arg , $ap = ADMINPERMS )
{
2011-06-07 12:40:34 +00:00
// $ap = "4"; // Just for testing.
2011-05-11 11:52:50 +00:00
if ( ! ADMIN || trim ( $ap ) === '' )
{
return FALSE ;
}
2011-06-07 12:40:34 +00:00
2011-05-11 11:52:50 +00:00
if ( $arg === 0 ) // Common-error avoidance with getperms(0)
2008-11-27 02:18:25 +00:00
{
2011-05-11 11:52:50 +00:00
$arg = '0' ;
2006-12-02 04:36:16 +00:00
}
2010-02-10 21:53:56 +00:00
if ( $ap === '0' || $ap === '0.' ) // BC fix.
2008-11-27 02:18:25 +00:00
{
2011-05-11 11:52:50 +00:00
return TRUE ;
2006-12-02 04:36:16 +00:00
}
2009-09-12 16:42:44 +00:00
if ( $arg == 'P' && preg_match ( " #(.*?)/ " . e107 :: getInstance () -> getFolder ( 'plugins' ) . " (.*?)/(.*?)# " , e_SELF , $matches ))
2008-11-27 02:18:25 +00:00
{
2009-12-24 10:51:23 +00:00
$sql = e107 :: getDb ( 'psql' );
2010-02-10 21:53:56 +00:00
2010-05-02 18:41:20 +00:00
// FIXME - cache it, avoid sql query here
2016-02-15 00:56:08 -08:00
if ( $sql -> select ( 'plugin' , 'plugin_id' , " plugin_path = ' " . $matches [ 2 ] . " ' LIMIT 1 " ))
2008-11-27 02:18:25 +00:00
{
2016-02-15 00:56:08 -08:00
$row = $sql -> fetch ();
2010-02-10 21:53:56 +00:00
$arg = 'P' . $row [ 'plugin_id' ];
2006-12-02 04:36:16 +00:00
}
}
2010-02-10 21:53:56 +00:00
2009-12-24 10:51:23 +00:00
$ap_array = explode ( '.' , $ap );
2009-08-05 14:18:09 +00:00
2011-05-11 11:52:50 +00:00
if ( in_array ( $arg , $ap_array , FALSE ))
2008-11-27 02:18:25 +00:00
{
2011-05-11 11:52:50 +00:00
return TRUE ;
2008-11-27 02:18:25 +00:00
}
2009-09-29 09:25:35 +00:00
elseif ( strpos ( $arg , " | " )) // check for multiple perms - separated by '|'.
2009-08-05 14:18:09 +00:00
{
2009-09-29 09:25:35 +00:00
$tmp = explode ( " | " , $arg );
2009-08-05 14:18:09 +00:00
foreach ( $tmp as $val )
{
2011-05-11 11:52:50 +00:00
if ( in_array ( $val , $ap_array ))
2009-08-05 14:18:09 +00:00
{
2011-05-11 11:52:50 +00:00
return TRUE ;
2009-08-05 14:18:09 +00:00
}
}
}
2008-11-27 02:18:25 +00:00
else
{
2011-05-11 11:52:50 +00:00
return FALSE ;
2006-12-02 04:36:16 +00:00
}
}
/**
2015-02-15 16:07:27 -08:00
* @ deprecated
2006-12-02 04:36:16 +00:00
* Get the user data from user and user_extended tables
2013-03-31 04:23:11 -07:00
* SO MUCH DEPRECATED ! Use e107 :: user ( $uid );
2006-12-02 04:36:16 +00:00
* @ return array
*/
2008-11-27 02:18:25 +00:00
function get_user_data ( $uid , $extra = '' )
2006-12-02 04:36:16 +00:00
{
2010-05-17 15:51:42 +00:00
if ( e107 :: getPref ( 'developer' ))
{
e107 :: getAdminLog () -> log_event (
'Deprecated call - get_user_data()' ,
2015-01-26 18:03:14 -08:00
'Call to deprecated function get_user_data() (class2.php) ' . " \n " . print_r ( debug_backtrace ( null , 2 ), true ),
2010-05-17 15:51:42 +00:00
E_LOG_INFORMATIVE ,
'DEPRECATED'
);
// TODO - debug screen Deprecated Functions (e107)
2015-01-26 18:03:14 -08:00
e107 :: getMessage () -> addDebug ( 'Deprecated get_user_data() backtrace:<pre>' . " \n " . print_r ( debug_backtrace ( null , 2 ), true ) . '</pre>' );
2010-05-17 15:51:42 +00:00
}
$var = array ();
$user = e107 :: getSystemUser ( $uid , true );
if ( $user )
{
$var = $user -> getUserData ();
}
return $var ;
2006-12-02 04:36:16 +00:00
}
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
2014-01-10 07:36:54 -08:00
//SO MUCH DEPRECATED
/**
* @ deprecated
* @ example Use instead : e107 :: getConfig ( alias ) ->-> setPref ( $array ) -> save (); Not to be used for saving plugin or theme prefs !
*/
2008-01-16 10:53:57 +00:00
function save_prefs ( $table = 'core' , $uid = USERID , $row_val = '' )
2007-02-03 12:43:53 +00:00
{
2010-03-14 02:11:23 +00:00
global $pref , $user_pref , $tp , $PrefCache , $sql , $eArrayStorage , $theme_pref ;
2009-08-28 15:21:23 +00:00
2010-05-17 15:51:42 +00:00
if ( e107 :: getPref ( 'developer' ))
{
2014-01-10 07:36:54 -08:00
$backtrace = debug_backtrace ( false );
2014-01-10 09:32:14 -08:00
e107 :: getAdminLog () -> add (
2010-05-17 15:51:42 +00:00
'Deprecated call - save_prefs()' ,
2014-01-10 07:36:54 -08:00
" Call to deprecated function save_prefs() (class2.php). Backtrace: \n " . print_r ( $backtrace , true ),
2010-05-17 15:51:42 +00:00
E_LOG_INFORMATIVE ,
'DEPRECATED'
);
2014-01-10 07:36:54 -08:00
e107 :: getMessage () -> addDebug ( 'Deprecated save_prefs() backtrace:<pre>' . " \n " . print_r ( $backtrace , true ) . '</pre>' );
2010-05-17 15:51:42 +00:00
}
2009-08-17 14:40:23 +00:00
switch ( $table )
{
case 'core' :
//brute load, force update
return e107 :: getConfig () -> loadData ( $pref , false ) -> save ( false , true );
break ;
2009-08-28 15:21:23 +00:00
2009-08-17 14:40:23 +00:00
case 'theme' :
//brute load, force update
return e107 :: getConfig () -> set ( 'sitetheme_pref' , $theme_pref ) -> save ( false , true );
break ;
2009-08-28 15:21:23 +00:00
2009-08-17 14:40:23 +00:00
default :
2010-09-06 21:35:04 +00:00
$_user_pref = $tp -> toDB ( $user_pref , true , true , 'pReFs' );
2009-08-17 14:40:23 +00:00
$tmp = $eArrayStorage -> WriteArray ( $_user_pref );
2016-02-15 00:56:08 -08:00
$sql -> update ( 'user' , " user_prefs=' $tmp ' WHERE user_id= " . intval ( $uid ));
2009-08-17 14:40:23 +00:00
return $tmp ;
break ;
}
2006-12-02 04:36:16 +00:00
}
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
2015-02-15 16:07:27 -08:00
/**
* @ deprecated use e107 :: setRegistry ()
* @ param $id
* @ param $var
*/
2008-11-27 02:18:25 +00:00
function cachevars ( $id , $var )
{
2009-07-22 00:49:35 +00:00
e107 :: setRegistry ( 'core/cachedvars/' . $id , $var );
2006-12-02 04:36:16 +00:00
}
2015-02-15 16:07:27 -08:00
/**
* @ deprecated use e107 :: getRegistry ()
* @ param $id
* @ return mixed
*/
2008-11-27 02:18:25 +00:00
function getcachedvars ( $id )
{
2009-08-06 22:39:36 +00:00
return e107 :: getRegistry ( 'core/cachedvars/' . $id , false );
2006-12-02 04:36:16 +00:00
}
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
2009-12-13 21:52:32 +00:00
/**
* @ package e107
*/
2008-11-27 02:18:25 +00:00
class floodprotect
{
function flood ( $table , $orderfield )
{
2006-12-02 04:36:16 +00:00
/*
# Test for possible flood
#
# - parameter #1 string $table, table being affected
# - parameter #2 string $orderfield, date entry in respective table
# - return boolean
# - scope public
*/
$sql = new db ;
2008-11-27 02:18:25 +00:00
if ( FLOODPROTECT == true )
{
2016-02-15 00:56:08 -08:00
$sql -> select ( $table , '*' , 'ORDER BY ' . $orderfield . ' DESC LIMIT 1' , 'no_where' );
$row = $sql -> fetch ();
2008-11-27 02:18:25 +00:00
return ( $row [ $orderfield ] > ( time () - FLOODTIMEOUT ) ? false : true );
}
else
{
2006-12-02 04:36:16 +00:00
return TRUE ;
}
}
}
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
2010-05-14 18:45:51 +00:00
/**
* The whole could happen inside e_user class
* @ return void
*/
2008-11-27 02:18:25 +00:00
function init_session ()
{
2006-12-02 04:36:16 +00:00
/*
# Validate user
#
# - parameters none
# - return boolean
# - scope public
*/
2012-06-14 04:13:16 +00:00
// ----------------------------------------
2010-02-10 21:53:56 +00:00
2010-05-14 18:45:51 +00:00
global $user_pref , $currentUser ;
2010-02-10 21:53:56 +00:00
2010-05-13 15:47:31 +00:00
$e107 = e107 :: getInstance ();
2010-02-10 21:53:56 +00:00
2010-05-14 18:45:51 +00:00
// New user model
$user = e107 :: getUser ();
2006-12-02 04:36:16 +00:00
2012-01-02 22:06:22 +00:00
define ( 'USERIP' , e107 :: getIPHandler () -> getIP ( FALSE ));
2010-05-19 15:28:52 +00:00
define ( 'POST_REFERER' , md5 ( $user -> getToken ()));
// Check for intruders - outside the model for now
2010-10-26 07:41:20 +00:00
// TODO replace __referer with e-token, remove the above
2010-05-19 15:28:52 +00:00
if (( isset ( $_POST [ '__referer' ]) && ! $user -> checkToken ( $_POST [ '__referer' ]))
|| ( isset ( $_GET [ '__referer' ]) && ! $user -> checkToken ( $_GET [ '__referer' ])))
{
// Die, die, die! DIE!!!
die ( 'Unauthorized access!' );
}
2010-02-10 21:53:56 +00:00
2010-05-14 18:45:51 +00:00
if ( e107 :: isCli ())
2008-01-22 00:39:08 +00:00
{
2009-12-24 09:59:21 +00:00
define ( 'USER' , true );
define ( 'USERID' , 1 );
define ( 'USERNAME' , 'e107-cli' );
define ( 'USERTHEME' , false );
define ( 'ADMIN' , true );
define ( 'GUEST' , false );
define ( 'USERCLASS' , '' );
define ( 'USEREMAIL' , '' );
define ( 'USERCLASS_LIST' , '' );
2010-02-10 21:53:56 +00:00
define ( 'USERCLASS' , '' );
2012-07-21 03:55:04 +00:00
define ( 'USERJOINED' , '' );
2009-12-24 09:59:21 +00:00
return ;
2008-01-22 00:39:08 +00:00
}
2010-05-14 18:45:51 +00:00
if ( $user -> hasBan ())
{
$msg = e107 :: findPref ( 'ban_messages/6' );
if ( $msg ) echo e107 :: getParser () -> toHTML ( $msg );
exit ;
}
if ( ! $user -> isUser ())
2008-01-22 00:39:08 +00:00
{
2008-11-27 02:18:25 +00:00
define ( 'USER' , false );
2008-06-13 20:20:23 +00:00
define ( 'USERID' , 0 );
2008-11-27 02:18:25 +00:00
define ( 'USERTHEME' , false );
define ( 'ADMIN' , false );
define ( 'GUEST' , true );
2006-12-02 04:36:16 +00:00
define ( 'USERCLASS' , '' );
define ( 'USEREMAIL' , '' );
2013-03-19 19:04:32 -07:00
define ( 'USERSIGNATURE' , '' );
2016-03-22 11:42:05 -07:00
define ( 'ADMINPERMS' , false );
2010-05-14 18:45:51 +00:00
if ( $user -> hasSessionError ())
{
define ( 'LOGINMESSAGE' , CORE_LAN10 );
define ( 'CORRUPT_COOKIE' , true );
}
2008-01-22 00:39:08 +00:00
}
else
{
2010-05-14 18:45:51 +00:00
// we shouldn't use getValue() here, it's there for e.g. shortcodes, profile page render etc.
define ( 'USERID' , $user -> getId ());
define ( 'USERNAME' , $user -> get ( 'user_name' ));
2012-07-21 03:55:04 +00:00
define ( 'USERURL' , $user -> get ( 'user_homepage' , false )); //required for BC
2010-05-14 18:45:51 +00:00
define ( 'USEREMAIL' , $user -> get ( 'user_email' ));
define ( 'USER' , true );
define ( 'USERCLASS' , $user -> get ( 'user_class' ));
define ( 'USERIMAGE' , $user -> get ( 'user_image' ));
define ( 'USERPHOTO' , $user -> get ( 'user_sess' ));
2012-07-21 03:55:04 +00:00
define ( 'USERJOINED' , $user -> get ( 'user_join' ));
define ( 'USERVISITS' , $user -> get ( 'user_visits' ));
2013-03-19 19:04:32 -07:00
define ( 'USERSIGNATURE' , $user -> get ( 'user_signature' ));
2010-05-14 18:45:51 +00:00
define ( 'ADMIN' , $user -> isAdmin ());
define ( 'ADMINID' , $user -> getAdminId ());
define ( 'ADMINNAME' , $user -> getAdminName ());
define ( 'ADMINPERMS' , $user -> getAdminPerms ());
define ( 'ADMINEMAIL' , $user -> getAdminEmail ());
define ( 'ADMINPWCHANGE' , $user -> getAdminPwchange ());
if ( ADMIN ) // XXX - why for admins only?
{
e107 :: getRedirect () -> setPreviousUrl ();
}
define ( 'USERLV' , $user -> get ( 'user_lastvisit' ));
// BC - FIXME - get rid of them!
$currentUser = $user -> getData ();
2011-11-25 17:17:09 +00:00
$currentUser [ 'user_realname' ] = $user -> get ( 'user_login' ); // Used by force_userupdate
2010-05-14 18:45:51 +00:00
$e107 -> currentUser = & $currentUser ;
2011-11-29 23:37:44 +00:00
// if(defined('SETTHEME')) //override - within e_module for example.
// {
// $_POST['sitetheme'] = SETTHEME;
// $_POST['settheme'] = 1;
// }
2010-05-15 17:33:11 +00:00
// XXX could go to e_user class as well
2010-05-14 18:45:51 +00:00
if ( $user -> checkClass ( e107 :: getPref ( 'allow_theme_select' , false ), false ))
{ // User can set own theme
if ( isset ( $_POST [ 'settheme' ]))
{
$uconfig = $user -> getConfig ();
if ( e107 :: getPref ( 'sitetheme' ) != $_POST [ 'sitetheme' ])
{
require_once ( e_HANDLER . " theme_handler.php " );
$utheme = new themeHandler ;
$ut = $utheme -> themeArray [ $_POST [ 'sitetheme' ]];
$uconfig -> setPosted ( 'sitetheme' , $_POST [ 'sitetheme' ])
-> setPosted ( 'sitetheme_custompages' , $ut [ 'custompages' ])
-> setPosted ( 'sitetheme_deflayout' , $utheme -> findDefault ( $_POST [ 'sitetheme' ]));
}
else
{
$uconfig -> remove ( 'sitetheme' )
-> remove ( 'sitetheme_custompages' )
-> remove ( 'sitetheme_deflayout' );
}
$uconfig -> save ( true );
unset ( $ut );
}
2016-09-12 10:09:33 -07:00
2010-05-14 18:45:51 +00:00
}
elseif ( $user -> getPref ( 'sitetheme' ))
{
$user -> getConfig ()
-> remove ( 'sitetheme' )
-> remove ( 'sitetheme_custompages' )
-> remove ( 'sitetheme_deflayout' )
-> save ( false );
}
2016-09-12 10:09:33 -07:00
2010-05-14 18:45:51 +00:00
$user_pref = $user -> getPref ();
}
define ( 'USERCLASS_LIST' , $user -> getClassList ( true ));
2010-05-15 17:33:11 +00:00
define ( 'e_CLASS_REGEXP' , $user -> getClassRegex ());
2010-05-14 18:45:51 +00:00
define ( 'e_NOBODY_REGEXP' , '(^|,)' . e_UC_NOBODY . '(,|$)' );
2006-12-02 04:36:16 +00:00
}
2008-06-13 20:20:23 +00:00
2016-06-01 10:41:47 -07:00
$sql -> db_Mark_Time ( 'Go online' );
2008-01-06 22:16:37 +00:00
if ( ! isset ( $_E107 [ 'no_online' ]) && varset ( $pref [ 'track_online' ]))
{
2010-05-15 17:33:11 +00:00
e107 :: getOnline () -> goOnline ( $pref [ 'track_online' ], $pref [ 'flood_protect' ]);
2006-12-02 04:36:16 +00:00
}
2010-10-26 07:41:20 +00:00
/**
* Set Cookie
* @ param string $name
* @ param string $value
* @ param integer $expire seconds
* @ param string $path
* @ param string $domain
* @ param boolean $secure
* @ return void
*/
2010-09-10 01:01:48 +00:00
function cookie ( $name , $value , $expire = 0 , $path = e_HTTP , $domain = '' , $secure = 0 )
2008-11-27 02:18:25 +00:00
{
2013-05-26 13:46:31 -07:00
if ( ! e_SUBDOMAIN || ( defined ( 'MULTILANG_SUBDOMAIN' ) && MULTILANG_SUBDOMAIN === TRUE ))
{
$domain = ( e_DOMAIN != FALSE ) ? " . " . e_DOMAIN : " " ;
}
2016-08-19 16:13:38 -07:00
setcookie ( $name , $value , $expire , $path , $domain , $secure , true );
2006-12-02 04:36:16 +00:00
}
2008-05-19 09:42:28 +00:00
// generic function for retaining values across pages. ie. cookies or sessions.
2011-06-07 12:40:34 +00:00
function session_set ( $name , $value , $expire = '' , $path = e_HTTP , $domain = '' , $secure = 0 )
2008-05-19 09:42:28 +00:00
{
global $pref ;
2008-12-22 03:15:04 +00:00
if ( $pref [ 'user_tracking' ] == 'session' )
2008-05-19 09:42:28 +00:00
{
$_SESSION [ $name ] = $value ;
}
else
{
2013-07-24 08:42:25 -07:00
if (( $domain == '' && ! e_SUBDOMAIN ) || ( defined ( 'MULTILANG_SUBDOMAIN' ) && MULTILANG_SUBDOMAIN === TRUE ))
{
$domain = ( e_DOMAIN != FALSE ) ? " . " . e_DOMAIN : " " ;
}
2016-08-19 16:13:38 -07:00
setcookie ( $name , $value , $expire , $path , $domain , $secure , true );
2008-05-19 09:42:28 +00:00
$_COOKIE [ $name ] = $value ;
}
}
2006-12-02 04:36:16 +00:00
//------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------//
2008-12-22 03:15:04 +00:00
function message_handler ( $mode , $message , $line = 0 , $file = '' )
2008-11-27 02:18:25 +00:00
{
2015-05-16 19:06:13 -07:00
if ( ! defined ( 'e_HANDLER' ))
2014-07-03 19:45:50 -07:00
{
2015-05-16 19:06:13 -07:00
echo $message ;
2014-07-03 19:45:50 -07:00
return ;
}
2016-03-14 19:17:37 -07:00
2008-11-27 02:18:25 +00:00
e107_require_once ( e_HANDLER . 'message_handler.php' );
2006-12-02 04:36:16 +00:00
show_emessage ( $mode , $message , $line , $file );
}
2008-12-21 22:29:38 +00:00
/*
2006-12-02 04:36:16 +00:00
// -----------------------------------------------------------------------------
2008-11-27 02:18:25 +00:00
function table_exists ( $check )
{
if ( ! $GLOBALS [ 'mySQLtablelist' ])
{
2006-12-02 04:36:16 +00:00
$tablist = mysql_list_tables ( $GLOBALS [ 'mySQLdefaultdb' ]);
2008-11-27 02:18:25 +00:00
while ( list ( $temp ) = mysql_fetch_array ( $tablist ))
{
2006-12-02 04:36:16 +00:00
$GLOBALS [ 'mySQLtablelist' ][] = $temp ;
}
}
$mltable = MPREFIX . strtolower ( $check );
2008-11-27 02:18:25 +00:00
foreach ( $GLOBALS [ 'mySQLtablelist' ] as $lang )
{
if ( strpos ( $lang , $mltable ) !== FALSE )
{
2006-12-02 04:36:16 +00:00
return TRUE ;
}
}
}
2008-12-21 22:29:38 +00:00
*/
2006-12-02 04:36:16 +00:00
2007-01-12 02:36:18 +00:00
function class_list ( $uid = '' )
{
$clist = array ();
2006-12-02 04:36:16 +00:00
2007-01-12 02:36:18 +00:00
if ( is_numeric ( $uid ) || USER === true )
2006-12-02 04:36:16 +00:00
{
2007-01-12 02:36:18 +00:00
if ( is_numeric ( $uid ))
2006-12-02 04:36:16 +00:00
{
2015-01-26 18:03:14 -08:00
if ( $ud = e107 :: user ( $uid ))
2006-12-02 04:36:16 +00:00
{
2007-01-12 02:36:18 +00:00
$admin_status = $ud [ 'user_admin' ];
$class_list = $ud [ 'user_class' ];
$admin_perms = $ud [ 'user_perms' ];
2006-12-02 04:36:16 +00:00
}
2007-01-12 02:36:18 +00:00
else
{
$admin_status = false ;
$class_list = " " ;
$admin_perms = " " ;
2006-12-02 04:36:16 +00:00
}
}
2007-01-12 02:36:18 +00:00
else
{
$admin_status = ADMIN ;
$class_list = USERCLASS ;
$admin_perms = ADMINPERMS ;
}
if ( $class_list )
{
$clist = explode ( ',' , $class_list );
}
2008-11-25 16:26:03 +00:00
2007-01-12 02:36:18 +00:00
$clist [] = e_UC_MEMBER ;
2008-11-25 16:26:03 +00:00
2007-01-12 02:36:18 +00:00
if ( $admin_status == true )
{
$clist [] = e_UC_ADMIN ;
}
if ( $admin_perms === '0' )
{
$clist [] = e_UC_MAINADMIN ;
}
}
else
{
$clist [] = e_UC_GUEST ;
2006-12-02 04:36:16 +00:00
}
2008-11-25 16:26:03 +00:00
2007-01-12 02:36:18 +00:00
$clist [] = e_UC_READONLY ;
$clist [] = e_UC_PUBLIC ;
2008-11-25 16:26:03 +00:00
2007-01-12 02:36:18 +00:00
return implode ( ',' , $clist );
2006-12-02 04:36:16 +00:00
}
// ---------------------------------------------------------------------------
2009-11-12 01:53:16 +00:00
/**
2015-03-09 15:05:34 -07:00
* @ Deprecated by e107 :: lan ();
2009-11-17 09:37:22 +00:00
* @ param string $path
* @ param boolean $force [ optional ] Please use the default
* @ return void
2009-11-12 01:53:16 +00:00
*/
2008-11-25 16:26:03 +00:00
function include_lan ( $path , $force = false )
2008-08-11 20:45:01 +00:00
{
2009-09-19 15:27:26 +00:00
return e107 :: includeLan ( $path , $force );
2006-12-02 04:36:16 +00:00
}
2008-12-07 21:41:04 +00:00
/*
withdrawn - use loadLanFiles ( $path , 'admin' ) instead
2008-08-11 20:45:01 +00:00
// Searches a defined set of paths and file names to load language files used for admin (including install etc)
function include_lan_admin ( $path )
{
include_lan ( $path . 'languages/' . e_LANGUAGE . '/lan_config.php' );
include_lan ( $path . 'languages/admin/' . e_LANGUAGE . '.php' );
}
2008-12-07 21:41:04 +00:00
*/
// Routine looks in standard paths for language files associated with a plugin or theme - primarily for core routines, which won't know
// for sure where the author has put them.
// $unitName is the name (directory path) of the plugin or theme
// $type determines what is to be loaded:
// 'runtime' - the standard runtime language file for a plugin
// 'admin' - the standard admin language file for a plugin
// 'theme' - the standard language file for a plugin (these are usually pretty small, so one is enough)
// Otherwise, $type is treated as part of a filename within the plugin's language directory, prefixed with the current language
// Returns FALSE on failure (not found).
// Returns the include_once error return if there is one
// Otherwise returns an empty string.
// Note - if the code knows precisely where the language file is located, use include_lan()
// $pref['noLanguageSubs'] can be set TRUE to prevent searching for the English files if the files for the current site language don't exist.
2009-07-22 14:32:51 +00:00
//DEPRECATED - use e107::loadLanFiles();
2015-02-15 16:07:27 -08:00
/**
* @ deprecated - use e107 :: loadLanFiles ();
* @ param $unitName
* @ param string $type
* @ return bool | string
*/
2008-12-07 21:41:04 +00:00
function loadLanFiles ( $unitName , $type = 'runtime' )
{
2015-02-12 13:09:56 -08:00
$info = debug_backtrace ( DEBUG_BACKTRACE_IGNORE_ARGS , 2 );
e107 :: getMessage () -> addDebug ( " Using deprecated function loanLanFiles(). Replace with e107::loadLanFiles(). " . print_a ( $info , true ));
2009-07-22 14:32:51 +00:00
return e107 :: loadLanFiles ( $unitName , $type );
2008-12-07 21:41:04 +00:00
}
2008-08-11 20:45:01 +00:00
2009-08-05 19:58:32 +00:00
2006-12-02 04:36:16 +00:00
2009-12-07 20:47:37 +00:00
/**
* Check that all required user fields ( including extended fields ) are valid .
* @ param array $currentUser - data for user
* @ return boolean TRUE if update required
*/
function force_userupdate ( $currentUser )
2007-08-12 21:40:49 +00:00
{
2009-12-07 20:47:37 +00:00
if ( e_PAGE == 'usersettings.php' || strpos ( e_SELF , ADMINDIR ) == TRUE || ( defined ( 'FORCE_USERUPDATE' ) && ( FORCE_USERUPDATE == FALSE )))
2006-12-02 04:36:16 +00:00
{
return FALSE ;
}
2008-11-27 02:18:25 +00:00
$signup_option_names = array ( 'realname' , 'signature' , 'image' , 'timezone' , 'class' );
2006-12-02 04:36:16 +00:00
foreach ( $signup_option_names as $key => $value )
{
2009-12-07 20:47:37 +00:00
if ( e107 :: getPref ( 'signup_option_' . $value , 0 ) == 2 && ! $currentUser [ 'user_' . $value ])
2006-12-02 04:36:16 +00:00
{
return TRUE ;
}
}
2009-12-07 20:47:37 +00:00
if ( ! e107 :: getPref ( 'disable_emailcheck' , TRUE ) && ! trim ( $currentUser [ 'user_email' ])) return TRUE ;
2007-08-12 21:40:49 +00:00
2016-02-15 00:56:08 -08:00
if ( e107 :: getDb () -> select ( 'user_extended_struct' , 'user_extended_struct_applicable, user_extended_struct_write, user_extended_struct_name, user_extended_struct_type' , 'user_extended_struct_required = 1 AND user_extended_struct_applicable != ' . e_UC_NOBODY ))
2006-12-02 04:36:16 +00:00
{
2016-02-15 00:56:08 -08:00
while ( $row = e107 :: getDb () -> fetch ())
2006-12-02 04:36:16 +00:00
{
2009-12-07 20:47:37 +00:00
if ( ! check_class ( $row [ 'user_extended_struct_applicable' ])) { continue ; } // Must be applicable to this user class
if ( ! check_class ( $row [ 'user_extended_struct_write' ])) { continue ; } // And user must be able to change it
$user_extended_struct_name = " user_ { $row [ 'user_extended_struct_name' ] } " ;
2012-01-14 23:01:21 +00:00
if ( ! isset ( $currentUser [ $user_extended_struct_name ]))
{
//e107::admin_log->e_log_event(4, __FILE__."|".__FUNCTION__."@".__LINE__, 'FORCE', 'Force User update', 'Trigger field: '.$user_extended_struct_name, FALSE, LOG_TO_ROLLING);
return TRUE ;
}
if (( $row [ 'user_extended_struct_type' ] == 7 ) && ( $currentUser [ $user_extended_struct_name ] == '0000-00-00' ))
2009-12-07 20:47:37 +00:00
{
//e107::admin_log->e_log_event(4, __FILE__."|".__FUNCTION__."@".__LINE__, 'FORCE', 'Force User update', 'Trigger field: '.$user_extended_struct_name, FALSE, LOG_TO_ROLLING);
return TRUE ;
}
2006-12-02 04:36:16 +00:00
}
}
return FALSE ;
}
2009-12-07 20:47:37 +00:00
2009-12-13 21:52:32 +00:00
/**
* @ package e107
*/
2008-11-27 02:18:25 +00:00
class error_handler
{
2006-12-02 04:36:16 +00:00
var $errors ;
var $debug = false ;
2016-02-12 12:58:44 -08:00
protected $xdebug = false ;
protected $docroot = '' ;
protected $label = array ();
2006-12-02 04:36:16 +00:00
2016-02-12 12:58:44 -08:00
function __construct ()
2008-11-27 02:18:25 +00:00
{
2016-02-12 12:58:44 -08:00
$this -> label = array ( E_NOTICE => " Notice " , E_WARNING => " Warning " , E_DEPRECATED => " Deprecated " , E_STRICT => " Strict " );
$this -> color = array ( E_NOTICE => 'info' , E_WARNING => 'warning' , E_DEPRECATED => 'danger' , E_STRICT => 'primary' );
$this -> docroot = dirname ( realpath ( __FILE__ )) . DIRECTORY_SEPARATOR ;
2006-12-05 09:33:20 +00:00
// This is initialized before the current debug level is known
2016-02-12 12:58:44 -08:00
if ( function_exists ( 'xdebug_get_function_stack' ))
{
$this -> xdebug = true ;
}
2006-12-05 09:33:20 +00:00
//
2008-12-22 03:15:04 +00:00
global $_E107 ;
if ( isset ( $_E107 [ 'debug' ]))
2008-01-21 03:54:10 +00:00
{
$this -> debug = true ;
error_reporting ( E_ALL );
return ;
2008-12-22 03:15:04 +00:00
}
if ( isset ( $_E107 [ 'cli' ]))
2008-01-21 03:54:10 +00:00
{
2008-12-22 03:15:04 +00:00
error_reporting ( E_ALL ^ E_NOTICE );
2008-01-21 03:54:10 +00:00
return ;
}
2009-07-21 14:20:13 +00:00
if (( isset ( $_SERVER [ 'QUERY_STRING' ]) && strpos ( $_SERVER [ 'QUERY_STRING' ], 'debug=' ) !== FALSE ) || isset ( $_COOKIE [ 'e107_debug_level' ]) && strpos ( $_SERVER [ 'QUERY_STRING' ], 'debug=-' ) !== TRUE )
2008-11-27 02:18:25 +00:00
{
2009-07-21 14:20:13 +00:00
$this -> debug = true ;
error_reporting ( E_ALL );
2008-11-27 02:18:25 +00:00
}
else
{
2006-12-02 04:36:16 +00:00
error_reporting ( E_ERROR | E_PARSE );
}
}
function handle_error ( $type , $message , $file , $line , $context ) {
2006-12-05 09:33:20 +00:00
$startup_error = ( ! defined ( 'E107_DEBUG_LEVEL' )); // Error before debug system initialized
2016-02-12 12:58:44 -08:00
2006-12-02 04:36:16 +00:00
switch ( $type ) {
case E_NOTICE :
2016-02-12 12:58:44 -08:00
case E_DEPRECATED :
// case E_STRICT:
2012-12-06 14:16:55 -08:00
if ( $startup_error || E107_DBG_ALLERRORS || E107_DBG_ERRBACKTRACE )
2008-11-27 02:18:25 +00:00
{
2016-02-12 12:58:44 -08:00
2016-02-12 19:28:35 -08:00
$error [ 'short' ] = " <span class='label label- " . $this -> color [ $type ] . " '> " . $this -> label [ $type ] . " </span> { $message } , Line <mark> { $line } </mark> of { $file } <br /> \n " ;
2016-02-12 12:58:44 -08:00
if ( $this -> xdebug )
{
$backtrace = xdebug_get_function_stack ();
}
else
{
$trace = debug_backtrace ();
$backtrace [ 0 ] = ( isset ( $trace [ 1 ]) ? $trace [ 1 ] : " " );
$backtrace [ 1 ] = ( isset ( $trace [ 2 ]) ? $trace [ 2 ] : " " );
}
2006-12-02 04:36:16 +00:00
$error [ 'trace' ] = $backtrace ;
$this -> errors [] = $error ;
}
break ;
case E_WARNING :
2012-12-06 14:16:55 -08:00
if ( $startup_error || E107_DBG_BASIC || E107_DBG_ERRBACKTRACE )
2008-11-27 02:18:25 +00:00
{
2016-02-12 12:58:44 -08:00
// $error['short'] = "Warning: {$message}, Line {$line} of {$file}<br />\n";
2016-02-12 19:28:35 -08:00
$error [ 'short' ] = " <span class='label label- " . $this -> color [ $type ] . " '> " . $this -> label [ $type ] . " </span> { $message } , Line <mark> { $line } </mark> of { $file } <br /> \n " ;
2016-02-12 12:58:44 -08:00
if ( $this -> xdebug )
{
$backtrace = xdebug_get_function_stack ();
}
else
{
$trace = debug_backtrace ();
$backtrace [ 0 ] = ( isset ( $trace [ 1 ]) ? $trace [ 1 ] : " " );
$backtrace [ 1 ] = ( isset ( $trace [ 2 ]) ? $trace [ 2 ] : " " );
}
2006-12-02 04:36:16 +00:00
$error [ 'trace' ] = $backtrace ;
$this -> errors [] = $error ;
}
break ;
case E_USER_ERROR :
2008-11-27 02:18:25 +00:00
if ( $this -> debug == true )
{
2016-02-12 19:28:35 -08:00
$error [ 'short' ] = " Internal Error Message: { $message } , Line <mark> { $line } </mark> of { $file } <br /> \n " ;
2006-12-02 04:36:16 +00:00
$trace = debug_backtrace ();
$backtrace [ 0 ] = ( isset ( $trace [ 1 ]) ? $trace [ 1 ] : " " );
$backtrace [ 1 ] = ( isset ( $trace [ 2 ]) ? $trace [ 2 ] : " " );
$error [ 'trace' ] = $backtrace ;
$this -> errors [] = $error ;
}
default :
return true ;
break ;
}
}
2016-02-12 12:58:44 -08:00
function render_trace ( $array )
{
if ( $this -> xdebug == false )
{
return print_a ( $array , true );
}
array_pop ( $array );
2016-02-12 19:28:35 -08:00
$text = " <table class='table table-bordered table-striped table-condensed'>
2016-02-12 12:58:44 -08:00
< tr class = 'danger' >< th > #</th><th>Function</th><th>Location</th></tr>";
foreach ( $array as $key => $val )
{
$text .= "
< tr >
< td > " . $key . " </ td >
< td > " ;
$text .= ! empty ( $val [ 'class' ]) ? $val [ 'class' ] . " -> " : '' ;
$text .= ! empty ( $val [ 'include_filename' ]) ? " include: " . str_replace ( $this -> docroot , '' , $val [ 'include_filename' ]) : '' ;
$text .= ! empty ( $val [ 'function' ]) ? $val [ 'function' ] . " ( " : " " ;
$text .= ! empty ( $val [ 'params' ]) ? print_r ( $val [ 'params' ], true ) : '' ;
$text .= ! empty ( $val [ 'function' ]) ? " ) " : " " ;
$text .= " </td>
< td > " ;
$text .= str_replace ( $this -> docroot , '' , $val [ 'file' ]) . " : " . $val [ 'line' ];
$text .= " </td>
</ tr > " ;
}
$text .= " </table> " ;
return $text ;
}
2008-11-27 02:18:25 +00:00
function return_errors ()
{
2006-12-02 04:36:16 +00:00
$index = 0 ; $colours [ 0 ] = " #C1C1C1 " ; $colours [ 1 ] = " #B6B6B6 " ;
2009-07-21 14:20:13 +00:00
$ret = " " ;
2012-12-06 14:16:55 -08:00
// print_a($this->errors);
2006-12-05 09:33:20 +00:00
if ( E107_DBG_ERRBACKTRACE )
{
2016-02-12 12:58:44 -08:00
2008-11-27 02:18:25 +00:00
foreach ( $this -> errors as $key => $value )
{
2012-12-16 21:00:31 -08:00
$ret .= " \t <tr> \n \t \t <td class='forumheader3' > { $value [ 'short' ] } </td><td><input class='btn btn-info button e-expandit' data-target = 'bt_ { $key } ' type ='button' style='cursor: hand; cursor: pointer;' size='30' value='Back Trace' /> \n " ;
2016-02-12 19:28:35 -08:00
$ret .= " </td> \n \t </tr> " ;
2016-02-12 12:58:44 -08:00
$ret .= " \t <tr> \n <td style='display: none;' colspan='2' id='bt_ { $key } '> " . $this -> render_trace ( $value [ 'trace' ]) . " </td></tr> \n " ;
2016-02-12 19:28:35 -08:00
2008-11-27 02:18:25 +00:00
if ( $index == 0 ) { $index = 1 ; } else { $index = 0 ; }
}
2012-12-06 14:16:55 -08:00
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
else
{
2006-12-30 03:07:50 +00:00
foreach ( $this -> errors as $key => $value )
2006-12-05 09:33:20 +00:00
{
$ret .= " <tr class='forumheader3'><td> { $value [ 'short' ] } </td></tr> \n " ;
}
}
2009-07-21 14:20:13 +00:00
2012-12-16 21:00:31 -08:00
return ( $ret ) ? " <table class='table table-condensed fborder'> \n " . $ret . " </table> " : FALSE ;
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
function trigger_error ( $information , $level )
{
2006-12-02 04:36:16 +00:00
trigger_error ( $information );
}
}
2014-05-24 20:40:51 -07:00
/**
* Manage Headers sent to browser .
* It is important to specify one of Expires or Cache - Control max - age , and one of Last - Modified or ETag , for all cacheable resources .
* It is redundant to specify both Expires and Cache - Control : max - age , or to specify both Last - Modified and ETag .
* Reference : http :// css - tricks . com / snippets / php / intelligent - php - cache - control /
* XXX Etag cannot be relied on as some hosts have Etag disabled .
* XXX session_cache_limiter ( 'private' ) will override some of the things below and bring back our browser cache issues .
*/
class e_http_header
{
private $content ;
private $etag ;
private $compress_output = false ;
private $compression_level = 6 ;
private $compression_browser_support = false ;
private $compression_server_support = false ;
private $headers = array ();
2016-03-19 17:14:22 -07:00
private $length = 0 ;
2014-05-24 20:40:51 -07:00
function __construct ()
{
if ( strstr ( varset ( $_SERVER [ 'HTTP_ACCEPT_ENCODING' ], '' ), 'gzip' ))
{
$this -> compression_browser_support = true ;
}
2016-03-19 17:14:22 -07:00
if ( ini_get ( " zlib.output_compression " ) == '' && function_exists ( " gzencode " ))
2014-05-24 20:40:51 -07:00
{
$this -> compression_server_support = true ;
}
2016-03-19 17:14:22 -07:00
if ( $this -> compression_server_support == true && $this -> compression_browser_support == true )
{
$this -> compress_output = varset ( e107 :: getPref ( 'compress_output' ), false );
}
else
{
$this -> compress_output = false ;
}
2014-05-24 20:40:51 -07:00
}
2016-03-22 06:11:37 -07:00
function setContent ( $content , $search = null , $replace = null )
2014-05-24 20:40:51 -07:00
{
2016-03-19 17:14:22 -07:00
if ( $content == 'buffer' )
{
$this -> length = ob_get_length ();
2016-03-22 06:11:37 -07:00
$this -> content = ob_get_clean ();
if ( ! empty ( $search ) && ! empty ( $replace ))
{
$this -> content = str_replace ( $search , $replace , $this -> content );
$this -> length = strlen ( $this -> content );
}
2016-03-19 17:14:22 -07:00
}
else
{
$this -> content = $content ;
$this -> length = strlen ( $content );
}
$this -> etag = md5 ( $this -> content );
//print_a($this->length);
// return $this->content;
}
/**
* Return Content ( with or without encoding )
* @ return mixed
*/
function getOutput ()
{
return $this -> content ;
2014-05-24 20:40:51 -07:00
}
function setHeader ( $header , $force = false , $response_code = null )
{
list ( $key , $val ) = explode ( ':' , $header , 2 );
$this -> headers [ $key ] = $val ;
header ( $header , $force , $response_code );
}
2016-03-19 17:14:22 -07:00
function debug () // needs to be disabled if PHP gzip is to work
2014-05-24 20:40:51 -07:00
{
2016-03-19 17:14:22 -07:00
if ( ! ADMIN )
{
return null ;
}
2014-05-24 20:40:51 -07:00
2016-03-19 17:14:22 -07:00
$text = " <h3>Server Headers</h3> " ;
2014-05-24 20:40:51 -07:00
$server = getallheaders ();
ksort ( $server );
2016-03-19 17:14:22 -07:00
$text .= print_a ( $server , true );
$text .= " <h3>e107 Headers</h3> " ;
2014-05-24 20:40:51 -07:00
ksort ( $this -> headers );
2016-03-19 17:14:22 -07:00
$text .= print_a ( $this -> headers , true );
$text .= " <h4>Compress Output</h4> " ;
$text .= print_a ( $this -> compress_output , true );
2014-05-24 20:40:51 -07:00
$server = array ();
foreach ( $_SERVER as $k => $v )
{
if ( substr ( $k , 0 , 4 ) == 'HTTP' )
{
$server [ $k ] = $v ;
}
}
2016-03-19 17:14:22 -07:00
$text .= " <h3>_SERVER</h3> " ;
$text .= " <h4>zlib.output_compression</h4> " ;
$text .= print_a ( ini_get ( " zlib.output_compression " ), true );
$text .= print_a ( $server , true );
if ( $this -> compress_output == true )
{
$text = gzencode ( $text , $this -> compression_level );
}
echo $text ;
2014-05-24 20:40:51 -07:00
}
function send ()
{
// Disable caching of html.
/*
$this -> setHeader ( " Expires: 0 " , true );
$this -> setHeader ( " Last-Modified: " . gmdate ( " D, d M Y H:i:s " ) . " GMT " , true );
$this -> setHeader ( " Cache-Control: no-store, no-cache, must-revalidate " , true );
$this -> setHeader ( " Cache-Control: post-check=0, pre-check=0 " , false );
$this -> setHeader ( " Pragma: no-cache " );
$this -> setHeader ( " Cache-Control: max-age=0 " , false );
*/
// $this->setHeader("Cache-Control: public", true);
$canCache = e107 :: canCache ();
// $this->setHeader("Cache-Control: must-revalidate", true);
if ( $canCache && ! deftrue ( 'e_NOCACHE' ) && $_SERVER [ 'REQUEST_METHOD' ] === 'GET' && $_SERVER [ 'QUERY_STRING' ] != 'logout' )
{
// header("Cache-Control: must-revalidate", true);
if ( e107 :: getPref ( 'site_page_expires' )) // TODO - allow per page
{
if ( function_exists ( 'date_default_timezone_set' ))
{
date_default_timezone_set ( 'UTC' );
}
$time = time () + ( integer ) e107 :: getPref ( 'site_page_expires' );
$this -> setHeader ( 'Expires: ' . gmdate ( " D, d M Y H:i:s " , $time ) . ' GMT' , true );
}
}
else
{
$canCache = false ;
}
2016-03-19 17:14:22 -07:00
if ( $this -> compress_output != false )
2014-05-24 20:40:51 -07:00
{
// $this->setHeader("ETag: \"{$this->etag}-gzip\"");
$this -> setHeader ( 'ETag: "' . $this -> etag . '-gzip"' , true );
2016-03-19 17:14:22 -07:00
$this -> content = gzencode ( $this -> content , $this -> compression_level );
$this -> setHeader ( 'Content-Encoding: gzip' , true );
$this -> setHeader ( " Content-Length: " . $this -> length , true );
2014-05-24 20:40:51 -07:00
}
else
{
2016-03-19 17:14:22 -07:00
/*
2014-05-24 20:40:51 -07:00
if ( $this -> compression_browser_support == true )
{
$this -> setHeader ( 'ETag: "' . $this -> etag . '-gzip"' , true );
}
else
2016-03-19 17:14:22 -07:00
{ */
2014-05-24 20:40:51 -07:00
$this -> setHeader ( 'ETag: "' . $this -> etag . '"' , true );
2016-03-19 17:14:22 -07:00
// }
2014-05-24 20:40:51 -07:00
2016-03-19 17:14:22 -07:00
$this -> setHeader ( " Content-Length: " . $this -> length , true );
2014-05-24 20:40:51 -07:00
}
2014-07-03 19:45:50 -07:00
if ( defset ( 'X-POWERED-BY' ) !== false )
{
$this -> setHeader ( " X-Powered-By: e107 " , true ); // no less secure than e107-specific html.
}
2014-05-24 20:40:51 -07:00
if ( $this -> compression_server_support == true )
{
$this -> setHeader ( 'Vary: Accept-Encoding' );
}
2016-03-19 17:14:22 -07:00
else
2014-05-24 20:40:51 -07:00
{
2016-03-19 17:14:22 -07:00
$this -> setHeader ( 'Vary: Accept' );
2014-05-24 20:40:51 -07:00
}
// should come after the Etag header
if ( $canCache && isset ( $_SERVER [ 'HTTP_IF_NONE_MATCH' ]))
{
$IF_NONE_MATCH = str_replace ( '"' , '' , $_SERVER [ 'HTTP_IF_NONE_MATCH' ]);
if ( $IF_NONE_MATCH == $this -> etag || ( $IF_NONE_MATCH == ( $this -> etag . " -gzip " )))
{
$this -> setHeader ( 'HTTP/1.1 304 Not Modified' );
exit ();
}
}
}
}
2006-12-02 04:36:16 +00:00
$sql -> db_Mark_Time ( '(After class2)' );
2008-11-27 02:18:25 +00:00
function e107_ini_set ( $var , $value )
{
if ( function_exists ( 'ini_set' ))
{
2008-11-29 13:10:56 +00:00
return ini_set ( $var , $value );
2006-12-02 04:36:16 +00:00
}
2008-11-29 13:10:56 +00:00
return FALSE ;
2006-12-02 04:36:16 +00:00
}
2008-11-27 02:18:25 +00:00
// Return true if specified plugin installed, false if not
2015-02-15 16:07:27 -08:00
//DEPRECATED
/**
* @ deprecated - use e107 :: isInstalled ();
* @ param $plugname
* @ return bool
*/
2008-10-07 21:29:25 +00:00
function plugInstalled ( $plugname )
{
2009-07-22 14:32:51 +00:00
return e107 :: isInstalled ( $plugname );
/* global $pref ;
2008-10-07 21:29:25 +00:00
// Could add more checks here later if appropriate
2009-07-22 14:32:51 +00:00
return isset ( $pref [ 'plug_installed' ][ $plugname ]); */
2008-10-07 21:29:25 +00:00
}
2014-07-03 19:45:50 -07:00