************************************************************************/
// Some security stuff...
-if (ereg(basename(__FILE__), $_SERVER['PHP_SELF']))
-{
+if (!defined('__SECURITY')) {
$INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), "/inc") + 4) . "/security.php";
require($INC);
}
$ADD = "";
// Skip loading extensions
-if ((!mxchange_installed) || (mxchange_installing)) return;
+if ((!isBooleanConstantAndTrue('mxchange_installed')) || (isBooleanConstantAndTrue('mxchange_installing'))) return;
// Load default sql_patches extension if present
-if (file_exists(PATH."inc/extensions/ext-sql_patches.php") && is_readable(PATH."inc/extensions/ext-sql_patches.php"))
-{
+if (FILE_READABLE(PATH."inc/extensions/ext-sql_patches.php")) {
// Load it...
$EXT_LOAD_MODE = "";
require_once(PATH."inc/extensions/ext-sql_patches.php");
- $KEEP_ACTIVE = array('sql_patches' => "Y"); // KEEP THIS ALWAYS ACTIVE!
-}
- else
-{
+ $cacheArray['active_extensions'] = array('sql_patches' => 'Y'); // KEEP THIS ALWAYS ACTIVE!
+} else {
// Initialize array for "always keep active extensions"
- $KEEP_ACTIVE = array();
+ $cacheArray['active_extensions'] = array();
}
//
// Load extensions
//
-if (EXT_IS_ACTIVE("cache"))
-{
+if (EXT_IS_ACTIVE("cache")) {
// Load cache extension alone
include_once(PATH."inc/libs/cache_functions.php");
- $CACHE_FILE = "";
+ $cacheMode = "";
include_once(PATH."inc/extensions/ext-cache.php");
- switch($CACHE->cache_file("extensions", true))
- {
- case true : $CACHE_FILE = "load"; break;
- case false: $CACHE_FILE = "init"; break;
+ switch($cacheInstance->cache_file("extensions", true)) {
+ case true : $cacheMode = "load"; break;
+ case false: $cacheMode = "init"; break;
}
// Do not recreate cache file when it's switched off!
- if (($CACHE_FILE == "init") && ($CONFIG['cache_exts'] == "N")) $CACHE_FILE = "skip";
-
- // Load language
- if ($CACHE_FILE == "load") include(PATH."inc/language/cache_".GET_LANGUAGE().".php");
-}
- else
-{
- $CACHE_FILE = "no";
+ if (($cacheMode == "init") && ($_CONFIG['cache_exts'] == "N")) $cacheMode = "skip";
+} else {
+ // Cache extension not active
+ $cacheMode = "no";
}
-if ($CACHE_FILE == "load")
-{
- // Load more cache files (like admins)
- require_once(PATH."inc/load_cache.php");
+if ($cacheMode == "load") {
+ // Init include array
+ $EXT_POOL = array();
// Re-initialize handler
- $CACHE->cache_file("extensions", true);
+ $cacheInstance->cache_file("extensions", true);
// Load extension data from cache file
- $EXT_DUMMY = $CACHE->cache_load();
- foreach ($EXT_DUMMY['ext_name'] as $k=>$name)
- {
+ $EXT_DUMMY = $cacheInstance->cache_load();
+
+ // Begin with the cache preparation of extensions
+ $EXT_NAMES = array();
+ foreach ($EXT_DUMMY['ext_name'] as $k => $name) {
// Load functions file
- if ($EXT_DUMMY['ext_funcs'][$k] == "Y") require_once(PATH."inc/libs/".$name."_functions.php");
+ if ($EXT_DUMMY['ext_funcs'][$k] == "Y") {
+ require_once(PATH."inc/libs/".$name."_functions.php");
+ } // END - if
// Load Language file
- if ($EXT_DUMMY['ext_lang'][$k] == "Y")
- {
- $INC = sprintf(PATH."inc/language/%s_%s.php", $name, GET_LANGUAGE());
- if (file_exists($INC)) require_once($INC);
- }
+ if ($EXT_DUMMY['ext_lang'][$k] == "Y") {
+ $INC = sprintf("%sinc/language/%s_%s.php", PATH, $name, GET_LANGUAGE());
+ if (FILE_READABLE($INC)) {
+ // Add it
+ $EXT_POOL[] = $INC;
+ }
+ } // END - if
// Load CSS file
if ($EXT_DUMMY['ext_css'][$k] == "Y") $EXT_CSS_FILES[] = "".$name.".css";
// Load extension file itself
- if (($EXT_DUMMY['ext_active'][$k] == "Y") || ($EXT_DUMMY['ext_keep'][$k] == "Y") || (IS_ADMIN()))
- {
- require_once(PATH."inc/extensions/ext-".$name.".php");
- }
+ if (($EXT_DUMMY['ext_active'][$k] == "Y") || ($EXT_DUMMY['ext_keep'][$k] == "Y") || (IS_ADMIN())) {
+ $EXT_POOL[] = sprintf("%sinc/extensions/ext-%s.php", PATH, $name);
+ } // END - if
- // Transfer version number and active status
+ // Version number
$EXT_DUMMY['ext_version'][$name] = $EXT_DUMMY['ext_version'][$k];
unset($EXT_DUMMY['ext_version'][$k]);
+ // Extension is active
$EXT_DUMMY['ext_active'][$name] = $EXT_DUMMY['ext_active'][$k];
unset($EXT_DUMMY['ext_active'][$k]);
+ // Ext menu
$EXT_DUMMY['ext_menu'][$name] = $EXT_DUMMY['ext_menu'][$k];
unset($EXT_DUMMY['ext_menu'][$k]);
- $KEEP_ACTIVE['$name'] = $EXT_DUMMY['ext_keep'][$k];
+ // Extension id
+ $EXT_DUMMY['ext_id'][$name] = $EXT_DUMMY['ext_id'][$k];
+ $id = $EXT_DUMMY['ext_id'][$name];
+ unset($EXT_DUMMY['ext_id'][$k]);
+
+ // Add ext name
+ $EXT_NAMES[$id] = $name;
+
+ // Mark it as active extension
+ $cacheArray['active_extensions']['$name'] = $EXT_DUMMY['ext_keep'][$k];
unset($EXT_DUMMY['ext_keep'][$k]);
- $k2 = $EXT_DUMMY['ext_id'][$k];
- $EXT_DUMMY['ext_id'][$k2] = $name;
- if ($k2 != $k) unset($EXT_DUMMY['ext_id'][$k]);
// Remove unneccessary data from memory
unset($EXT_DUMMY['ext_lang'][$k]);
unset($EXT_DUMMY['ext_css'][$k]);
unset($EXT_DUMMY['ext_funcs'][$k]);
- }
+ } // END - foreach
+
+ // Write dummy array back
+ $EXT_DUMMY['ext_name'] = $EXT_NAMES;
+ unset($EXT_NAMES);
// Close cache file
- $CACHE->cache_close();
+ $cacheInstance->cache_close();
// Loading cache is done so let's free some memory!
unset($EXT_DUMMY['ext_lang']);
unset($EXT_DUMMY['ext_keep']);
unset($EXT_DUMMY['ext_css']);
unset($EXT_DUMMY['ext_funcs']);
- $EXTENSIONS = $EXT_DUMMY;
+ $cacheArray['extensions'] = $EXT_DUMMY;
unset($EXT_DUMMY);
// No database load needed
$res_ext_crt = false;
-}
- else
-{
+
+ // Load more cache files (like admins)
+ require_once(PATH."inc/load_cache.php");
+
+ // Load all extension files
+ foreach ($EXT_POOL as $inc) {
+ require_once($inc);
+ } // END - foreach
+
+ // Remove array
+ unset($EXT_POOL);
+} else {
// If current user is not admin load only activated extensions
// The admin shall use every available extension for testing purposes
- if (!IS_ADMIN()) $ADD = " WHERE ext_active='Y'";
+ if ((!IS_ADMIN()) && ($cacheMode != "init")) $ADD = " WHERE ext_active='Y'";
- if (GET_EXT_VERSION("sql_patches") >= "0.0.6")
- {
+ if (GET_EXT_VERSION("sql_patches") >= "0.0.6") {
// Query with CSS file from DB
$res_ext_crt = SQL_QUERY("SELECT id, ext_name, ext_lang_file, ext_has_css, ext_active, ext_version
FROM "._MYSQL_PREFIX."_extensions".$ADD."
ORDER BY ext_name", __FILE__, __LINE__);
- }
- else
- {
+ } else {
// Old obsulete query string
$res_ext_crt = SQL_QUERY("SELECT id, ext_name, ext_lang_file, ext_name, ext_active, ext_version
FROM "._MYSQL_PREFIX."_extensions".$ADD."
$DEL = array();
// At least one found?
-if ((SQL_NUMROWS($res_ext_crt) > 0) && (($CACHE_FILE == "init") || ($CACHE_FILE == "no")) && ($CSS != "1") && ($CSS != "-1"))
-{
+if ((SQL_NUMROWS($res_ext_crt) > 0) && (($cacheMode == "init") || ($cacheMode == "no")) && ($CSS != "1") && ($CSS != "-1")) {
// Load theme management
require_once(PATH."inc/theme-manager.php");
// If we need to init the cache init it now
- if ($CACHE_FILE == "init") $CACHE->cache_init("EXTENSIONS");
+ if ($cacheMode == "init") $cacheInstance->cache_init("EXTENSIONS");
// Extensions are registered so we load them
- while (list($EXT_ID, $name, $lang, $css, $active, $version) = SQL_FETCHROW($res_ext_crt))
- {
+ while (list($EXT_ID, $name, $lang, $css, $active, $version) = SQL_FETCHROW($res_ext_crt)) {
// Get menu entry
- $result_menu = SQL_QUERY_ESC("SELECT has_menu FROM "._MYSQL_PREFIX."_mod_reg WHERE module='%s' LIMIT 1",
- array($name), __FILE__, __LINE__);
- list($menu) = SQL_FETCHROW($result_menu);
- //* DEBUG: */ echo "*".$name."/".$menu."*<br>";
-
- // An empty menu entry will be interpreted as N (no menu) to avoid problems
- if (empty($menu)) $menu = "N";
+ $menu = "N";
+ if (MODULE_HAS_MENU($name, true)) {
+ $menu = "Y";
+ } // END - if
// Load extensions
- $file1 = sprintf(PATH."inc/extensions/ext-%s.php", $name);
+ $file1 = sprintf("%sinc/extensions/ext-%s.php", PATH, $name);
$file2 = $file1; $EXT_CSS = "N"; $EXT_ALWAYS_ACTIVE = "N";
// Special functions file
- $file3 = sprintf(PATH."inc/libs/%s_functions.php", $name);
+ $file3 = sprintf("%sinc/libs/%s_functions.php", PATH, $name);
// Does the extension file exists?
- if (file_exists($file1) && is_readable($file1))
- {
+ if (FILE_READABLE($file1)) {
// If there's no language file specified we don't need to load one... ;-)
if (!empty($lang)) {
// Create language file
- $file2 = sprintf(PATH."inc/language/%s_%s.php", $lang, GET_LANGUAGE());
+ $file2 = sprintf("%sinc/language/%s_%s.php", PATH, $lang, GET_LANGUAGE());
}
- if (file_exists($file3) && is_readable($file3))
- {
+ if (FILE_READABLE($file3)) {
// Special functions file
$funcs = "Y";
require_once($file3);
- }
- else
- {
+ } else {
// Don't load functions file
$funcs = "N";
}
// Do we need a language file?
- if (($file1 != $file2) && (file_exists($file2)) && (is_readable($file2)))
- {
+ if (($file1 != $file2) && (FILE_READABLE($file2))) {
// Load language file
$lang = "Y";
include($file2);
- }
- else
- {
+ } else {
// Don't load language file
$lang = "N";
}
// Load extension
- if ($name != "sql_patches")
- {
+ if ($name != "sql_patches") {
// Load extension's file
include_once($file1);
- }
- else
- {
+ } else {
// KEEP sql_patches ALWAYS ACTIVE!
$EXT_ALWAYS_ACTIVE = "Y";
}
- if ($css == "Y")
- {
- $CSS_FILE = PATH."theme/".GET_CURR_THEME()."/css/".$name.".css";
- if (file_exists($CSS_FILE))
- {
+ if ($css == "Y") {
+ $CSS_FILE = sprintf("%stheme/%s/css/%s.css", PATH, GET_CURR_THEME(), $name);
+ if (FILE_READABLE($CSS_FILE)) {
// CSS file for extension was found (use only relative path for now!)
$EXT_CSS_FILES[] = $name.".css";
- }
- else
- {
+ } else {
// Don't load CSS file
$css = "N";
}
- }
+ } // END - if
// Add cache row
- if ($CACHE_FILE == "init")
- {
- $CACHE->add_row(array(
+ if ($cacheMode == "init") {
+ $cacheInstance->add_row(array(
'ext_id' => $EXT_ID,
'ext_name' => $name,
'ext_lang' => $lang,
'ext_version' => $version,
'ext_keep' => $EXT_ALWAYS_ACTIVE,
));
- }
- elseif ($CACHE_FILE == "no")
- {
+ } elseif ($cacheMode == "no") {
// Remember this value for later usage
- $KEEP_ACTIVE[$name] = $EXT_ALWAYS_ACTIVE;
+ $cacheArray['active_extensions'][$name] = $EXT_ALWAYS_ACTIVE;
}
- }
- elseif (!file_exists($file1))
- {
+ } elseif (!FILE_READABLE($file1)) {
// Deleted extension file so we mark it for removal from DB
$DEL[] = $name;
}
- }
+ } // END - while
- if ($CACHE_FILE == "init")
- {
+ if ($cacheMode == "init") {
// Close cache file
- $CACHE->cache_close();
+ $cacheInstance->cache_close();
// Load more cache files (like admins)
require_once(PATH."inc/load_cache.php");
- }
+ } // END - if
+
+ // Free memory
+ SQL_FREERESULT($res_ext_crt);
}
-// Free memory
-SQL_FREERESULT($res_ext_crt);
-
-// Compile configuration system
-/**
- * Commented out...
- *
- *foreach ($CONFIG as $k=>$v)
- *{
- * $CONFIG[$k] = COMPILE_CODE($v);
- *}
- */
-
-// Load include files
-if (!empty($INC_POOL[0]))
-{
- foreach ($INC_POOL as $inc)
- {
+// Load include files if found
+if (!empty($INC_POOL[0])) {
+ foreach ($INC_POOL as $inc) {
require_once($inc);
- }
-}
+ } // END - foreach
+
+ // Remove array
+ unset($INC_POOL);
+} // END - if
// Uninstall extensions that are no longer in our system
-if (!empty($DEL[0]))
-{
+if (!empty($DEL[0])) {
// Remove extensions from two tables: extension registry and tasks table
- foreach ($DEL as $name)
- {
+ foreach ($DEL as $name) {
// First remove entry from extensions table
- $result = SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_extensions WHERE ext_name='%s' LIMIT 1",
- array($name), __FILE__, __LINE__);
+ SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_extensions WHERE ext_name='%s' LIMIT 1",
+ array($name), __FILE__, __LINE__);
// Remove (maybe?) found tasks (main task and possible updates
- $result = SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_task_system WHERE subject LIKE '[%s:] %' AND (task_type='EXTENSION' OR task_type='EXTENSION_UPDATE')",
- array($name), __FILE__, __LINE__);
- }
+ SQL_QUERY_ESC("DELETE LOW_PRIORITY FROM "._MYSQL_PREFIX."_task_system WHERE subject LIKE '[%s:] %' AND (task_type='EXTENSION' OR task_type='EXTENSION_UPDATE')",
+ array($name), __FILE__, __LINE__);
+ } // END - foreach
// I think it's not neccessary to run the optimization function here
// because we didn't delete so much data from database. Can you aggree?
-}
+} // END - if
+
//
?>