1
0
mirror of https://github.com/wbbaddons/Tims-Chat.git synced 2025-01-22 02:00:40 +00:00

Fixing Chat*(Page|Form|Action)

This commit is contained in:
Tim Düsterhus 2012-09-07 22:37:25 +02:00
parent ec0154e3a4
commit f777bc1d2e
5 changed files with 21 additions and 19 deletions

View File

@ -67,8 +67,9 @@ class ChatLeaveAction extends AbstractAction {
$this->userData['roomID'] = \wcf\util\ChatUtil::readUserData('roomID');
$this->room = chat\room\ChatRoom::getCache()->search($this->userData['roomID']);
if (!$this->room) throw new \wcf\system\exception\IllegalLinkException();
$cache = chat\room\ChatRoom::getCache();
if (!isset($cache[$this->userData['roomID']])) throw new \wcf\system\exception\IllegalLinkException();
$this->room = $cache[$this->userData['roomID']];
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
if (CHAT_DISPLAY_JOIN_LEAVE) {

View File

@ -95,8 +95,10 @@ class ChatForm extends AbstractForm {
$this->userData['roomID'] = \wcf\util\ChatUtil::readUserData('roomID');
$this->userData['away'] = \wcf\util\ChatUtil::readUserData('away');
$this->room = chat\room\ChatRoom::getCache()->search($this->userData['roomID']);
if (!$this->room) throw new \wcf\system\exception\IllegalLinkException();
$cache = chat\room\ChatRoom::getCache();
if (!isset($cache[$this->userData['roomID']])) throw new \wcf\system\exception\IllegalLinkException();
$this->room = $cache[$this->userData['roomID']];
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
if (!$this->room->canWrite()) throw new \wcf\system\exception\PermissionDeniedException();
parent::readData();

View File

@ -133,9 +133,10 @@ class ChatMessagePage extends AbstractPage {
*/
public function readRoom() {
$roomID = \wcf\util\ChatUtil::readUserData('roomID');
$cache = chat\room\ChatRoom::getCache();
if (!isset($cache[$roomID])) throw new \wcf\system\exception\IllegalLinkException();
$this->room = chat\room\ChatRoom::getCache()->search($roomID);
if (!$this->room) throw new \wcf\system\exception\IllegalLinkException();
$this->room = $cache[$roomID];
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
}

View File

@ -213,22 +213,20 @@ class ChatPage extends AbstractPage {
if ($this->roomID === 0) {
// no room given
try {
// redirect to first chat-room
$this->rooms->seek(0);
\wcf\util\HeaderUtil::redirect(\wcf\system\request\LinkHandler::getInstance()->getLink('Chat', array(
'object' => $this->rooms->current()
)));
exit;
}
catch (\OutOfBoundsException $e) {
$room = reset($this->rooms);
if ($room === null) {
// no valid room found
throw new \wcf\system\exception\IllegalLinkException();
}
// redirect to first chat-room
\wcf\util\HeaderUtil::redirect(\wcf\system\request\LinkHandler::getInstance()->getLink('Chat', array(
'object' => $room
)));
exit;
}
$this->room = $this->rooms->search($this->roomID);
if (!$this->room) throw new \wcf\system\exception\IllegalLinkException();
if (!isset($this->rooms[$this->roomID])) throw new \wcf\system\exception\IllegalLinkException();
$this->room = $this->rooms[$this->roomID];
if (!$this->room->canEnter()) throw new \wcf\system\exception\PermissionDeniedException();
}

View File

@ -62,8 +62,8 @@ class ChatRefreshRoomListPage extends AbstractPage {
$this->rooms = chat\room\ChatRoom::getCache();
$roomID = \wcf\util\ChatUtil::readUserData('roomID');
$this->room = $this->rooms->search($roomID);
if (!$this->room) throw new \wcf\system\exception\IllegalLinkException();
if (!isset($this->rooms[$roomID])) throw new \wcf\system\exception\IllegalLinkException();
$this->room = $this->rooms[$roomID];
}
/**