Zeile 20 | Zeile 20 |
---|
/** * The current cache handler we're using *
|
/** * The current cache handler we're using *
|
* @var object
| * @var CacheHandlerInterface
|
*/ public $handler = null;
|
*/ public $handler = null;
|
/** * Whether or not to exit the script if we cannot load the specified extension * * @var boolean */ var $silent = false;
| |
/** * A count of the number of calls.
| /** * A count of the number of calls.
|
Zeile 58 | Zeile 51 |
---|
* @var string */ public $cache_debug;
|
* @var string */ public $cache_debug;
|
/**
| /** * @var array */ public $moderators;
/** * @var array */ public $built_moderators;
/** * @var array */ public $moderators_forum_cache;
/**
|
* Build cache data. * */ function cache() { global $db, $mybb;
|
* Build cache data. * */ function cache() { global $db, $mybb;
|
| require_once MYBB_ROOT."/inc/cachehandlers/interface.php";
|
switch($mybb->config['cache_store']) { // Disk cache case "files": require_once MYBB_ROOT."/inc/cachehandlers/disk.php";
|
switch($mybb->config['cache_store']) { // Disk cache case "files": require_once MYBB_ROOT."/inc/cachehandlers/disk.php";
|
$this->handler = new diskCacheHandler($this->silent);
| $this->handler = new diskCacheHandler();
|
break; // Memcache cache case "memcache": require_once MYBB_ROOT."/inc/cachehandlers/memcache.php";
|
break; // Memcache cache case "memcache": require_once MYBB_ROOT."/inc/cachehandlers/memcache.php";
|
$this->handler = new memcacheCacheHandler($this->silent);
| $this->handler = new memcacheCacheHandler();
|
break; // Memcached cache case "memcached": require_once MYBB_ROOT."/inc/cachehandlers/memcached.php";
|
break; // Memcached cache case "memcached": require_once MYBB_ROOT."/inc/cachehandlers/memcached.php";
|
$this->handler = new memcachedCacheHandler($this->silent);
| $this->handler = new memcachedCacheHandler();
|
break; // eAccelerator cache case "eaccelerator": require_once MYBB_ROOT."/inc/cachehandlers/eaccelerator.php";
|
break; // eAccelerator cache case "eaccelerator": require_once MYBB_ROOT."/inc/cachehandlers/eaccelerator.php";
|
$this->handler = new eacceleratorCacheHandler($this->silent);
| $this->handler = new eacceleratorCacheHandler();
|
break; // Xcache cache case "xcache": require_once MYBB_ROOT."/inc/cachehandlers/xcache.php";
|
break; // Xcache cache case "xcache": require_once MYBB_ROOT."/inc/cachehandlers/xcache.php";
|
$this->handler = new xcacheCacheHandler($this->silent);
| $this->handler = new xcacheCacheHandler();
|
break; // APC cache case "apc": require_once MYBB_ROOT."/inc/cachehandlers/apc.php";
|
break; // APC cache case "apc": require_once MYBB_ROOT."/inc/cachehandlers/apc.php";
|
$this->handler = new apcCacheHandler($this->silent);
| $this->handler = new apcCacheHandler(); break; // APCu cache case "apcu": require_once MYBB_ROOT."/inc/cachehandlers/apcu.php"; $this->handler = new apcuCacheHandler(); break; // Redis cache case "redis": require_once MYBB_ROOT."/inc/cachehandlers/redis.php"; $this->handler = new redisCacheHandler();
|
break; }
|
break; }
|
if(is_object($this->handler))
| if($this->handler instanceof CacheHandlerInterface)
|
{
|
{
|
if(method_exists($this->handler, "connect"))
| if(!$this->handler->connect())
|
{
|
{
|
if(!$this->handler->connect()) { $this->handler = null; }
| $this->handler = null;
|
} } else
| } } else
|
Zeile 117 | Zeile 134 |
---|
$query = $db->simple_select("datacache", "title,cache"); while($data = $db->fetch_array($query)) {
|
$query = $db->simple_select("datacache", "title,cache"); while($data = $db->fetch_array($query)) {
|
$this->cache[$data['title']] = unserialize($data['cache']);
| // use native_unserialize() over my_unserialize() for performance reasons $this->cache[$data['title']] = native_unserialize($data['cache']);
|
} } }
| } } }
|
Zeile 125 | Zeile 143 |
---|
/** * Read cache from files or db. *
|
/** * Read cache from files or db. *
|
* @param string The cache component to read. * @param boolean If true, cannot be overwritten during script execution. * @return unknown
| * @param string $name The cache component to read. * @param boolean $hard If true, cannot be overwritten during script execution. * @return mixed
|
*/ function read($name, $hard=false) {
| */ function read($name, $hard=false) {
|
Zeile 137 | Zeile 155 |
---|
if(isset($this->cache[$name]) && $hard == false) { return $this->cache[$name];
|
if(isset($this->cache[$name]) && $hard == false) { return $this->cache[$name];
|
}
| }
|
// If we're not hard refreshing, and this cache doesn't exist, return false // It would have been loaded pre-global if it did exist anyway...
|
// If we're not hard refreshing, and this cache doesn't exist, return false // It would have been loaded pre-global if it did exist anyway...
|
else if($hard == false && !is_object($this->handler))
| else if($hard == false && !($this->handler instanceof CacheHandlerInterface))
|
{ return false; }
|
{ return false; }
|
if(is_object($this->handler))
| if($this->handler instanceof CacheHandlerInterface)
|
{ get_execution_time();
| { get_execution_time();
|
Zeile 171 | Zeile 189 |
---|
// Fetch from database $query = $db->simple_select("datacache", "title,cache", "title='".$db->escape_string($name)."'"); $cache_data = $db->fetch_array($query);
|
// Fetch from database $query = $db->simple_select("datacache", "title,cache", "title='".$db->escape_string($name)."'"); $cache_data = $db->fetch_array($query);
|
$data = unserialize($cache_data['cache']);
| // use native_unserialize() over my_unserialize() for performance reasons $data = native_unserialize($cache_data['cache']);
|
// Update cache for handler get_execution_time();
| // Update cache for handler get_execution_time();
|
Zeile 194 | Zeile 214 |
---|
$query = $db->simple_select("datacache", "title,cache", "title='$name'"); $cache_data = $db->fetch_array($query);
|
$query = $db->simple_select("datacache", "title,cache", "title='$name'"); $cache_data = $db->fetch_array($query);
|
if(!$cache_data['title'])
| if(empty($cache_data['title']))
|
{ $data = false; } else {
|
{ $data = false; } else {
|
$data = unserialize($cache_data['cache']);
| // use native_unserialize() over my_unserialize() for performance reasons $data = native_unserialize($cache_data['cache']);
|
} }
| } }
|
Zeile 220 | Zeile 241 |
---|
/** * Update cache contents. *
|
/** * Update cache contents. *
|
* @param string The cache content identifier. * @param string The cache content.
| * @param string $name The cache content identifier. * @param mixed $contents The cache content.
|
*/ function update($name, $contents) {
| */ function update($name, $contents) {
|
Zeile 230 | Zeile 251 |
---|
$this->cache[$name] = $contents;
// We ALWAYS keep a running copy in the db just incase we need it
|
$this->cache[$name] = $contents;
// We ALWAYS keep a running copy in the db just incase we need it
|
$dbcontents = $db->escape_string(serialize($contents));
| $dbcontents = $db->escape_string(my_serialize($contents));
|
$replace_array = array( "title" => $db->escape_string($name),
| $replace_array = array( "title" => $db->escape_string($name),
|
Zeile 239 | Zeile 260 |
---|
$db->replace_query("datacache", $replace_array, "", false);
// Do we have a cache handler we're using?
|
$db->replace_query("datacache", $replace_array, "", false);
// Do we have a cache handler we're using?
|
if(is_object($this->handler))
| if($this->handler instanceof CacheHandlerInterface)
|
{ get_execution_time();
| { get_execution_time();
|
Zeile 261 | Zeile 282 |
---|
* Originally from frostschutz's PluginLibrary * github.com/frostschutz *
|
* Originally from frostschutz's PluginLibrary * github.com/frostschutz *
|
* @param string Cache name or title * @param boolean To delete a cache starting with name_
| * @param string $name Cache name or title * @param boolean $greedy To delete a cache starting with name_
|
*/ function delete($name, $greedy = false) {
|
*/ function delete($name, $greedy = false) {
|
global $db, $mybb, $cache;
| global $db, $mybb, $cache;
|
// Prepare for database query. $dbname = $db->escape_string($name); $where = "title = '{$dbname}'";
// Delete on-demand or handler cache
|
// Prepare for database query. $dbname = $db->escape_string($name); $where = "title = '{$dbname}'";
// Delete on-demand or handler cache
|
if($this->handler)
| if($this->handler instanceof CacheHandlerInterface)
|
{ get_execution_time();
| { get_execution_time();
|
Zeile 314 | Zeile 335 |
---|
$where .= " OR title LIKE '{$ldbname}=_%' ESCAPE '='";
|
$where .= " OR title LIKE '{$ldbname}=_%' ESCAPE '='";
|
if($this->handler)
| if($this->handler instanceof CacheHandlerInterface)
|
{ $query = $db->simple_select("datacache", "title", $where);
| { $query = $db->simple_select("datacache", "title", $where);
|
Zeile 347 | Zeile 368 |
---|
if($mybb->debug_mode) { $this->debug_call('delete:'.$name, $call_time, $hit);
|
if($mybb->debug_mode) { $this->debug_call('delete:'.$name, $call_time, $hit);
|
} }
| } }
|
} }
| } }
|
Zeile 359 | Zeile 380 |
---|
/** * Debug a cache call to a non-database cache handler *
|
/** * Debug a cache call to a non-database cache handler *
|
* @param string The cache key * @param string The time it took to perform the call. * @param boolean Hit or miss status
| * @param string $string The cache key * @param string $qtime The time it took to perform the call. * @param boolean $hit Hit or miss status
|
*/ function debug_call($string, $qtime, $hit) {
| */ function debug_call($string, $qtime, $hit) {
|
Zeile 385 | Zeile 406 |
---|
$cache_data = explode(':', $string); $cache_method = $cache_data[0]; $cache_key = $cache_data[1];
|
$cache_data = explode(':', $string); $cache_method = $cache_data[0]; $cache_key = $cache_data[1];
|
$this->cache_debug .= "<table style=\"background-color: #666;\" width=\"95%\" cellpadding=\"4\" cellspacing=\"1\" align=\"center\">\n". "<tr>\n". "<td style=\"background-color: #ccc;\">{$debug_extra}<div><strong>#".$this->call_count." - ".ucfirst($cache_method)." Call</strong></div></td>\n". "</tr>\n". "<tr style=\"background-color: #fefefe;\">\n". "<td><span style=\"font-family: Courier; font-size: 14px;\">(".$mybb->config['cache_store'].") [".$hit_status."] ".htmlspecialchars_uni($cache_key)."</span></td>\n". "</tr>\n". "<tr>\n". "<td bgcolor=\"#ffffff\">Call Time: ".format_time_duration($qtime)."</td>\n". "</tr>\n". "</table>\n". "<br />\n";
| $this->cache_debug = "<table style=\"background-color: #666;\" width=\"95%\" cellpadding=\"4\" cellspacing=\"1\" align=\"center\"> <tr> <td style=\"background-color: #ccc;\">{$debug_extra}<div><strong>#{$this->call_count} - ".ucfirst($cache_method)." Call</strong></div></td> </tr> <tr style=\"background-color: #fefefe;\"> <td><span style=\"font-family: Courier; font-size: 14px;\">({$mybb->config['cache_store']}) [{$hit_status}] ".htmlspecialchars_uni($cache_key)."</span></td> </tr> <tr> <td bgcolor=\"#ffffff\">Call Time: ".format_time_duration($qtime)."</td> </tr> </table> <br />\n";
|
$this->calllist[$this->call_count]['key'] = $string; $this->calllist[$this->call_count]['time'] = $qtime; }
|
$this->calllist[$this->call_count]['key'] = $string; $this->calllist[$this->call_count]['time'] = $qtime; }
|
|
|
/** * Select the size of the cache *
|
/** * Select the size of the cache *
|
* @param string The name of the cache
| * @param string $name The name of the cache
|
* @return integer the size of the cache */ function size_of($name='') { global $db;
|
* @return integer the size of the cache */ function size_of($name='') { global $db;
|
if(is_object($this->handler))
| if($this->handler instanceof CacheHandlerInterface)
|
{ $size = $this->handler->size_of($name); if(!$size)
|
{ $size = $this->handler->size_of($name); if(!$size)
|
{
| {
|
if($name)
|
if($name)
|
{
| {
|
$query = $db->simple_select("datacache", "cache", "title='{$name}'"); return strlen($db->fetch_field($query, "cache")); }
| $query = $db->simple_select("datacache", "cache", "title='{$name}'"); return strlen($db->fetch_field($query, "cache")); }
|
Zeile 435 | Zeile 456 |
---|
} // Using MySQL as cache else
|
} // Using MySQL as cache else
|
{
| {
|
if($name)
|
if($name)
|
{
| {
|
$query = $db->simple_select("datacache", "cache", "title='{$name}'"); return strlen($db->fetch_field($query, "cache")); }
| $query = $db->simple_select("datacache", "cache", "title='{$name}'"); return strlen($db->fetch_field($query, "cache")); }
|
Zeile 453 | Zeile 474 |
---|
* */ function update_version()
|
* */ function update_version()
|
{
| {
|
global $mybb;
$version = array( "version" => $mybb->version, "version_code" => $mybb->version_code );
|
global $mybb;
$version = array( "version" => $mybb->version, "version_code" => $mybb->version_code );
|
|
|
$this->update("version", $version); }
| $this->update("version", $version); }
|
Zeile 469 | Zeile 490 |
---|
* */ function update_attachtypes()
|
* */ function update_attachtypes()
|
{ global $db;
| { global $db;
|
$types = array();
|
$types = array();
|
$query = $db->simple_select("attachtypes", "*");
| $query = $db->simple_select('attachtypes', '*', 'enabled=1');
|
while($type = $db->fetch_array($query)) { $type['extension'] = my_strtolower($type['extension']);
| while($type = $db->fetch_array($query)) { $type['extension'] = my_strtolower($type['extension']);
|
Zeile 489 | Zeile 510 |
---|
* */ function update_smilies()
|
* */ function update_smilies()
|
{ global $db;
| { global $db;
|
$smilies = array();
|
$smilies = array();
|
|
|
$query = $db->simple_select("smilies", "*", "", array('order_by' => 'disporder', 'order_dir' => 'ASC')); while($smilie = $db->fetch_array($query)) { $smilies[$smilie['sid']] = $smilie; }
|
$query = $db->simple_select("smilies", "*", "", array('order_by' => 'disporder', 'order_dir' => 'ASC')); while($smilie = $db->fetch_array($query)) { $smilies[$smilie['sid']] = $smilie; }
|
|
|
$this->update("smilies", $smilies); }
| $this->update("smilies", $smilies); }
|
Zeile 508 | Zeile 529 |
---|
* */ function update_posticons()
|
* */ function update_posticons()
|
{ global $db;
$icons = array();
| { global $db;
$icons = array();
|
$query = $db->simple_select("icons", "iid, name, path"); while($icon = $db->fetch_array($query)) {
| $query = $db->simple_select("icons", "iid, name, path"); while($icon = $db->fetch_array($query)) {
|
Zeile 527 | Zeile 548 |
---|
* */ function update_badwords()
|
* */ function update_badwords()
|
{ global $db;
$badwords = array();
| { global $db;
$badwords = array();
|
$query = $db->simple_select("badwords", "*"); while($badword = $db->fetch_array($query)) {
| $query = $db->simple_select("badwords", "*"); while($badword = $db->fetch_array($query)) {
|
Zeile 546 | Zeile 567 |
---|
* */ function update_usergroups()
|
* */ function update_usergroups()
|
{ global $db;
$query = $db->simple_select("usergroups");
| { global $db;
$query = $db->simple_select("usergroups");
|
$gs = array(); while($g = $db->fetch_array($query)) { $gs[$g['gid']] = $g; }
|
$gs = array(); while($g = $db->fetch_array($query)) { $gs[$g['gid']] = $g; }
|
|
|
$this->update("usergroups", $gs); }
/** * Update the forum permissions cache. *
|
$this->update("usergroups", $gs); }
/** * Update the forum permissions cache. *
|
* @return false When failed, returns false.
| * @return bool When failed, returns false.
|
*/ function update_forumpermissions() { global $forum_cache, $db;
|
*/ function update_forumpermissions() { global $forum_cache, $db;
|
$this->built_forum_permissions = array(0);
| $this->forum_permissions = $this->built_forum_permissions = array(0);
|
// Get our forum list cache_forums(true); if(!is_array($forum_cache))
| // Get our forum list cache_forums(true); if(!is_array($forum_cache))
|
Zeile 603 | Zeile 624 |
---|
$this->build_forum_permissions(); $this->update("forumpermissions", $this->built_forum_permissions);
|
$this->build_forum_permissions(); $this->update("forumpermissions", $this->built_forum_permissions);
|
| return true;
|
}
/** * Build the forum permissions array * * @access private
|
}
/** * Build the forum permissions array * * @access private
|
* @param array An optional permissions array. * @param int An optional permission id.
| * @param array $permissions An optional permissions array. * @param int $pid An optional permission id.
|
*/ private function build_forum_permissions($permissions=array(), $pid=0) { $usergroups = array_keys($this->read("usergroups", true));
|
*/ private function build_forum_permissions($permissions=array(), $pid=0) { $usergroups = array_keys($this->read("usergroups", true));
|
if($this->forum_permissions_forum_cache[$pid])
| if(!empty($this->forum_permissions_forum_cache[$pid]))
|
{ foreach($this->forum_permissions_forum_cache[$pid] as $main) {
| { foreach($this->forum_permissions_forum_cache[$pid] as $main) {
|
Zeile 624 | Zeile 647 |
---|
$perms = $permissions; foreach($usergroups as $gid) {
|
$perms = $permissions; foreach($usergroups as $gid) {
|
if($this->forum_permissions[$forum['fid']][$gid])
| if(isset($this->forum_permissions[$forum['fid']][$gid]) && $this->forum_permissions[$forum['fid']][$gid])
|
{ $perms[$gid] = $this->forum_permissions[$forum['fid']][$gid]; }
|
{ $perms[$gid] = $this->forum_permissions[$forum['fid']][$gid]; }
|
if($perms[$gid])
| if(!empty($perms[$gid]))
|
{ $perms[$gid]['fid'] = $forum['fid']; $this->built_forum_permissions[$forum['fid']][$gid] = $perms[$gid];
| { $perms[$gid]['fid'] = $forum['fid']; $this->built_forum_permissions[$forum['fid']][$gid] = $perms[$gid];
|
Zeile 645 | Zeile 668 |
---|
* */ function update_stats()
|
* */ function update_stats()
|
{ global $db;
| {
|
require_once MYBB_ROOT."inc/functions_rebuild.php"; rebuild_stats(); }
|
require_once MYBB_ROOT."inc/functions_rebuild.php"; rebuild_stats(); }
|
|
|
/** * Update the statistics cache *
| /** * Update the statistics cache *
|
Zeile 659 | Zeile 680 |
---|
function update_statistics() { global $db;
|
function update_statistics() { global $db;
|
|
|
$query = $db->simple_select('users', 'uid, username, referrals', 'referrals>0', array('order_by' => 'referrals', 'order_dir' => 'DESC', 'limit' => 1)); $topreferrer = $db->fetch_array($query);
$timesearch = TIME_NOW - 86400;
|
$query = $db->simple_select('users', 'uid, username, referrals', 'referrals>0', array('order_by' => 'referrals', 'order_dir' => 'DESC', 'limit' => 1)); $topreferrer = $db->fetch_array($query);
$timesearch = TIME_NOW - 86400;
|
switch($db->type) { case 'pgsql': $group_by = $db->build_fields_string('users', 'u.'); break; default: $group_by = 'p.uid'; break; }
| |
|
|
$query = $db->query(' SELECT u.uid, u.username, COUNT(pid) AS poststoday FROM '.TABLE_PREFIX.'posts p LEFT JOIN '.TABLE_PREFIX.'users u ON (p.uid=u.uid) WHERE p.dateline>'.$timesearch.' GROUP BY '.$group_by.' ORDER BY poststoday DESC LIMIT 1 '); $topposter = $db->fetch_array($query);
| $query = $db->query(" SELECT u.uid, u.username, COUNT(*) AS poststoday FROM {$db->table_prefix}posts p LEFT JOIN {$db->table_prefix}users u ON (p.uid=u.uid) WHERE p.dateline > {$timesearch} AND p.visible=1 GROUP BY u.uid, u.username ORDER BY poststoday DESC ");
$most_posts = 0; $topposter = array(); while($user = $db->fetch_array($query)) { if($user['poststoday'] > $most_posts) { $most_posts = $user['poststoday']; $topposter = $user; } }
|
$query = $db->simple_select('users', 'COUNT(uid) AS posters', 'postnum>0'); $posters = $db->fetch_field($query, 'posters');
| $query = $db->simple_select('users', 'COUNT(uid) AS posters', 'postnum>0'); $posters = $db->fetch_field($query, 'posters');
|
Zeile 691 | Zeile 713 |
---|
'time' => TIME_NOW, 'top_referrer' => (array)$topreferrer, 'top_poster' => (array)$topposter,
|
'time' => TIME_NOW, 'top_referrer' => (array)$topreferrer, 'top_poster' => (array)$topposter,
|
'posters' => $posters,
| 'posters' => $posters
|
);
$this->update('statistics', $statistics);
| );
$this->update('statistics', $statistics);
|
Zeile 699 | Zeile 721 |
---|
/** * Update the moderators cache.
|
/** * Update the moderators cache.
|
*
| * * @return bool Returns false on failure
|
*/ function update_moderators() {
| */ function update_moderators() {
|
Zeile 735 | Zeile 758 |
---|
// Fetch moderators from the database $query = $db->query(" SELECT m.*, u.username, u.usergroup, u.displaygroup
|
// Fetch moderators from the database $query = $db->query(" SELECT m.*, u.username, u.usergroup, u.displaygroup
|
FROM ".TABLE_PREFIX."moderators m
| FROM ".TABLE_PREFIX."moderators m
|
LEFT JOIN ".TABLE_PREFIX."users u ON (m.id=u.uid) WHERE m.isgroup = '0' ORDER BY u.username
| LEFT JOIN ".TABLE_PREFIX."users u ON (m.id=u.uid) WHERE m.isgroup = '0' ORDER BY u.username
|
Zeile 766 | Zeile 789 |
---|
$this->moderators[$moderator['fid']]['usergroups'][$moderator['id']] = $moderator; }
|
$this->moderators[$moderator['fid']]['usergroups'][$moderator['id']] = $moderator; }
|
if(is_array($this->moderators))
| foreach(array_keys($this->moderators) as $fid)
|
{
|
{
|
foreach(array_keys($this->moderators) as $fid)
| if(isset($this->moderators[$fid]['users']))
|
{
|
{
|
uasort($this->moderators[$fid], 'sort_moderators_by_usernames');
| uasort($this->moderators[$fid]['users'], 'sort_moderators_by_usernames');
|
} }
$this->build_moderators();
|
} }
$this->build_moderators();
|
|
|
$this->update("moderators", $this->built_moderators);
|
$this->update("moderators", $this->built_moderators);
|
}
| return true; }
|
/** * Update the users awaiting activation cache.
| /** * Update the users awaiting activation cache.
|
Zeile 792 | Zeile 817 |
---|
$data = array( 'users' => $awaitingusers,
|
$data = array( 'users' => $awaitingusers,
|
'time' => TIME_NOW,
| 'time' => TIME_NOW
|
);
|
);
|
|
|
$this->update('awaitingactivation', $data); }
| $this->update('awaitingactivation', $data); }
|
Zeile 802 | Zeile 827 |
---|
* Build the moderators array * * @access private
|
* Build the moderators array * * @access private
|
* @param array An optional moderators array (moderators of the parent forum for example). * @param int An optional parent ID.
| * @param array $moderators An optional moderators array (moderators of the parent forum for example). * @param int $pid An optional parent ID.
|
*/ private function build_moderators($moderators=array(), $pid=0) {
| */ private function build_moderators($moderators=array(), $pid=0) {
|
Zeile 813 | Zeile 838 |
---|
{ foreach($main as $forum) {
|
{ foreach($main as $forum) {
|
$forum_mods = '';
| $forum_mods = array();
|
if(count($moderators))
|
if(count($moderators))
|
{
| {
|
$forum_mods = $moderators;
|
$forum_mods = $moderators;
|
}
| }
|
// Append - local settings override that of a parent - array_merge works here if(isset($this->moderators[$forum['fid']])) {
| // Append - local settings override that of a parent - array_merge works here if(isset($this->moderators[$forum['fid']])) {
|
Zeile 832 | Zeile 857 |
---|
} $this->built_moderators[$forum['fid']] = $forum_mods; $this->build_moderators($forum_mods, $forum['fid']);
|
} $this->built_moderators[$forum['fid']] = $forum_mods; $this->build_moderators($forum_mods, $forum['fid']);
|
} }
| } }
|
} }
| } }
|
Zeile 864 | Zeile 889 |
---|
}
$this->update("forums", $forums);
|
}
$this->update("forums", $forums);
|
}
| }
|
/** * Update usertitles cache. *
| /** * Update usertitles cache. *
|
Zeile 882 | Zeile 907 |
---|
}
$this->update("usertitles", $usertitles);
|
}
$this->update("usertitles", $usertitles);
|
}
| }
|
/** * Update reported content cache.
| /** * Update reported content cache.
|
Zeile 890 | Zeile 915 |
---|
*/ function update_reportedcontent() {
|
*/ function update_reportedcontent() {
|
global $db, $mybb;
$reports = array(); $query = $db->simple_select("reportedcontent", "COUNT(rid) AS unreadcount", "reportstatus='0'"); $num = $db->fetch_array($query);
| global $db;
$query = $db->simple_select("reportedcontent", "COUNT(rid) AS unreadcount", "reportstatus='0'"); $unreadcount = $db->fetch_field($query, 'unreadcount');
|
$query = $db->simple_select("reportedcontent", "COUNT(rid) AS reportcount");
|
$query = $db->simple_select("reportedcontent", "COUNT(rid) AS reportcount");
|
$total = $db->fetch_array($query);
$query = $db->simple_select("reportedcontent", "dateline", "reportstatus='0'", array('order_by' => 'dateline', 'order_dir' => 'DESC')); $latest = $db->fetch_array($query);
$reasons = array();
if(!empty($mybb->settings['reportreasons'])) { $options = $mybb->settings['reportreasons']; $options = explode("\n", $options);
foreach($options as $option) { $option = explode("=", $option); $reasons[$option[0]] = $option[1]; } }
| $reportcount = $db->fetch_field($query, 'reportcount'); $query = $db->simple_select("reportedcontent", "dateline", "reportstatus='0'", array('order_by' => 'dateline', 'order_dir' => 'DESC', 'limit' => 1)); $dateline = $db->fetch_field($query, 'dateline');
|
$reports = array(
|
$reports = array(
|
"unread" => $num['unreadcount'], "total" => $total['reportcount'], "lastdateline" => $latest['dateline'], "reasons" => $reasons
| 'unread' => $unreadcount, 'total' => $reportcount, 'lastdateline' => $dateline,
|
);
$this->update("reportedcontent", $reports);
| );
$this->update("reportedcontent", $reports);
|
Zeile 939 | Zeile 948 |
---|
while($mycode = $db->fetch_array($query)) { $mycodes[] = $mycode;
|
while($mycode = $db->fetch_array($query)) { $mycodes[] = $mycode;
|
}
| }
|
$this->update("mycode", $mycodes); }
|
$this->update("mycode", $mycodes); }
|
|
|
/** * Update the mailqueue cache *
|
/** * Update the mailqueue cache *
|
| * @param int $last_run * @param int $lock_time
|
*/ function update_mailqueue($last_run=0, $lock_time=0) { global $db;
|
*/ function update_mailqueue($last_run=0, $lock_time=0) { global $db;
|
|
|
$query = $db->simple_select("mailqueue", "COUNT(*) AS queue_size"); $queue_size = $db->fetch_field($query, "queue_size");
$mailqueue = $this->read("mailqueue"); if(!is_array($mailqueue))
|
$query = $db->simple_select("mailqueue", "COUNT(*) AS queue_size"); $queue_size = $db->fetch_field($query, "queue_size");
$mailqueue = $this->read("mailqueue"); if(!is_array($mailqueue))
|
{
| {
|
$mailqueue = array();
|
$mailqueue = array();
|
}
| }
|
$mailqueue['queue_size'] = $queue_size; if($last_run > 0) {
| $mailqueue['queue_size'] = $queue_size; if($last_run > 0) {
|
Zeile 974 | Zeile 985 |
---|
* Update update_check cache (dummy function used by upgrade/install scripts) */ function update_update_check()
|
* Update update_check cache (dummy function used by upgrade/install scripts) */ function update_update_check()
|
{
| {
|
$update_cache = array( "dateline" => TIME_NOW );
$this->update("update_check", $update_cache);
|
$update_cache = array( "dateline" => TIME_NOW );
$this->update("update_check", $update_cache);
|
}
| }
|
/** * Update default_theme cache */
| /** * Update default_theme cache */
|
Zeile 992 | Zeile 1003 |
---|
$query = $db->simple_select("themes", "name, tid, properties, stylesheets", "def='1'", array('limit' => 1)); $theme = $db->fetch_array($query); $this->update("default_theme", $theme);
|
$query = $db->simple_select("themes", "name, tid, properties, stylesheets", "def='1'", array('limit' => 1)); $theme = $db->fetch_array($query); $this->update("default_theme", $theme);
|
}
/**
| }
/**
|
* Updates the tasks cache saving the next run time */ function update_tasks()
| * Updates the tasks cache saving the next run time */ function update_tasks()
|
Zeile 1003 | Zeile 1014 |
---|
$query = $db->simple_select("tasks", "nextrun", "enabled=1", array("order_by" => "nextrun", "order_dir" => "asc", "limit" => 1)); $next_task = $db->fetch_array($query);
|
$query = $db->simple_select("tasks", "nextrun", "enabled=1", array("order_by" => "nextrun", "order_dir" => "asc", "limit" => 1)); $next_task = $db->fetch_array($query);
|
|
|
$task_cache = $this->read("tasks"); if(!is_array($task_cache)) {
| $task_cache = $this->read("tasks"); if(!is_array($task_cache)) {
|
Zeile 1012 | Zeile 1023 |
---|
$task_cache['nextrun'] = $next_task['nextrun'];
if(!$task_cache['nextrun'])
|
$task_cache['nextrun'] = $next_task['nextrun'];
if(!$task_cache['nextrun'])
|
{
| {
|
$task_cache['nextrun'] = TIME_NOW+3600; }
|
$task_cache['nextrun'] = TIME_NOW+3600; }
|
|
|
$this->update("tasks", $task_cache); }
| $this->update("tasks", $task_cache); }
|
Zeile 1029 | Zeile 1040 |
---|
$banned_ips = array(); $query = $db->simple_select("banfilters", "fid,filter", "type=1"); while($banned_ip = $db->fetch_array($query))
|
$banned_ips = array(); $query = $db->simple_select("banfilters", "fid,filter", "type=1"); while($banned_ip = $db->fetch_array($query))
|
{
| {
|
$banned_ips[$banned_ip['fid']] = $banned_ip; } $this->update("bannedips", $banned_ips); }
|
$banned_ips[$banned_ip['fid']] = $banned_ip; } $this->update("bannedips", $banned_ips); }
|
|
|
/** * Updates the banned emails cache */
| /** * Updates the banned emails cache */
|
Zeile 1046 | Zeile 1057 |
---|
$query = $db->simple_select("banfilters", "fid, filter", "type = '3'");
while($banned_email = $db->fetch_array($query))
|
$query = $db->simple_select("banfilters", "fid, filter", "type = '3'");
while($banned_email = $db->fetch_array($query))
|
{
| {
|
$banned_emails[$banned_email['fid']] = $banned_email; }
|
$banned_emails[$banned_email['fid']] = $banned_email; }
|
|
|
$this->update("bannedemails", $banned_emails); }
| $this->update("bannedemails", $banned_emails); }
|
Zeile 1063 | Zeile 1074 |
---|
$spiders = array(); $query = $db->simple_select("spiders", "sid, name, useragent, usergroup", "", array("order_by" => "LENGTH(useragent)", "order_dir" => "DESC")); while($spider = $db->fetch_array($query))
|
$spiders = array(); $query = $db->simple_select("spiders", "sid, name, useragent, usergroup", "", array("order_by" => "LENGTH(useragent)", "order_dir" => "DESC")); while($spider = $db->fetch_array($query))
|
{
| {
|
$spiders[$spider['sid']] = $spider; } $this->update("spiders", $spiders); }
|
$spiders[$spider['sid']] = $spider; } $this->update("spiders", $spiders); }
|
|
|
function update_most_replied_threads() { global $db, $mybb;
|
function update_most_replied_threads() { global $db, $mybb;
|
|
|
$threads = array();
|
$threads = array();
|
$query = $db->simple_select("threads", "tid, subject, replies, fid", "visible='1'", array('order_by' => 'replies', 'order_dir' => 'DESC', 'limit_start' => 0, 'limit' => $mybb->settings['statslimit']));
| $query = $db->simple_select("threads", "tid, subject, replies, fid, uid", "visible='1'", array('order_by' => 'replies', 'order_dir' => 'DESC', 'limit_start' => 0, 'limit' => $mybb->settings['statslimit']));
|
while($thread = $db->fetch_array($query)) { $threads[] = $thread; }
$this->update("most_replied_threads", $threads);
|
while($thread = $db->fetch_array($query)) { $threads[] = $thread; }
$this->update("most_replied_threads", $threads);
|
}
| }
|
function update_most_viewed_threads() { global $db, $mybb;
|
function update_most_viewed_threads() { global $db, $mybb;
|
$threads = array();
$query = $db->simple_select("threads", "tid, subject, views, fid", "visible='1'", array('order_by' => 'views', 'order_dir' => 'DESC', 'limit_start' => 0, 'limit' => $mybb->settings['statslimit']));
| $threads = array();
$query = $db->simple_select("threads", "tid, subject, views, fid, uid", "visible='1'", array('order_by' => 'views', 'order_dir' => 'DESC', 'limit_start' => 0, 'limit' => $mybb->settings['statslimit']));
|
while($thread = $db->fetch_array($query)) { $threads[] = $thread;
| while($thread = $db->fetch_array($query)) { $threads[] = $thread;
|
Zeile 1099 | Zeile 1110 |
---|
$this->update("most_viewed_threads", $threads); }
|
$this->update("most_viewed_threads", $threads); }
|
| /** * @deprecated */
|
function update_banned()
|
function update_banned()
|
{ global $db;
$bans = array();
$query = $db->simple_select("banned"); while($ban = $db->fetch_array($query)) { $bans[$ban['uid']] = $ban; }
$this->update("banned", $bans);
| { // "banned" cache removed
|
}
function update_birthdays()
| }
function update_birthdays()
|
Zeile 1120 | Zeile 1124 |
---|
$birthdays = array();
|
$birthdays = array();
|
// Get today, yesturday, and tomorrow's time (for different timezones)
| // Get today, yesterday, and tomorrow's time (for different timezones)
|
$bdaytime = TIME_NOW; $bdaydate = my_date("j-n", $bdaytime, '', 0); $bdaydatetomorrow = my_date("j-n", ($bdaytime+86400), '', 0);
| $bdaytime = TIME_NOW; $bdaydate = my_date("j-n", $bdaytime, '', 0); $bdaydatetomorrow = my_date("j-n", ($bdaytime+86400), '', 0);
|
Zeile 1136 | Zeile 1140 |
---|
if($bday['birthdayprivacy'] != 'all') {
|
if($bday['birthdayprivacy'] != 'all') {
|
++$birthdays[$bday['bday']]['hiddencount'];
| if(isset($birthdays[$bday['bday']]['hiddencount'])) { ++$birthdays[$bday['bday']]['hiddencount']; } else { $birthdays[$bday['bday']]['hiddencount'] = 1; }
|
continue;
|
continue;
|
}
| }
|
// We don't need any excess caleries in the cache unset($bday['birthdayprivacy']);
|
// We don't need any excess caleries in the cache unset($bday['birthdayprivacy']);
|
| if(!isset($birthdays[$bday['bday']]['users'])) { $birthdays[$bday['bday']]['users'] = array(); }
|
$birthdays[$bday['bday']]['users'][] = $bday; }
| $birthdays[$bday['bday']]['users'][] = $bday; }
|
Zeile 1243 | Zeile 1259 |
---|
}
$this->update("profilefields", $fields);
|
}
$this->update("profilefields", $fields);
|
| }
/** * Update the report reasons cache. * */ function update_reportreasons($no_plugins = false) { global $db;
$content_types = array('post', 'profile', 'reputation'); if(!$no_plugins) { global $plugins; $content_types = $plugins->run_hooks("report_content_types", $content_types); }
$reasons = array();
$query = $db->simple_select("reportreasons", "*", "", array('order_by' => 'disporder')); while($reason = $db->fetch_array($query)) { if($reason['appliesto'] == 'all') { foreach($content_types as $content) { $reasons[$content][] = array( 'rid' => $reason['rid'], 'title' => $reason['title'], 'extra' => $reason['extra'], ); } } elseif($reason['appliesto'] != '') { $appliesto = explode(",", $reason['appliesto']); foreach($appliesto as $content) { $reasons[$content][] = array( 'rid' => $reason['rid'], 'title' => $reason['title'], 'extra' => $reason['extra'], ); } } }
$this->update("reportreasons", $reasons);
|
}
/* Other, extra functions for reloading caches if we just changed to another cache extension (i.e. from db -> xcache) */
| }
/* Other, extra functions for reloading caches if we just changed to another cache extension (i.e. from db -> xcache) */
|
Zeile 1251 | Zeile 1315 |
---|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='mostonline'");
|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='mostonline'");
|
$this->update("mostonline", unserialize($db->fetch_field($query, "cache"))); }
| $this->update("mostonline", my_unserialize($db->fetch_field($query, "cache"))); }
|
function reload_plugins() { global $db;
$query = $db->simple_select("datacache", "title,cache", "title='plugins'");
|
function reload_plugins() { global $db;
$query = $db->simple_select("datacache", "title,cache", "title='plugins'");
|
$this->update("plugins", unserialize($db->fetch_field($query, "cache")));
| $this->update("plugins", my_unserialize($db->fetch_field($query, "cache")));
|
}
function reload_last_backup()
| }
function reload_last_backup()
|
Zeile 1267 | Zeile 1331 |
---|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='last_backup'");
|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='last_backup'");
|
$this->update("last_backup", unserialize($db->fetch_field($query, "cache")));
| $this->update("last_backup", my_unserialize($db->fetch_field($query, "cache")));
|
}
function reload_internal_settings()
|
}
function reload_internal_settings()
|
{ global $db;
| { global $db;
|
$query = $db->simple_select("datacache", "title,cache", "title='internal_settings'");
|
$query = $db->simple_select("datacache", "title,cache", "title='internal_settings'");
|
$this->update("internal_settings", unserialize($db->fetch_field($query, "cache")));
| $this->update("internal_settings", my_unserialize($db->fetch_field($query, "cache")));
|
}
function reload_version_history()
|
}
function reload_version_history()
|
{ global $db;
| { global $db;
|
$query = $db->simple_select("datacache", "title,cache", "title='version_history'");
|
$query = $db->simple_select("datacache", "title,cache", "title='version_history'");
|
$this->update("version_history", unserialize($db->fetch_field($query, "cache")));
| $this->update("version_history", my_unserialize($db->fetch_field($query, "cache")));
|
}
function reload_modnotes()
|
}
function reload_modnotes()
|
{ global $db;
| { global $db;
|
$query = $db->simple_select("datacache", "title,cache", "title='modnotes'");
|
$query = $db->simple_select("datacache", "title,cache", "title='modnotes'");
|
$this->update("modnotes", unserialize($db->fetch_field($query, "cache")));
| $this->update("modnotes", my_unserialize($db->fetch_field($query, "cache")));
|
}
function reload_adminnotes()
| }
function reload_adminnotes()
|
Zeile 1299 | Zeile 1363 |
---|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='adminnotes'");
|
global $db;
$query = $db->simple_select("datacache", "title,cache", "title='adminnotes'");
|
$this->update("adminnotes", unserialize($db->fetch_field($query, "cache"))); }
function reload_mybb_credits() { admin_redirect('index.php?module=home-credits&fetch_new=-2');
| $this->update("adminnotes", my_unserialize($db->fetch_field($query, "cache")));
|
} }
| } }
|