Вход Регистрация
Файл: MobileCMS-2.7.0-beta/libraries/controller.php
Строк: 54
<?php
/**
     * MobileCMS
     *
     * Open source content management system for mobile sites
     *
     * @author MobileCMS Team <support@mobilecms.ru>
     * @copyright Copyright (c) 2011, MobileCMS Team
     * @link http://mobilecms.ru Official site
     * @license http://opensource.org/licenses/gpl-license.php GNU Public License
     */

/**
 * Главный контроллер
 */
abstract class Controller {
    
/**
     * Переменная, в которую записываем ошибки при валидации форм
     */
    
public $error false;
    
/**
     * Класс шаблонизатора
     */
    
public $tpl;
    
/**
     * Тема
     */
    
protected $template_theme 'default';
    
/**
     * Количество элементов на страницу по умолчанию
     */
    
protected $per_page 7;

    
/**
     * Constructor
     */
    
public function __construct() {
        
$this->config Registry::get('config');
        
$this->db Registry::get('db');

        
// Определение старта для пагинации
        
$this->start = !empty($_GET['start']) ? intval($_GET['start']) : 0;
        if (!empty(
$_GET['page']) && is_numeric($_GET['page'])) {
            
$this->start $_GET['page'] * $this->per_page 1;
        }
        if (
$this->start 0) {
            
a_error('Не верный формат данных');
        }
        
        
// Подключение шаблонизатора
        
a_import('libraries/template');
        
$this->tpl = new Template;
        
        
// Добавляем объект шаблона в Registry
        
Registry::set('tpl'$this->tpl);
        
        
// Подключение кеширования
        
$this->cache = new SystemDeprecatedFileCache(ROOT.'cache/file_cache');
        
        
// Добавление мета данных на страницу
        
define('DESCRIPTION'$this->config['system']['description']);
        
define('KEYWORDS'$this->config['system']['keywords']);

        
// Получение данных о польльзователе
        
if (!empty($_SESSION['check_user_id'])) $user_id $_SESSION['check_user_id'];
        elseif (!empty(
$_SESSION['user_id'])) $user_id $_SESSION['user_id'];
        else 
$user_id = -1;
        
        
// Авторизация гостей по COOKIES, добавление гостей в бд
        
if ($user_id == -&& !empty($_COOKIE['username'])) {
            if (
$try_user_id $this->db->get_one("SELECT user_id FROM #__users WHERE username = '".a_safe($_COOKIE['username'])."' AND password = '".a_safe($_COOKIE['password'])."'")) {
                
$user_id $try_user_id;
                
$_SESSION['user_id'] = $user_id;
            }
        }
        
        
// Добавление гостей в бд
        
if ($user_id == -1) {
            
$user_agent $_SERVER['HTTP_USER_AGENT'];
            
            
// Проверяем наличие гостя в списке
            
if ($guest $this->db->get_row("SELECT id FROM #__guests WHERE ip = '".a_safe($_SERVER['REMOTE_ADDR'])."' AND user_agent = '".a_safe($user_agent)."'")) {
                
// Обновляем дату последнего посещения
                
$this->db->query("UPDATE #__guests SET
                    last_time = UNIX_TIMESTAMP()
                    WHERE id = '"
intval($guest['id'])."'
                "
);
            }
            
// Добавляем нового гостя в список
            
else {
                
// Записываем гостя в базу
                
$this->db->query("INSERT INTO #__guests SET
                    ip = '"
a_safe($_SERVER['REMOTE_ADDR'])."',
                    user_agent = '"
a_safe($user_agent)."',
                    last_time = UNIX_TIMESTAMP()
                "
);     
            }
        }
        
        
$this->user $this->db->get_row("SELECT * FROM #__users LEFT JOIN #__users_profiles USING(user_id) WHERE user_id = $user_id");
        
        
define('USER_ID'$this->user['user_id']);
        
$this->tpl->assign('user'$this->user);
        
        
// Обновляем время последнего посещения
        
if (USER_ID != -1$this->db->query("UPDATE #__users SET last_visit = UNIX_TIMESTAMP() WHERE user_id = '".USER_ID."'");
        
        
// Подключения помощника пользователей
        
a_import('modules/user/helpers/user');
        
        
// Управление правами доступа
        
$this->access a_load_class('libraries/access');

        if (
$this->user) {
            
$access_level $this->access->get_level($this->user['status']);
        } else {
            
$access_level 1;
        }

        
define('ACCESS_LEVEL'$access_level);

        
// Выполнение событий до вызова контроллера
        
main::events_exec($this->db'pre_controller');

        if (
ACCESS_LEVEL $this->access_level) {
            if (
USER_ID == -1) {
                
header('Location: '.a_url('user/login''from='.urlencode($_SERVER["REQUEST_URI"]), true));
                exit;
            } else {
                
a_error('У вас нет доступа к данной странице!');
            }
        }
        
        
// Получение темы оформления, для админки
        
if ($this->template_theme == 'admin') {
            
$this->tpl->theme $this->config['system']['admin_theme'];
        }
        
// Использование Web темы
        
elseif (WEB_VERSION == '1') {            
            
$this->tpl->theme $this->config['system']['web_theme'];
        } else {
            
$this->tpl->theme $this->config['system']['default_theme'];
        }
        
        
define('THEME'$this->tpl->theme);

        
// Проверка модерации пользователя
        
if (defined('MODERATE')) {
            
a_error(MODERATE);
        }
    }
}
?>
Онлайн: 0
Реклама