Вход Регистрация
Файл: admin/applications/core/tasks/optimize.php
Строк: 80
<?php
/**
 * @file        optimize.php     Task to optimize database tables daily
 *~TERABYTE_DOC_READY~
 * $Copyright: (c) 2001 - 2011 Invision Power Services, Inc.$
 * $License: http://www.invisionpower.com/company/standards.php#license$
 * $Author: ips_terabyte $
 * @since        -
 * $LastChangedDate: 2012-05-25 13:17:47 -0400 (Fri, 25 May 2012) $
 * @version        v3.3.3
 * $Revision: 10798 $
 */

if ( ! defined'IN_IPB' ) )
{
    print 
"<h1>Incorrect access</h1>You cannot access this file directly. If you have recently upgraded, make sure you upgraded all the relevant files.";
    exit();
}

/**
 *
 * @class        task_item
 * @brief        Task to optimize database tables daily
 *
 */
class task_item
{
    
/**
     * Tables to optimize.  Initially I was just going to run
     * optimize tables query against all tables, but Charles
     * prefers this static list of tables, and so it shall be.
     *
     * @var        $charlesTables
     */
    
protected $charlesTables = array( 'core_item_markers',
                                      
'core_item_markers_storage',
                                      
'inline_notifications',
                                      
'cache_store',
                                      
'content_cache_posts',
                                     );
    
    
/**
     * Object that stores the parent task manager class
     *
     * @var        $class
     */
    
protected $class;
    
    
/**
     * Array that stores the task data
     *
     * @var        $task
     */
    
protected $task = array();
    
    
/**
     * Registry Object Shortcuts
     *
     * @var        $registry
     * @var        $DB
     * @var        $lang
     */
    
protected $registry;
    protected 
$DB;
    protected 
$lang;
    
    
/**
     * Constructor
     *
     * @param    object        $registry        Registry object
     * @param    object        $class            Task manager class object
     * @param    array        $task            Array with the task data
     * @return    @e void
     */
    
public function __constructipsRegistry $registry$class$task )
    {
        
/* Make registry objects */
        
$this->registry    $registry;
        
$this->DB        $this->registry->DB();
        
$this->lang        $this->registry->getClass('class_localization');
        
        
$this->class    $class;
        
$this->task        $task;
    }
    
    
/**
     * Run this task
     * 
     * @return    @e void
     */
    
public function runTask()
    {
        
/* Not needed for mssql as per #23105 bug */
        
if ( ipsRegistry::dbFunctions()->getDriverType() != 'mysql' )
        {
            
$this->class->unlockTask$this->task );
            return;
        }
        
        
/* Get tables and optimize */
        
$tables  $this->charlesTables;
        
$_tables = array();
        
        if( 
is_array($tables) AND count($tables) )
        {
            
/* InnoDB is a no-no! :o */
            
$this->DB->query"SHOW TABLE STATUS" );
            
            while( 
$tbl $this->DB->fetch() )
            {
                if ( ! empty(
$tbl['Name']) && in_array$tbl['Name'], $tables ) && strtolower($tbl['Engine']) != 'innodb' )
                {
                    
$_tables[] = $tbl['Name'];
                }
            }
            
            
/* Was everything a no-no? :( */
            
if( count($_tables) )
            {
                
$PRE ipsRegistry::dbFunctions()->getPrefix();
                
                foreach( 
$_tables as $_table )
                {
                    
$this->DB->query"OPTIMIZE TABLE {$PRE}{$_table});
                    
$this->DB->query"ANALYZE TABLE {$PRE}{$_table});
                }
            }
        }
        
        
/* Log to log table - modify but dont delete */
        
$this->registry->getClass('class_localization')->loadLanguageFile( array( 'public_global' ), 'core' );
        
$this->class->appendTaskLog$this->tasksprintf$this->lang->words['task__optimizedtables'], count($_tables) ) );
        
        
/* Unlock Task: DO NOT MODIFY! */
        
$this->class->unlockTask$this->task );
    }
}
Онлайн: 0
Реклама