Просмотр файла mc-2.6.3/modules/chat/controllers/chat.php

Размер файла: 6.25Kb
<?php
/**
 * MobileCMS
 *
 * Open source content management system for mobile sites
 *
 * @author MobileCMS Team <[email protected]>
 * @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 Chat_Controller extends Controller {
	/**
	 * Уровень пользовательского доступа
	 */
	public $access_level = 0;

	/**
	 * Constructor
	 */
	public function __construct() {
		parent::__construct();

		if (ACCESS_LEVEL < 5)
			a_notice('Для того чтобы находиться в чате необходимо <a href="'.a_url('user/registration').'">зарегистрироваться</a> либо <a href="'.a_url('user/login').'">войти</a> под своим именем!', a_url('user/registration'), 10);
	}

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

	/**
	 * Список комнат
	 */
	public function action_list_rooms() {
		# Обновляем время последнего посещения
		$this->db->query("UPDATE #__users SET
			chat_room_id = '0',
			chat_last_time = UNIX_TIMESTAMP()
			WHERE
			user_id = '". USER_ID."'
		");

		# Список комнат
		$rooms = $this->db->get_array("SELECT *,
			(SELECT COUNT(*) FROM #__users AS u WHERE u.chat_room_id = cr.room_id AND u.chat_last_time >= UNIX_TIMESTAMP() + ". intval($this->config['chat']['online_time'])." * 60) AS users_in_room
			FROM #__chat_rooms AS cr ORDER BY position");

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

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

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

		if (ACCESS_LEVEL < 8 && USER_ID != $message['user_id']) a_error('У вас нет прав на выполнение этой операции!');

		if (!empty($_GET['confirm'])) {
			$this->db->query("DELETE FROM #__chat_messages WHERE message_id = '".intval($_GET['message_id'])."'");
			# Уменьшаем рейтинг
			user::rating_update(-1, $message['user_id']);
			a_notice('Сообщение удалено!', a_url('chat/in_room', 'room_id='.$_GET['room_id']));
		}
		else {
			a_confirm('Подтверждаете удаление данного сообщения?', a_url('chat/delete_message', 'message_id='.$_GET['message_id'].'&amp;room_id='.$_GET['room_id'].'&amp;confirm=ok'), a_url('chat/in_room', 'room_id='.$_GET['room_id']));
		}
	}

	/**
	 * Просмотр комнаты
	 */
	public function action_in_room() {
		$this->per_page = $this->config['chat']['messages_per_page'];

		if (isset($_POST['update'])) {
			if (is_numeric($_POST['update']) && ($_POST['update'] >= 0 OR $_POST['update'] <= 60)) {
				$this->db->query("UPDATE #__users SET chat_update = '".intval($_POST['update'])."' WHERE user_id = '".USER_ID."'");
				# Обновим информацию о пользователе
				$this->user['chat_update'] = intval($_POST['update']);
			}
		}

  		if (!$room = $this->db->get_row("SELECT * FROM #__chat_rooms WHERE room_id = '".intval($_GET['room_id'])."'"))
			a_error('Раздел не найден!');

		# Обновляем время последнего посещения
		$this->db->query("UPDATE #__users SET
			chat_room_id = '". $room['room_id']."',
			chat_last_time = UNIX_TIMESTAMP()
			WHERE
			user_id = '". USER_ID."'
		");

		 $sql = "SELECT SQL_CALC_FOUND_ROWS cm.*, u.username, u.status AS user_status, up.avatar AS avatar_exists, u.last_visit
			FROM #__chat_messages AS cm LEFT JOIN #__users AS u USING(user_id) LEFT JOIN #__users_profiles AS up USING(user_id)
			WHERE cm.room_id = ". intval($_GET['room_id']);

		$sql .= " ORDER BY cm.message_id DESC LIMIT $this->start, $this->per_page";

		$result = $this->db->query($sql);

		$messages = array();
		if (!class_exists('smiles')) a_import('modules/smiles/helpers/smiles');
		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;
		}

		$total = $this->db->get_one("SELECT FOUND_ROWS()");

		# Пагинация
		$pg_conf['base_url'] = a_url('chat/in_room', 'room_id='.intval($_GET['room_id']).'&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,
			'room' => $room,
			'pagination' => $pg->create_links()
		));
	
		$this->tpl->display('in_room');
	}

	/**
	 * Написать сообщение
	 */
	public function action_say() {
		if (!$room = $this->db->get_row("SELECT * FROM #__chat_rooms WHERE room_id = '".intval($_GET['room_id'])."'"))
			a_error('Комната не найдена!');

		if (isset($_POST['submit'])) {
			if (empty($_POST['message'])) {
				$this->error .= 'Укажите сообщение!<br />';
			}
			if (main::strlen($_POST['message']) > $this->config['chat']['message_max_len']) {
				$this->error .= 'Сообщение превышает '.$this->config['chat']['message_max_len'].' символов!<br />';
			}

			if (!$this->error) {
				# Добавляем сообщение
				$this->db->query("INSERT INTO #__chat_messages SET
					user_id = '". USER_ID."',
					room_id = '". $room['room_id']."',
					message = '". a_safe($_POST['message'])."',
					time = UNIX_TIMESTAMP()
				");

				# Добавляем рейтинг
				user::rating_update();
		
				header('location: '.a_url('chat/in_room', 'room_id='.intval($_GET['room_id']), TRUE));
				exit;
			}
		}
		if (!isset($_POST['submit']) || $this->error) {
			$this->tpl->assign(array(
			'error' => $this->error,
			'room' => $room
			));
	
			$this->tpl->display('say');
		}
	}
}
?>