X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=inc%2Floader%2Fload_cache-admin.php;h=fc7d134b718a955f20454c7240eda10e94366f4d;hb=d900268f17d81753e28bed251f143edc0402930b;hp=5f240f552632a7ca7b4d2065ec024cba0657c0f9;hpb=5bdeaf8b452206598b6c6cd4f941145b11a0eccc;p=mailer.git diff --git a/inc/loader/load_cache-admin.php b/inc/loader/load_cache-admin.php index 5f240f5526..fc7d134b71 100644 --- a/inc/loader/load_cache-admin.php +++ b/inc/loader/load_cache-admin.php @@ -1,7 +1,7 @@ loadCacheFile("admins")) && ($cacheInstance->extensionVersionMatches("admins"))) { +if (($GLOBALS['cache_instance']->loadCacheFile('admin')) && ($GLOBALS['cache_instance']->extensionVersionMatches('admins'))) { // Load cache - global $cacheArray; - $cacheArray['admins'] = $cacheInstance->getArrayFromCache(); + $GLOBALS['cache_array']['admin'] = $GLOBALS['cache_instance']->getArrayFromCache(); // Check if valid - if ((isset($cacheArray['admins']['login'])) && (is_array($cacheArray['admins']['login'])) && (is_array($cacheArray['admins']['aid']))) { + if ((isset($GLOBALS['cache_array']['admin']['login'])) && (is_array($GLOBALS['cache_array']['admin']['login'])) && (is_array($GLOBALS['cache_array']['admin']['admin_id']))) { // Check count - if (count($cacheArray['admins']['login']) == count($cacheArray['admins']['aid'])) { - // Get "id map" - $idMap = $cacheArray['admins']['aid']; - - // Rewrite the cache array - for ($idx = (count($idMap) - 1); $idx >= 0; $idx--) { + if (count($GLOBALS['cache_array']['admin']['login']) == count($GLOBALS['cache_array']['admin']['admin_id'])) { + // Rewrite the cache + $admins = array(); + foreach ($GLOBALS['cache_array']['admin']['login'] as $idx => $admin) { // Rewrite all entries - foreach ($cacheArray['admins'] as $key=>$entryArray) { - // Rewrite the entry - if ($key == "aid") { - // Rewrite admin id (use login name as index) - $cacheArray['admins']['aid'][$cacheArray['admins']['login'][$idx]] = $entryArray[$idx]; + foreach ($GLOBALS['cache_array']['admin'] as $key => $entry) { + // Do we have login or regular entries? + if ($key == 'login') { + // Login, so use id + $admins[$key][$GLOBALS['cache_array']['admin']['admin_id'][$idx]] = $entry[$idx]; } else { - // Rewrite regular entry - $cacheArray['admins'][$key][$idMap[$idx]] = $entryArray[$idx]; + // Regular entry so use login + $admins[$key][$GLOBALS['cache_array']['admin']['login'][$idx]] = $entry[$idx]; } + } // END - foreach + } // END - foreach - // Is the last entry reached? - if ($idx == 0) { - // Remove it - unset($cacheArray['admins'][$key][0]); - } // END - if - } // END - if - } // END - for + // Transfer back to cache array and remove dummy + $GLOBALS['cache_array']['admin'] = $admins; + unset($admins); } else { // Nope, cache file is corrupted! - $cacheInstance->destroyCacheFile(); - unset($cacheArray['admins']); + $GLOBALS['cache_instance']->removeCacheFile(); + unset($GLOBALS['cache_array']['admin']); } } else { // Nope, cache file is corrupted! - $cacheInstance->destroyCacheFile(); - unset($cacheArray['admins']); + $GLOBALS['cache_instance']->removeCacheFile(); + unset($GLOBALS['cache_array']['admin']); } -} elseif ((getConfig('cache_admins') == "Y") && ($CSS != "1") && ($CSS != "-1")) { +} elseif (getOutputMode() != 1) { // Create cache file - $cacheInstance->init("ADMINS"); - $cacheInstance->storeExtensionVersion("admins"); + $GLOBALS['cache_instance']->init(); // Load every data from DB to cache file - $ADD = RUN_FILTER('sql_admin_extra_data'); + $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__); - while($dummy = SQL_FETCHARRAY($result_admins)) { + $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 - $cacheInstance->addRow($dummy); + $GLOBALS['cache_instance']->addRow($dummy); } // END - while // Free memory SQL_FREERESULT($result_admins); // Close cache - $cacheInstance->finalize(); - - // Reload the cache - require(__FILE__); + $GLOBALS['cache_instance']->storeExtensionVersion('admins'); + $GLOBALS['cache_instance']->finalize(); } // Next cached table are the admins_acls... -if (GET_EXT_VERSION("admins") >= "0.3") { +if (isExtensionInstalledAndNewer('admins', '0.3')) { // Check for cache file - if (($cacheInstance->loadCacheFile("admins_acls")) && ($cacheInstance->extensionVersionMatches("admins"))) { + if (($GLOBALS['cache_instance']->loadCacheFile('admin_acls')) && ($GLOBALS['cache_instance']->extensionVersionMatches('admins'))) { // Load referal system from cache - global $cacheArray; - $cacheArray['admin_acls'] = $cacheInstance->getArrayFromCache(); - } elseif ((getConfig('cache_acls') == "Y") && ($CSS != "1") && ($CSS != "-1")) { + $GLOBALS['cache_array']['admin_acls'] = $GLOBALS['cache_instance']->getArrayFromCache(); + } elseif (getOutputMode() != 1) { // Create cache file here - $cacheInstance->init("ADMINS_ACLS"); - $cacheInstance->storeExtensionVersion("admins"); + $GLOBALS['cache_instance']->init(); - // Load all modules and their data - $result = SQL_QUERY("SELECT id, admin_id, action_menu, what_menu, access_mode FROM `{!_MYSQL_PREFIX!}_admins_acls` ORDER BY admin_id, action_menu, what_menu", __FILE__, __LINE__); + // 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` ASC, `action_menu` ASC, `what_menu` ASC', __FILE__, __LINE__); // Add all rows - while ($data = SQL_FETCHARRAY($result)) { + while ($content = SQL_FETCHARRAY($result)) { // Add row to cache file - $cacheInstance->addRow($data); + $GLOBALS['cache_instance']->addRow($content); } // END - while // Free memory SQL_FREERESULT($result); // Close cache - $cacheInstance->finalize(); - - // Reload the cache - require(__FILE__); + $GLOBALS['cache_instance']->storeExtensionVersion('admins'); + $GLOBALS['cache_instance']->finalize(); } } // END - if -// +// [EOF] ?>