Fixes for installation phase
[mailer.git] / inc / loader / load_cache-admin.php
index 11d80fe5118e3fcb59c2df467d4a561e719f8b5b..93e862d4c5f60c241ba992574b923241f07acc18 100644 (file)
@@ -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 *
 
 // 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') && (getOutputMode() != '1') && (getOutputMode() != '-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') && (getOutputMode() != '1') && (getOutputMode() != '-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]
 ?>