mirror of
https://github.com/wbbaddons/Tims-Chat.git
synced 2025-01-22 02:00:40 +00:00
Adapt to cache system changes
This commit is contained in:
parent
98281b502b
commit
1bb655d08c
@ -1,7 +1,6 @@
|
||||
<?php
|
||||
namespace chat\data\room;
|
||||
use \chat\data\suspension\Suspension;
|
||||
use \wcf\system\cache\CacheHandler;
|
||||
use \wcf\system\WCF;
|
||||
|
||||
/**
|
||||
@ -24,13 +23,6 @@ class Room extends \chat\data\CHATDatabaseObject implements \wcf\system\request\
|
||||
*/
|
||||
protected static $databaseTableIndexName = 'roomID';
|
||||
|
||||
/**
|
||||
* Caches rooms.
|
||||
*
|
||||
* @var array<wcf\data\chat\room\ChatRoom>
|
||||
*/
|
||||
protected static $cache = null;
|
||||
|
||||
/**
|
||||
* @see \wcf\data\chat\room\ChatRoom::getTitle();
|
||||
*/
|
||||
@ -121,16 +113,7 @@ class Room extends \chat\data\CHATDatabaseObject implements \wcf\system\request\
|
||||
* Loads the room cache.
|
||||
*/
|
||||
public static function getCache() {
|
||||
if (self::$cache === null) {
|
||||
CacheHandler::getInstance()->addResource(
|
||||
'chatRooms',
|
||||
CHAT_DIR.'cache/cache.rooms.php',
|
||||
'\chat\system\cache\builder\RoomCacheBuilder'
|
||||
);
|
||||
self::$cache = CacheHandler::getInstance()->get('chatRooms');
|
||||
}
|
||||
|
||||
return self::$cache;
|
||||
return \chat\system\cache\builder\RoomCacheBuilder::getInstance()->getData();
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -59,6 +59,7 @@ class RoomEditor extends \wcf\data\DatabaseObjectEditor implements \wcf\data\IEd
|
||||
* Clears the room cache.
|
||||
*/
|
||||
public static function resetCache() {
|
||||
\wcf\system\cache\CacheHandler::getInstance()->clear(CHAT_DIR.'cache', 'cache.rooms.php');
|
||||
\chat\system\cache\builder\RoomCacheBuilder::getInstance()->reset();
|
||||
\chat\system\cache\builder\PermissionCacheBuilder::getInstance()->reset();
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,6 @@
|
||||
<?php
|
||||
namespace chat\page;
|
||||
use \chat\data;
|
||||
use \wcf\system\cache\CacheHandler;
|
||||
use \wcf\system\WCF;
|
||||
|
||||
/**
|
||||
|
@ -1,7 +1,6 @@
|
||||
<?php
|
||||
namespace chat\page;
|
||||
use \chat\data;
|
||||
use \wcf\system\cache\CacheHandler;
|
||||
use \wcf\system\exception\IllegalLinkException;
|
||||
use \wcf\system\WCF;
|
||||
|
||||
|
@ -11,20 +11,18 @@ use wcf\system\WCF;
|
||||
* @package be.bastelstu.chat
|
||||
* @subpackage system.cache.builder
|
||||
*/
|
||||
class PermissionCacheBuilder implements \wcf\system\cache\builder\ICacheBuilder {
|
||||
class PermissionCacheBuilder implements \wcf\system\cache\builder\AbstractCacheBuilder {
|
||||
/**
|
||||
* @see wcf\system\cache\ICacheBuilder::getData()
|
||||
* @see wcf\system\cache\AbstractCacheBuilder::rebuild()
|
||||
*/
|
||||
public function getData(array $cacheResource) {
|
||||
public function rebuild(array $parameters) {
|
||||
$data = array();
|
||||
list(, $groupIDsStr) = explode('-', $cacheResource['cache']);
|
||||
$groupIDs = explode(',', $groupIDsStr);
|
||||
|
||||
if (count($groupIDs)) {
|
||||
if (!empty($parameters)) {
|
||||
$conditionBuilder = new \wcf\system\database\util\PreparedStatementConditionBuilder();
|
||||
$conditionBuilder->add('acl_option.objectTypeID = ?', array(\wcf\system\acl\ACLHandler::getInstance()->getObjectTypeID('be.bastelstu.chat.room')));
|
||||
$conditionBuilder->add('option_to_group.optionID = acl_option.optionID');
|
||||
$conditionBuilder->add('option_to_group.groupID IN (?)', array($groupIDs));
|
||||
$conditionBuilder->add('option_to_group.groupID IN (?)', array($parameters));
|
||||
$sql = "SELECT option_to_group.groupID, option_to_group.objectID AS roomID, option_to_group.optionValue,
|
||||
acl_option.optionName AS permission
|
||||
FROM wcf".WCF_N."_acl_option acl_option,
|
||||
|
@ -10,11 +10,11 @@ namespace chat\system\cache\builder;
|
||||
* @package be.bastelstu.chat
|
||||
* @subpackage system.cache.builder
|
||||
*/
|
||||
class RoomCacheBuilder implements \wcf\system\cache\builder\ICacheBuilder {
|
||||
class RoomCacheBuilder implements \wcf\system\cache\builder\AbstractCacheBuilder {
|
||||
/**
|
||||
* @see \wcf\system\cache\ICacheBuilder::getData()
|
||||
* @see \wcf\system\cache\AbstractCacheBuilder::rebuild()
|
||||
*/
|
||||
public function getData(array $cacheResource) {
|
||||
public function rebuild(array $parameters) {
|
||||
// get all chat rooms
|
||||
$roomList = new \chat\data\room\RoomList();
|
||||
$roomList->sqlOrderBy = "room.position";
|
||||
|
@ -1,7 +1,6 @@
|
||||
<?php
|
||||
namespace chat\system\permission;
|
||||
use \wcf\system\acl\ACLHandler;
|
||||
use \wcf\system\cache\CacheHandler;
|
||||
use \wcf\system\package\PackageDependencyHandler;
|
||||
use \wcf\system\WCF;
|
||||
|
||||
@ -35,10 +34,7 @@ class PermissionHandler {
|
||||
$ush = \wcf\system\user\storage\UserStorageHandler::getInstance();
|
||||
|
||||
// get groups permissions
|
||||
$groups = implode(',', $user->getGroupIDs());
|
||||
$groupsFileName = \wcf\util\StringUtil::getHash(implode('-', $user->getGroupIDs()));
|
||||
CacheHandler::getInstance()->addResource('permission-'.$groups, WCF_DIR.'cache/cache.permission-'.$groupsFileName.'.php', '\chat\system\cache\builder\PermissionCacheBuilder');
|
||||
$this->chatPermissions = CacheHandler::getInstance()->get('permission-'.$groups);
|
||||
$this->chatPermissions = \chat\system\cache\builder\PermissionCacheBuilder::getInstance()->getData($user->getGroupIDs);
|
||||
|
||||
// get user permissions
|
||||
if ($user->userID) {
|
||||
@ -106,6 +102,6 @@ class PermissionHandler {
|
||||
$ush = \wcf\system\user\storage\UserStorageHandler::getInstance();
|
||||
|
||||
$ush->resetAll('chatUserPermissions', $packageID);
|
||||
\wcf\system\cache\CacheHandler::getInstance()->clear(WCF_DIR.'cache', 'cache.permission-[a-f0-9]{40}.php');
|
||||
\chat\system\cache\builder\PermissionCacheBuilder::getInstance()->reset();
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user