forked from GNUsocial/gnu-social
e26a843caf
Moved much of the writing that happens when posting a notice to a new queuehandler, distribqueuehandler. This updates tags, groups, replies and inboxes at queue time (or at Web time, if queues are disabled). To make this work well, I had to break up the monolithic Notice::blowCaches() and make cache blowing happen closer to where data is updated. Squashed commit of the following: commit 5257626c62750ac4ac1db0ce2b71410c5711cfa3 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 14:56:41 2010 -0500 slightly better handling of blowing tag memory cache commit 8a22a3cdf6ec28685da129a0313e7b2a0837c9ef Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:42:56 2010 -0500 change 'distribute' to 'distrib' so not too long for dbqueue commit 7a063315b0f7fad27cb6fbd2bdd74e253af83e4f Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:39:15 2010 -0500 change handle_notice() to handle() in distributqueuehandler commit 1a39ccd28b9994137d7bfd21bb4f230546938e77 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 16:05:25 2010 -0500 error with queuemanager commit e6b3bb93f305cfd2de71a6340b8aa6fb890049b7 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 01:11:34 2010 -0500 Blow memcache at different point rather than one big function for Notice class commit 94d557cdc016187d1d0647ae1794cd94d6fb8ac8 Author: Evan Prodromou <evan@status.net> Date: Mon Jan 25 00:48:44 2010 -0500 Blow memcache at different point rather than one big function for Notice class commit 1c781dd08c88a35dafc5c01230b4872fd6b95182 Author: Evan Prodromou <evan@status.net> Date: Wed Jan 20 08:54:18 2010 -0500 move broadcasting and distributing to new queuehandler commit da3e46d26b84e4f028f34a13fd2ee373e4c1b954 Author: Evan Prodromou <evan@status.net> Date: Wed Jan 20 08:53:12 2010 -0500 Move distribution of notices to new distribute queue handler
100 lines
3.0 KiB
PHP
100 lines
3.0 KiB
PHP
<?php
|
|
/*
|
|
* StatusNet - the distributed open-source microblogging tool
|
|
* Copyright (C) 2008, 2009, StatusNet, Inc.
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Affero General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
require_once INSTALLDIR.'/classes/Memcached_DataObject.php';
|
|
|
|
class Notice_tag extends Memcached_DataObject
|
|
{
|
|
###START_AUTOCODE
|
|
/* the code below is auto generated do not remove the above tag */
|
|
|
|
public $__table = 'notice_tag'; // table name
|
|
public $tag; // varchar(64) primary_key not_null
|
|
public $notice_id; // int(4) primary_key not_null
|
|
public $created; // datetime() not_null
|
|
|
|
/* Static get */
|
|
function staticGet($k,$v=null)
|
|
{ return Memcached_DataObject::staticGet('Notice_tag',$k,$v); }
|
|
|
|
/* the code above is auto generated do not remove the tag below */
|
|
###END_AUTOCODE
|
|
|
|
static function getStream($tag, $offset=0, $limit=20) {
|
|
|
|
$ids = Notice::stream(array('Notice_tag', '_streamDirect'),
|
|
array($tag),
|
|
'notice_tag:notice_ids:' . common_keyize($tag),
|
|
$offset, $limit);
|
|
|
|
return Notice::getStreamByIds($ids);
|
|
}
|
|
|
|
function _streamDirect($tag, $offset, $limit, $since_id, $max_id, $since)
|
|
{
|
|
$nt = new Notice_tag();
|
|
|
|
$nt->tag = $tag;
|
|
|
|
$nt->selectAdd();
|
|
$nt->selectAdd('notice_id');
|
|
|
|
if ($since_id != 0) {
|
|
$nt->whereAdd('notice_id > ' . $since_id);
|
|
}
|
|
|
|
if ($max_id != 0) {
|
|
$nt->whereAdd('notice_id < ' . $max_id);
|
|
}
|
|
|
|
if (!is_null($since)) {
|
|
$nt->whereAdd('created > \'' . date('Y-m-d H:i:s', $since) . '\'');
|
|
}
|
|
|
|
$nt->orderBy('notice_id DESC');
|
|
|
|
if (!is_null($offset)) {
|
|
$nt->limit($offset, $limit);
|
|
}
|
|
|
|
$ids = array();
|
|
|
|
if ($nt->find()) {
|
|
while ($nt->fetch()) {
|
|
$ids[] = $nt->notice_id;
|
|
}
|
|
}
|
|
|
|
return $ids;
|
|
}
|
|
|
|
function blowCache($blowLast=false)
|
|
{
|
|
self::blow('notice_tag:notice_ids:%s', common_keyize($this->tag));
|
|
if ($blowLast) {
|
|
self::blow('notice_tag:notice_ids:%s;last', common_keyize($this->tag));
|
|
}
|
|
}
|
|
|
|
function pkeyGet($kv)
|
|
{
|
|
return Memcached_DataObject::pkeyGet('Notice_tag', $kv);
|
|
}
|
|
}
|