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']))) { // Check count if (count($GLOBALS['cache_array']['admins']['login']) == count($GLOBALS['cache_array']['admins']['aid'])) { // Get "id map" $idMap = $GLOBALS['cache_array']['admins']['aid']; // 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') { // Rewrite admin id (use login name as index) $GLOBALS['cache_array']['admins']['aid'][$GLOBALS['cache_array']['admins']['login'][$idx]] = $entryArray[$idx]; } else { // Rewrite regular entry $GLOBALS['cache_array']['admins'][$key][$idMap[$idx]] = $entryArray[$idx]; } // Is the last entry reached? if ($idx == 0) { // Remove it unset($GLOBALS['cache_array']['admins'][$key][0]); } // END - if } // END - if } // END - for } else { // Nope, cache file is corrupted! $GLOBALS['cache_instance']->destroyCacheFile(); unset($GLOBALS['cache_array']['admins']); } } else { // Nope, cache file is corrupted! $GLOBALS['cache_instance']->destroyCacheFile(); unset($GLOBALS['cache_array']['admins']); } } elseif ((getConfig('cache_admins') == 'Y') && (getOutputMode() != '1') && (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__); while ($dummy = SQL_FETCHARRAY($result_admins)) { // Save row $GLOBALS['cache_instance']->addRow($dummy); } // END - while // Free memory SQL_FREERESULT($result_admins); // Close cache $GLOBALS['cache_instance']->finalize(); // Include loader again require(__FILE__); } // Next cached table are the admins_acls... if (GET_EXT_VERSION('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') && (getOutputMode() != '1') && (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__); // Add all rows while ($data = SQL_FETCHARRAY($result)) { // Add row to cache file $GLOBALS['cache_instance']->addRow($data); } // END - while // Free memory SQL_FREERESULT($result); // Close cache $GLOBALS['cache_instance']->finalize(); // Include loader again require(__FILE__); } } // END - if // ?>