X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=classes%2FNotice_tag.php;h=3d7658a1acfe19ed64e08f2c0d6ee152f43c2e4c;hb=5e47b1b2a07d8b300c511115ca018ece172a8505;hp=f2247299a4d137fba865e32cc350a97de0590fbb;hpb=e5345d8d7a5b519cfb24c9e2a971b485b3c1c872;p=quix0rs-gnu-social.git diff --git a/classes/Notice_tag.php b/classes/Notice_tag.php index f2247299a4..3d7658a1ac 100644 --- a/classes/Notice_tag.php +++ b/classes/Notice_tag.php @@ -1,7 +1,7 @@ 'Hash tags', + 'fields' => array( + 'tag' => array('type' => 'varchar', 'length' => 64, 'not null' => true, 'description' => 'hash tag associated with this notice'), + 'notice_id' => array('type' => 'int', 'not null' => true, 'description' => 'notice tagged'), + 'created' => array('type' => 'datetime', 'not null' => true, 'description' => 'date this record was created'), + ), + 'primary key' => array('tag', 'notice_id'), + 'foreign keys' => array( + 'notice_tag_notice_id_fkey' => array('notice', array('notice_id' => 'id')), + ), + 'indexes' => array( + 'notice_tag_created_idx' => array('created'), + 'notice_tag_notice_id_idx' => array('notice_id'), + 'notice_tag_tag_created_notice_id_idx' => array('tag', 'created', 'notice_id') + ), + ); } - - function blowCache() + + static function getStream($tag, $offset=0, $limit=20, $sinceId=0, $maxId=0) { - $cache = common_memcache(); - if ($cache) { - $cache->delete(common_cache_key('notice_tag:notice_stream:' . $this->tag)); - } + $stream = new TagNoticeStream($tag); + + return $stream->getNotices($offset, $limit, $sinceId, $maxId); } - function &pkeyGet($kv) + function blowCache($blowLast=false) { - return Memcached_DataObject::pkeyGet('Notice_tag', $kv); + 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)); + } } + + 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; + } }