2011-12-04 22:46:50 +01:00
|
|
|
<?php
|
2013-01-19 20:36:40 +01:00
|
|
|
namespace chat\data\message;
|
2011-12-04 22:46:50 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Represents a list of chat messages.
|
|
|
|
*
|
|
|
|
* @author Tim Düsterhus
|
2014-02-27 23:05:09 +01:00
|
|
|
* @copyright 2010-2014 Tim Düsterhus
|
2011-12-04 22:46:50 +01:00
|
|
|
* @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
|
2011-12-04 22:46:50 +01:00
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
class MessageList extends \wcf\data\DatabaseObjectList {
|
2011-12-04 22:46:50 +01:00
|
|
|
/**
|
2012-02-26 17:55:44 +01:00
|
|
|
* @see \wcf\data\DatabaseObjectList::$className
|
2011-12-04 22:46:50 +01:00
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
public $className = 'chat\data\message\Message';
|
2011-12-04 22:46:50 +01:00
|
|
|
|
2011-12-26 16:31:37 +01:00
|
|
|
/**
|
|
|
|
* 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>
|
2011-12-26 16:31:37 +01:00
|
|
|
*/
|
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();
|
|
|
|
|
2011-12-04 22:46:50 +01:00
|
|
|
$messageList = new static();
|
2013-01-26 22:46:54 +01:00
|
|
|
$messageList->sqlOrderBy = "message.messageID DESC";
|
2011-12-04 22:46:50 +01:00
|
|
|
$messageList->sqlLimit = $number;
|
2013-05-15 22:11:47 +02:00
|
|
|
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
|
2014-08-03 00:41:28 +02:00
|
|
|
|
|
|
|
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
|
|
|
|
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
|
|
|
|
}
|
2011-12-26 16:31:37 +01:00
|
|
|
|
2011-12-04 22:46:50 +01:00
|
|
|
$messageList->readObjects();
|
|
|
|
return array_reverse($messageList->getObjects());
|
|
|
|
}
|
2011-12-26 16:31:37 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Reads the messages since the given message-id for the given room.
|
2014-08-03 00:41:28 +02:00
|
|
|
*
|
2013-01-19 20:36:40 +01:00
|
|
|
* @param \chat\data\room\Room $room
|
|
|
|
* @param integer $since
|
|
|
|
* @return array<\chat\data\message\Message>
|
2011-12-26 16:31:37 +01:00
|
|
|
*/
|
2013-01-19 20:36:40 +01:00
|
|
|
public static function getMessagesSince(\chat\data\room\Room $room, $since) {
|
2011-12-26 16:31:37 +01:00
|
|
|
$messageList = new static();
|
2013-01-26 22:46:54 +01:00
|
|
|
$messageList->sqlOrderBy = "message.messageID ASC";
|
|
|
|
$messageList->getConditionBuilder()->add('message.messageID > ?', array($since));
|
2014-08-03 00:41:28 +02:00
|
|
|
|
|
|
|
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)
|
|
|
|
);
|
|
|
|
}
|
2011-12-26 16:31:37 +01:00
|
|
|
|
|
|
|
$messageList->readObjects();
|
|
|
|
return $messageList->getObjects();
|
|
|
|
}
|
2013-07-30 00:19:02 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* 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());
|
2014-08-03 00:41:28 +02:00
|
|
|
|
|
|
|
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
|
|
|
|
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
|
|
|
|
}
|
|
|
|
|
2013-07-30 00:19:02 +02:00
|
|
|
$messageList->getConditionBuilder()->add('message.time BETWEEN ? AND ?', array($start, $end));
|
|
|
|
|
|
|
|
$messageList->readObjects();
|
|
|
|
return $messageList->getObjects();
|
|
|
|
}
|
2011-12-04 22:46:50 +01:00
|
|
|
}
|