mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2025-01-02 23:20:08 +00:00
Implement a “pseudo global” room
The „global“ room can be activated on a user group basis. This allows for bots processing messages from all rooms and responding to them.
This commit is contained in:
parent
d22c209e8d
commit
c2fe53fdb0
@ -54,6 +54,11 @@ public function validateSend() {
|
|||||||
$this->parameters['userData']['away'] = WCF::getUser()->chatAway;
|
$this->parameters['userData']['away'] = WCF::getUser()->chatAway;
|
||||||
|
|
||||||
// read and validate room
|
// read and validate room
|
||||||
|
$this->readInteger('roomID', true);
|
||||||
|
if (\wcf\system\WCF::getSession()->getPermission('admin.chat.isInAllRooms') && $this->parameters['roomID'] !== 0) {
|
||||||
|
$this->parameters['userData']['roomID'] = $this->parameters['roomID'];
|
||||||
|
}
|
||||||
|
|
||||||
$this->parameters['room'] = room\RoomCache::getInstance()->getRoom($this->parameters['userData']['roomID']);
|
$this->parameters['room'] = room\RoomCache::getInstance()->getRoom($this->parameters['userData']['roomID']);
|
||||||
if ($this->parameters['room'] === null) throw new \wcf\system\exception\IllegalLinkException();
|
if ($this->parameters['room'] === null) throw new \wcf\system\exception\IllegalLinkException();
|
||||||
if (!$this->parameters['room']->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
|
if (!$this->parameters['room']->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
|
||||||
|
@ -30,7 +30,10 @@ public static function getNewestMessages(\chat\data\room\Room $room, $number = C
|
|||||||
$messageList->sqlOrderBy = "message.messageID DESC";
|
$messageList->sqlOrderBy = "message.messageID DESC";
|
||||||
$messageList->sqlLimit = $number;
|
$messageList->sqlLimit = $number;
|
||||||
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
|
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
|
||||||
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
|
|
||||||
|
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
|
||||||
|
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
|
||||||
|
}
|
||||||
|
|
||||||
$messageList->readObjects();
|
$messageList->readObjects();
|
||||||
return array_reverse($messageList->getObjects());
|
return array_reverse($messageList->getObjects());
|
||||||
@ -38,7 +41,7 @@ public static function getNewestMessages(\chat\data\room\Room $room, $number = C
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Reads the messages since the given message-id for the given room.
|
* Reads the messages since the given message-id for the given room.
|
||||||
*
|
*
|
||||||
* @param \chat\data\room\Room $room
|
* @param \chat\data\room\Room $room
|
||||||
* @param integer $since
|
* @param integer $since
|
||||||
* @return array<\chat\data\message\Message>
|
* @return array<\chat\data\message\Message>
|
||||||
@ -47,15 +50,26 @@ public static function getMessagesSince(\chat\data\room\Room $room, $since) {
|
|||||||
$messageList = new static();
|
$messageList = new static();
|
||||||
$messageList->sqlOrderBy = "message.messageID ASC";
|
$messageList->sqlOrderBy = "message.messageID ASC";
|
||||||
$messageList->getConditionBuilder()->add('message.messageID > ?', array($since));
|
$messageList->getConditionBuilder()->add('message.messageID > ?', array($since));
|
||||||
$messageList->getConditionBuilder()->add('
|
|
||||||
((
|
if ($room->roomID !== \chat\data\room\Room::GLOBAL_ROOM) {
|
||||||
message.receiver IS NULL
|
$messageList->getConditionBuilder()->add('
|
||||||
AND message.roomID = ?
|
((
|
||||||
)
|
message.receiver IS NULL
|
||||||
OR message.receiver = ?
|
AND message.roomID = ?
|
||||||
OR message.sender = ?)',
|
)
|
||||||
array($room->roomID, \wcf\system\WCF::getUser()->userID, \wcf\system\WCF::getUser()->userID)
|
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();
|
$messageList->readObjects();
|
||||||
return $messageList->getObjects();
|
return $messageList->getObjects();
|
||||||
@ -73,7 +87,11 @@ public static function getMessagesBetween(\chat\data\room\Room $room, $start, $e
|
|||||||
$messageList = new static();
|
$messageList = new static();
|
||||||
$messageList->sqlOrderBy = "message.messageID ASC";
|
$messageList->sqlOrderBy = "message.messageID ASC";
|
||||||
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
|
$messageList->getConditionBuilder()->add('message.receiver IS NULL', array());
|
||||||
$messageList->getConditionBuilder()->add('message.roomID = ?', array($room->roomID));
|
|
||||||
|
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->getConditionBuilder()->add('message.time BETWEEN ? AND ?', array($start, $end));
|
||||||
|
|
||||||
$messageList->readObjects();
|
$messageList->readObjects();
|
||||||
|
@ -30,6 +30,11 @@ class Room extends \chat\data\CHATDatabaseObject implements \wcf\system\request\
|
|||||||
*/
|
*/
|
||||||
protected static $users = null;
|
protected static $users = null;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* room id of the “global” pseudo chat room
|
||||||
|
*/
|
||||||
|
const GLOBAL_ROOM = -1;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @see \wcf\data\chat\room\ChatRoom::getTitle();
|
* @see \wcf\data\chat\room\ChatRoom::getTitle();
|
||||||
*/
|
*/
|
||||||
@ -194,6 +199,13 @@ public function getUsers() {
|
|||||||
self::$users[$user->chatRoomID][$userID] = $user;
|
self::$users[$user->chatRoomID][$userID] = $user;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($this->roomID === self::GLOBAL_ROOM) {
|
||||||
|
return array_reduce(self::$users, function($a, $b) {
|
||||||
|
return $a + $b;
|
||||||
|
}, array());
|
||||||
|
}
|
||||||
|
|
||||||
if (!isset(self::$users[$this->roomID])) self::$users[$this->roomID] = array();
|
if (!isset(self::$users[$this->roomID])) self::$users[$this->roomID] = array();
|
||||||
|
|
||||||
return self::$users[$this->roomID];
|
return self::$users[$this->roomID];
|
||||||
|
@ -94,7 +94,13 @@ public function readMessages() {
|
|||||||
* Initializes the room databaseobject.
|
* Initializes the room databaseobject.
|
||||||
*/
|
*/
|
||||||
public function readRoom() {
|
public function readRoom() {
|
||||||
$this->room = \chat\data\room\RoomCache::getInstance()->getRoom(WCF::getUser()->chatRoomID);
|
if (\wcf\system\WCF::getSession()->getPermission('admin.chat.isInAllRooms')) {
|
||||||
|
$this->room = new \chat\data\room\Room(null, array('roomID' => \chat\data\room\Room::GLOBAL_ROOM));
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$this->room = \chat\data\room\RoomCache::getInstance()->getRoom(WCF::getUser()->chatRoomID);
|
||||||
|
}
|
||||||
|
|
||||||
if (!$this->room) throw new IllegalLinkException();
|
if (!$this->room) throw new IllegalLinkException();
|
||||||
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
|
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
|
||||||
}
|
}
|
||||||
|
@ -85,6 +85,8 @@
|
|||||||
<item name="wcf.acp.group.option.admin.chat.canReadLog"><![CDATA[Kann Protokoll einsehen]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canReadLog"><![CDATA[Kann Protokoll einsehen]]></item>
|
||||||
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions"><![CDATA[Kann Sanktionen verwalten]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions"><![CDATA[Kann Sanktionen verwalten]]></item>
|
||||||
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions.description"><![CDATA[Impliziert „Kann bannen“, „Kann knebeln“, „Kann global bannen“, „Kann global knebeln“ und gegenbenenfalls weitere Rechte.]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions.description"><![CDATA[Impliziert „Kann bannen“, „Kann knebeln“, „Kann global bannen“, „Kann global knebeln“ und gegenbenenfalls weitere Rechte.]]></item>
|
||||||
|
<item name="wcf.acp.group.option.admin.chat.isInAllRooms"><![CDATA[Ist in allen Räumen]]></item>
|
||||||
|
<item name="wcf.acp.group.option.admin.chat.isInAllRooms.description"><![CDATA[Eine Aktivierung dieser Option bewirkt, dass Nachrichten aus allen Räumen an den Benutzer gesendet werden.<br /><strong>Achtung:</strong> Die Aktivierung dieser Option führt dazu, dass der Chat für Ihre Mitglieder unbenutzbar wird. Ziehen Sie das Aktivieren dieser Option nur für computergestützte Anwendungen (Bots) in Betracht!<!-- HC SVNT DRACONES -->]]></item>
|
||||||
</category>
|
</category>
|
||||||
|
|
||||||
<category name="wcf.acp.option">
|
<category name="wcf.acp.option">
|
||||||
|
@ -85,6 +85,8 @@
|
|||||||
<item name="wcf.acp.group.option.admin.chat.canReadLog"><![CDATA[Can see protocol]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canReadLog"><![CDATA[Can see protocol]]></item>
|
||||||
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions"><![CDATA[Can manage suspensions]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions"><![CDATA[Can manage suspensions]]></item>
|
||||||
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions.description"><![CDATA[Implies “Can ban”, “Can mute”, “Can ban globally”, “Can mute globally” und possibly other permissions.]]></item>
|
<item name="wcf.acp.group.option.admin.chat.canManageSuspensions.description"><![CDATA[Implies “Can ban”, “Can mute”, “Can ban globally”, “Can mute globally” und possibly other permissions.]]></item>
|
||||||
|
<item name="wcf.acp.group.option.admin.chat.isInAllRooms"><![CDATA[Is in all rooms]]></item>
|
||||||
|
<item name="wcf.acp.group.option.admin.chat.isInAllRooms.description"><![CDATA[Enabling this option will send messages from all rooms to the client.<br /><strong>Warning:</strong> Enabling this option might render the chat useless for your members! Only activate it for bots accessing the chat.<!-- HC SVNT DRACONES -->]]></item>
|
||||||
</category>
|
</category>
|
||||||
|
|
||||||
<category name="wcf.acp.option">
|
<category name="wcf.acp.option">
|
||||||
|
@ -157,6 +157,13 @@ pdf]]></defaultvalue>
|
|||||||
<admindefaultvalue>1</admindefaultvalue>
|
<admindefaultvalue>1</admindefaultvalue>
|
||||||
<usersonly>1</usersonly>
|
<usersonly>1</usersonly>
|
||||||
</option>
|
</option>
|
||||||
|
<option name="admin.chat.isInAllRooms">
|
||||||
|
<categoryname>admin.chat</categoryname>
|
||||||
|
<optiontype>boolean</optiontype>
|
||||||
|
<defaultvalue>0</defaultvalue>
|
||||||
|
<admindefaultvalue>0</admindefaultvalue>
|
||||||
|
<usersonly>1</usersonly>
|
||||||
|
</option>
|
||||||
</options>
|
</options>
|
||||||
</import>
|
</import>
|
||||||
</data>
|
</data>
|
||||||
|
Loading…
Reference in New Issue
Block a user