Файл: mc-2.6.4/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);
        
        // Подключение кеширования
        if (!class_exists('File_Cache')) a_import('libraries/file_cache');
        $this->cache = new File_Cache(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 == -1 && !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);
        }
    }
}
?>