1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-19 01:30:41 +00:00
Tims-Chat/file/lib/data/message/MessageList.class.php

101 lines
3.1 KiB
PHP
Raw Normal View History

<?php
2013-01-19 20:36:40 +01:00
namespace chat\data\message;
/**
* Represents a list of chat messages.
*
* @author Tim Düsterhus
2014-02-27 23:05:09 +01:00
* @copyright 2010-2014 Tim Düsterhus
* @license Creative Commons Attribution-NonCommercial-ShareAlike <http://creativecommons.org/licenses/by-nc-sa/3.0/legalcode>
2013-01-19 20:36:40 +01:00
* @package be.bastelstu.chat
* @subpackage chat.room
*/
2013-01-19 20:36:40 +01:00
class MessageList extends \wcf\data\DatabaseObjectList {
/**
* @see \wcf\data\DatabaseObjectList::$className
*/
2013-01-19 20:36:40 +01:00
public $className = 'chat\data\message\Message';
/**
* Reads the newest messages for the given room.
2014-02-28 17:06:50 +01:00
*
2013-01-19 20:36:40 +01:00
* @param \chat\data\room\Room $room
* @param integer $number
* @return array<\chat\data\message\Message>
*/
2013-01-19 20:36:40 +01:00
public static function getNewestMessages(\chat\data\room\Room $room, $number = CHAT_LASTMESSAGES) {
2013-06-23 18:46:52 +03:00
if ($number === 0) return array();
$messageList = new static();
$messageList->sqlOrderBy = "message.messageID DESC";
$messageList->sqlLimit = $number;
2013-05-15 22:11:47 +02:00
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
}
$messageList->readObjects();
return array_reverse($messageList->getObjects());
}
/**
* Reads the messages since the given message-id for the given room.
*
2013-01-19 20:36:40 +01:00
* @param \chat\data\room\Room $room
* @param integer $since
* @return array<\chat\data\message\Message>
*/
2013-01-19 20:36:40 +01:00
public static function getMessagesSince(\chat\data\room\Room $room, $since) {
$messageList = new static();
$messageList->sqlOrderBy = "message.messageID ASC";
$messageList->getConditionBuilder()->add('message.messageID > ?', array($since));
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
$messageList->getConditionBuilder()->add('
((
message.receiver IS NULL
AND message.roomID = ?
)
OR message.receiver = ?
OR message.sender = ?)',
array($room->roomID, \wcf\system\WCF::getUser()->userID, \wcf\system\WCF::getUser()->userID)
);
}
else {
$messageList->getConditionBuilder()->add('
(message.receiver IS NULL
OR message.receiver = ?
OR message.sender = ?)',
array(\wcf\system\WCF::getUser()->userID, \wcf\system\WCF::getUser()->userID)
);
}
$messageList->readObjects();
return $messageList->getObjects();
}
/**
* Reads the message between the given timestamps for the given room.
*
* @param \chat\data\room\Room $room
* @param integer $start
* @param integer $end
* @return array<\chat\data\message\Message>
*/
public static function getMessagesBetween(\chat\data\room\Room $room, $start, $end) {
$messageList = new static();
$messageList->sqlOrderBy = "message.messageID ASC";
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
}
$messageList->getConditionBuilder()->add('message.time BETWEEN ? AND ?', array($start, $end));
$messageList->readObjects();
return $messageList->getObjects();
}
}