Location: PHPKode > projects > phpMyVisites > phpmv2/core/include/ApplicationController.php
<?php
/* 
 * phpMyVisites : website statistics and audience measurements
 * Copyright (C) 2002 - 2006
 * http://www.phpmyvisites.net/ 
 * phpMyVisites is free software (license GNU/GPL)
 * Authors : phpMyVisites team
*/

// $Id: ApplicationController.php 232 2007-07-06 09:31:19Z matthieu_ $

require_once INCLUDE_PATH . '/core/include/Request.class.php';
require_once INCLUDE_PATH . '/core/include/Module.class.php';
require_once INCLUDE_PATH . '/core/include/Lang.class.php';
require_once INCLUDE_PATH . '/config.inc.php';
require_once INCLUDE_PATH . '/core/include/User.class.php';

class ApplicationController
{
    
    var $module;
    
    var $defaultModuleName = 'index';
    
    var $request;
    
    var $lang;
    
    
    /**
     * Constructeur
     */
    function ApplicationController(){}
    
    
    /**
     * Singleton
     */
    function &getInstance()
    {
        static $instance;
        
        if (!isset($instance)){
            $c = __CLASS__;
            $instance = new $c;
        }
        return $instance;
    }
    
    /**
     * Point d'entr�e de l'application
     *
     */
    function init()
    {
		    	
		$c =& PmvConfig::getInstance();
		$Lang =& Lang::getInstance();
		
		// id used for caching
		define('SMARTY_CACHE_ID', md5(
					@$_SERVER['SERVER_NAME']. // if server changes, must regenerate cache
					
					$_SERVER['PHP_SELF'].
					
					serialize($_GET). // one cache per distinct URL 
					
					serialize($_POST). // idem for POST
					
					// one cache per user
					(isset($_COOKIE[COOKIE_NAME_SESSION]) 
						? serialize($_COOKIE[COOKIE_NAME_SESSION])
						: '' ). 
					
					// file name of the language file
					$Lang->getFileName() . 
						
					// one cache per day
					date("Y-m-d"). 
					
					TIME_BEFORE_NEW_DAY_ARCHIVE. 
					PHPMV_VERSION.
					INTERNAL_STATS
				)
			);

		setIncludePath();
		
		$db =& Db::getInstance();

		if(defined( 'DB_HOST' ))
		{
			$db->connect();
		}
		
		// try to set memory limit to MEMORY_LIMIT 
		setMemoryLimit();
		
        $controller =& ApplicationController::getInstance();
        
		$controller->loadLang();
		
        $controller->parseRequest();

		$controller->loadModule();
		
		$controller->executeAction();
	}
     
    /**
     * Analyse et definit la requete utilisateur
     *
     */
    function parseRequest()
    {
         $this->request  =& Request::getInstance();
        if (!is_a( $this->request , 'Request'))
            trigger_error('Unable to parse current request... error', E_USER_ERROR);

    }
    
    /**
     * retourne la request 
     *
     */
    function &getRequest()
    {
        return $this->request;
    }
    
    
    function loadLang()
    {
        $this->lang =& Lang::getInstance();
    }
    
    function &getLang()
    {
        return $this->lang;
    }
    
    /**
     * Charge le module demand�
     *
     */
    function loadModule()
    {
		$moduleName = $this->request->getModuleName();
		$db =& Db::getInstance();
		
		if(ereg('admin', $moduleName) )
		{
			$this->lang->reloadLangFile();
		}
		if (!$moduleName)
		{
            $moduleName = $this->defaultModuleName;
		}
		
		
		if($moduleName == 'list_logos')
		{
			$authorized = true;
		}
		else
		{
			$b_writeDir = checkDirWritable( );
			
			/**
			 * very first : logo selection is allowed
			 */
			/**
			 * first look if installation is needed 
			 */
			if(!is_file( INCLUDE_PATH . "/config/config.php")
				|| !defined('DB_HOST')
				|| !defined('SU_LOGIN')
				|| !defined('INSTALL_OK'))
			{
				if( !Request::isCurrentModuleAnInstallModule() )
				{
					Request::redirectToModule('install_welcome');
				}
				$authorized = true;
			}
			
			/**
			 * second, look if database configuration only is needed
			 */
			else if(!$db->isReady() 
					&& substr_count( Request::getCurrentCompleteUrl(), 'mod=login' ) === 0
					&& substr_count( Request::getCurrentCompleteUrl(), 'mod=logout' ) === 0
					)
			{
				Request::redirectToModule('admin_db_config');			
			}
			
			/**
			 * third, look if there is a problem relative to writable directories
			 */
			else if( $b_writeDir === false)
			{	
				// case there is a write problem, we load server_info page to indicate the user the problem
				$moduleName = 'admin_server_info';
				$authorized = true;
			}
			else if($db->isReady())
			{
				if( version_compare($db->getVersion(), PHPMV_VERSION) == -1)
				{
					$moduleName = 'admin_update';
					$authorized = true;
				}
				else if( version_compare($db->getVersion(), PHPMV_VERSION) == 1)
				{
					trigger_error("There is a problem : your database is more recent than your phpMyVisites files! Try to upload the last release of phpMyVisites on your server.", E_USER_ERROR);
				}
			}
		}
		/**
		 * else it's ok! Load module
		 */
		
		// update module in the object request, used for hidden field in the login form
		$this->request->setModuleName($moduleName);
		
		// manage the user, is he authorized to see this module ?
		$me =& User::getInstance();
		
		
		if( isset($authorized)
			|| $me->isAuthorized( $moduleName )  
			|| $this->request->isCrontabAllowed()
			)
		{
	        $module = Module::factory($moduleName);
		}
		else
		{
	        $module = Module::factory('login');
		}
		
  		if (!is_subclass_of($module, 'Module'))
            trigger_error('Unable to load: ' . $moduleName . ' module', E_USER_ERROR);
        
         $module->init($this->request, null);
		
         $this->module =& $module;
	}
    
    
    function executeAction()
    {
		
        $this->module->doAction();
    }
}
?>
Return current item: phpMyVisites