Вход Регистрация
Файл: mc-2.6.3/modules/private/controllers/private.php
Строк: 85
<?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
 */

defined('IN_SYSTEM') or die('<b>403<br />Запрет доступа!</b>');


/**
 * Пользовательский контроллер модуля личных сообщений
 */
class Private_Controller extends Controller {
    
/**
     * Уровень пользовательского доступа
     */
    
public $access_level 5;
    
/**
     * Папки
     */
    
public $folders = array(
        
'new' => 'Новые',
        
'inbox' => 'Входящие',
        
'outbox' => 'Исходящие',
        
'saved' => 'Сохраненные'
    
);

    
/**
     * Метод по умолчанию
     */
    
public function action_index() {
        
$this->action_folders();
    }

    
/**
     * Список папок
     */
    
public function action_folders() {
        
$result $this->db->query("SELECT COUNT(*) AS count, folder FROM #__private_messages WHERE user_id = '".USER_ID."' GROUP BY folder");
        
$folders = array();
        while (
$folder $this->db->fetch_array($result)) {
            
$folders[$folder['folder']] = $folder['count'];
        }
    
        
$this->tpl->assign(array(
            
'folders' => $folders
        
));
    
        
$this->tpl->display('folders');
    }

    
/**
     * Отправить сообщение
     */
    
public function action_send() {
        if (isset(
$_POST['submit'])) {
            if (!
$user_to_id $this->db->get_one("SELECT user_id FROM #__users WHERE username = '".a_safe($_POST['username'])."' AND user_id != -1")) {
                
$this->error .= 'Получаетель не найден!<br />';
            }
            if (
$user_to_id == USER_ID) {
                
$this->error .= 'Отправлять сообщения самому себе запрещено!<br />';
            }
            if (empty(
$_POST['message'])) {
                
$this->error .= 'Укажите текст сообщения.<br />';
            }

            if (!
$this->error) {
                
# Отправляем сообщение адресату
                
$this->db->query("INSERT INTO #__private_messages SET
                    user_id = '
$user_to_id',
                    user_to_id = '
$user_to_id',
                    user_from_id = '"
.USER_ID."',
                    message = '"
a_safe($_POST['message'])."',
                    folder = 'new',
                    time = UNIX_TIMESTAMP()
                "
);
                
# Копируем сообщение в исходящие отправителя
                
$this->db->query("INSERT INTO #__private_messages SET
                    user_id = '"
USER_ID."',
                    user_to_id = '
$user_to_id',
                    user_from_id = '"
.USER_ID."',
                    message = '"
a_safe($_POST['message'])."',
                    folder = 'outbox',
                    time = UNIX_TIMESTAMP()
                "
);
    
                
a_notice('Сообщение отправлено!'a_url('private'));
            }
        }
        if (!isset(
$_POST['submit']) OR $this->error) {
            
$this->tpl->assign(array(
                
'error' => $this->error
            
));

            
$this->tpl->display('send');
        }
    }

    
/**
     * Просмотр папки
     */
    
public function action_list_messages() {
        if (!
array_key_exists($_GET['folder'], $this->folders))
            
a_error("Папка не найдена!");

        
$result $this->db->query("SELECT SQL_CALC_FOUND_ROWS pm.*, u_to.username AS username_to, u_from.username AS username_from
            FROM #__private_messages AS pm
            LEFT JOIN #__users AS u_to ON u_to.user_id = pm.user_to_id
            LEFT JOIN #__users AS u_from ON u_from.user_id = pm.user_from_id
            WHERE pm.folder = '"
a_safe($_GET['folder'])."' AND pm.user_id = '".USER_ID."'
            ORDER BY message_id DESC
            LIMIT 
$this->start$this->per_page
        "
);
        
$total $this->db->get_one("SELECT FOUND_ROWS()");

        if (!
class_exists('smiles')) a_import('modules/smiles/helpers/smiles');
        
$messages = array();
        while (
$message $this->db->fetch_array($result)) {
            
$message['message'] = smiles::smiles_replace($message['message']);
            
$message['message'] = main::bbcode($message['message']);
            
$message['message'] = nl2br($message['message']);

            
$messages[] = $message;
        }

        
# Если папка "новые", метим сообщения прочитанными
        
$this->db->query("UPDATE #__private_messages SET folder = 'inbox' WHERE user_id = '".USER_ID."' AND folder = 'new'");

        
# Пагинация
        
$pg_conf['base_url'] = a_url('private/list_messages''folder='.$_GET['folder'].'&amp;start=');
        
$pg_conf['total_rows'] = $total;
        
$pg_conf['per_page'] = $this->per_page;

        
a_import('libraries/pagination');
        
$pg = new CI_Pagination($pg_conf);

        
$this->tpl->assign(array(
            
'messages' => $messages,
            
'folder_name' => $this->folders[$_GET['folder']],
            
'pagination' => $pg->create_links()
        ));

        
$this->tpl->display('list_messages');
    }

    
/**
     * Просмотр сообщения
     */
    
public function view_message() {
        
$message $this->db->get_row("SELECT * FROM #__private_messages
            WHERE message_id = '"
intval($_GET['message_id'])."' AND user_id = '".USER_ID."'
        "
);

        if (!
$messagea_error("Сообщение не найдено!");

        
$this->tpl->assign(array(
            
'message' => $message
        
));

        
$this->tpl->display('view_message');
    }

    
/**
     * Удаление сообщения
     */
    
public function action_delete_message() {
        
$message $this->db->get_row("SELECT * FROM #__private_messages
            WHERE message_id = '"
intval($_GET['message_id'])."' AND user_id = '".USER_ID."'
        "
);

        if (!
$messagea_error("Сообщение не найдено!");

        if (!empty(
$_GET['confirm'])) {
            
$this->db->query("DELETE FROM #__private_messages WHERE message_id = '".intval($_GET['message_id'])."' AND user_id = '".USER_ID."'");
            
a_notice('Сообщение удалено!'a_url('private/list_messages''folder='.$_GET['folder']));
        }
        else {
            
a_confirm('Подтверждаете удаление данного сообщения?'a_url('private/delete_message''message_id='.$_GET['message_id'].'&amp;folder='.$_GET['folder'].'&amp;confirm=ok'), a_url('private/list_messages''folder='.$_GET['folder']));
        }
    }

    
/**
     * Сохранение сообщения
     */
    
public function action_save_message() {
        
$message $this->db->get_row("SELECT * FROM #__private_messages
            WHERE message_id = '"
intval($_GET['message_id'])."' AND user_id = '".USER_ID."'
        "
);

        if (!
$messagea_error("Сообщение не найдено!");

        
$this->db->query("UPDATE #__private_messages SET folder = 'saved' WHERE message_id = '".intval($_GET['message_id'])."' AND user_id = '".USER_ID."'");
        
a_notice('Сообщение сохранено!'a_url('private/list_messages''folder=saved'));
    }
}
?>
Онлайн: 0
Реклама