X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=classes%2FNotice_tag.php;h=81d346c5d3b2a5da148186492ff0f186175ff29c;hb=39f8d2c72830d7bc3c08f60d1df38d19c846a74b;hp=94f9296d602c92cc1c121cd498ad988ce4b6024d;hpb=2d456a15e5652a0c0e2c0f9f50221eed2d16e109;p=quix0rs-gnu-social.git diff --git a/classes/Notice_tag.php b/classes/Notice_tag.php index 94f9296d60..81d346c5d3 100644 --- a/classes/Notice_tag.php +++ b/classes/Notice_tag.php @@ -1,7 +1,7 @@ tag = $tag; + + $nt->selectAdd(); + $nt->selectAdd('notice_id'); + + Notice::addWhereSinceId($nt, $since_id, 'notice_id'); + Notice::addWhereMaxId($nt, $max_id, 'notice_id'); + + $nt->orderBy('created DESC, 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() + + function blowCache($blowLast=false) { - $cache = common_memcache(); - if ($cache) { - $cache->delete(common_cache_key('notice_tag:notice_stream:' . $this->tag)); + self::blow('notice_tag:notice_ids:%s', Cache::keyize($this->tag)); + if ($blowLast) { + self::blow('notice_tag:notice_ids:%s;last', Cache::keyize($this->tag)); } } + + function pkeyGet($kv) + { + return Memcached_DataObject::pkeyGet('Notice_tag', $kv); + } + + static function url($tag) + { + if (common_config('singleuser', 'enabled')) { + // regular TagAction isn't set up in 1user mode + $nickname = User::singleUserNickname(); + $url = common_local_url('showstream', + array('nickname' => $nickname, + 'tag' => $tag)); + } else { + $url = common_local_url('tag', array('tag' => $tag)); + } + + return $url; + } }