X-Git-Url: https://git.mxchange.org/?p=mailer.git;a=blobdiff_plain;f=inc%2Floader%2Fload_cache-admin.php;h=93e862d4c5f60c241ba992574b923241f07acc18;hp=93280c2a561025c23d7785aab7d576d40f47866c;hb=06d97fddd5c72e2b1c14ddb855b7eddc53f169a7;hpb=a090e351c49fe021fb3064325694da03402332e0 diff --git a/inc/loader/load_cache-admin.php b/inc/loader/load_cache-admin.php index 93280c2a56..93e862d4c5 100644 --- a/inc/loader/load_cache-admin.php +++ b/inc/loader/load_cache-admin.php @@ -17,7 +17,7 @@ * Needs to be in all Files and every File needs "svn propset * * svn:keywords Date Revision" (autoprobset!) at least!!!!!! * * -------------------------------------------------------------------- * - * Copyright (c) 2003 - 2008 by Roland Haeder * + * Copyright (c) 2003 - 2009 by Roland Haeder * * For more information visit: http://www.mxchange.org * * * * This program is free software; you can redistribute it and/or modify * @@ -38,30 +38,32 @@ // Some security stuff... if (!defined('__SECURITY')) { - $INC = substr(dirname(__FILE__), 0, strpos(dirname(__FILE__), '/inc') + 4) . '/security.php'; - require($INC); + die(); } // END - if +// Use this code if you don't want to run this cache loader on installation phase +if (isInstallationPhase()) return; + // Let's start with the admins table... if (($GLOBALS['cache_instance']->loadCacheFile('admins')) && ($GLOBALS['cache_instance']->extensionVersionMatches('admins'))) { // Load cache $GLOBALS['cache_array']['admins'] = $GLOBALS['cache_instance']->getArrayFromCache(); // Check if valid - if ((isset($GLOBALS['cache_array']['admins']['login'])) && (is_array($GLOBALS['cache_array']['admins']['login'])) && (is_array($GLOBALS['cache_array']['admins']['aid']))) { + if ((isset($GLOBALS['cache_array']['admins']['login'])) && (is_array($GLOBALS['cache_array']['admins']['login'])) && (is_array($GLOBALS['cache_array']['admins']['admin_id']))) { // Check count - if (count($GLOBALS['cache_array']['admins']['login']) == count($GLOBALS['cache_array']['admins']['aid'])) { + if (count($GLOBALS['cache_array']['admins']['login']) == count($GLOBALS['cache_array']['admins']['admin_id'])) { // Get "id map" - $idMap = $GLOBALS['cache_array']['admins']['aid']; + $idMap = $GLOBALS['cache_array']['admins']['admin_id']; // Rewrite the cache array for ($idx = (count($idMap) - 1); $idx >= 0; $idx--) { // Rewrite all entries foreach ($GLOBALS['cache_array']['admins'] as $key=>$entryArray) { // Rewrite the entry - if ($key == 'aid') { + if ($key == 'admin_id') { // Rewrite admin id (use login name as index) - $GLOBALS['cache_array']['admins']['aid'][$GLOBALS['cache_array']['admins']['login'][$idx]] = $entryArray[$idx]; + $GLOBALS['cache_array']['admins']['admin_id'][$GLOBALS['cache_array']['admins']['login'][$idx]] = $entryArray[$idx]; } else { // Rewrite regular entry $GLOBALS['cache_array']['admins'][$key][$idMap[$idx]] = $entryArray[$idx]; @@ -76,26 +78,28 @@ if (($GLOBALS['cache_instance']->loadCacheFile('admins')) && ($GLOBALS['cache_in } // END - for } else { // Nope, cache file is corrupted! - $GLOBALS['cache_instance']->destroyCacheFile(); + $GLOBALS['cache_instance']->removeCacheFile(); unset($GLOBALS['cache_array']['admins']); } } else { // Nope, cache file is corrupted! - $GLOBALS['cache_instance']->destroyCacheFile(); + $GLOBALS['cache_instance']->removeCacheFile(); unset($GLOBALS['cache_array']['admins']); } -} elseif ((getConfig('cache_admins') == 'Y') && ($GLOBALS['output_mode'] != '1') && ($GLOBALS['output_mode'] != '-1')) { +} elseif (getOutputMode() != '1') { // Create cache file $GLOBALS['cache_instance']->init('ADMINS'); - $GLOBALS['cache_instance']->storeExtensionVersion('admins'); // Load every data from DB to cache file $add = runFilterChain('sql_admin_extra_data'); // Query the database about this - $result_admins = SQL_QUERY('SELECT id AS aid, login, password, email'.$add.' -FROM `{!_MYSQL_PREFIX!}_admins` -ORDER BY login', __FILE__, __LINE__); + $result_admins = SQL_QUERY('SELECT + `id` AS admin_id, `login`, `password`, `email`' . $add . ' +FROM + `{?_MYSQL_PREFIX?}_admins` +ORDER BY + `login` ASC', __FILE__, __LINE__); while ($dummy = SQL_FETCHARRAY($result_admins)) { // Save row $GLOBALS['cache_instance']->addRow($dummy); @@ -105,42 +109,43 @@ ORDER BY login', __FILE__, __LINE__); SQL_FREERESULT($result_admins); // Close cache + $GLOBALS['cache_instance']->storeExtensionVersion('admins'); $GLOBALS['cache_instance']->finalize(); // Include loader again - require(__FILE__); + loadInclude('inc/loader/'.basename(__FILE__)); } // Next cached table are the admins_acls... -if (GET_EXT_VERSION('admins') >= '0.3') { +if (isExtensionInstalledAndNewer('admins', '0.3')) { // Check for cache file if (($GLOBALS['cache_instance']->loadCacheFile('admins_acls')) && ($GLOBALS['cache_instance']->extensionVersionMatches('admins'))) { // Load referal system from cache $GLOBALS['cache_array']['admin_acls'] = $GLOBALS['cache_instance']->getArrayFromCache(); - } elseif ((getConfig('cache_acls') == 'Y') && ($GLOBALS['output_mode'] != '1') && ($GLOBALS['output_mode'] != '-1')) { + } elseif (getOutputMode() != '1') { // Create cache file here $GLOBALS['cache_instance']->init('ADMINS_ACLS'); - $GLOBALS['cache_instance']->storeExtensionVersion('admins'); // Load all modules and their data (column 'id' is no longer required) - $result = SQL_QUERY('SELECT admin_id, action_menu, what_menu, access_mode FROM `{!_MYSQL_PREFIX!}_admins_acls` ORDER BY admin_id, action_menu, what_menu', __FILE__, __LINE__); + $result = SQL_QUERY('SELECT `admin_id`, `action_menu`, `what_menu`, `access_mode` FROM `{?_MYSQL_PREFIX?}_admins_acls` ORDER BY admin_id, action_menu, what_menu', __FILE__, __LINE__); // Add all rows - while ($data = SQL_FETCHARRAY($result)) { + while ($content = SQL_FETCHARRAY($result)) { // Add row to cache file - $GLOBALS['cache_instance']->addRow($data); + $GLOBALS['cache_instance']->addRow($content); } // END - while // Free memory SQL_FREERESULT($result); // Close cache + $GLOBALS['cache_instance']->storeExtensionVersion('admins'); $GLOBALS['cache_instance']->finalize(); // Include loader again - require(__FILE__); + loadInclude('inc/loader/'.basename(__FILE__)); } } // END - if -// +// [EOF] ?>