cache results of notice sitemap query
This commit is contained in:
parent
610d8021d8
commit
946cd15e8b
@ -84,37 +84,52 @@ class NoticesitemapAction extends SitemapAction
|
|||||||
|
|
||||||
function getNotices($y, $m, $d, $i)
|
function getNotices($y, $m, $d, $i)
|
||||||
{
|
{
|
||||||
$offset = ($i-1) * SitemapPlugin::NOTICES_PER_MAP;
|
$n = Notice::cacheGet("sitemap:notice:$y:$m:$d:$i");
|
||||||
$limit = SitemapPlugin::NOTICES_PER_MAP;
|
|
||||||
|
|
||||||
$notice = new Notice();
|
if ($n === false) {
|
||||||
|
|
||||||
$begindt = sprintf('%04d-%02d-%02d 00:00:00', $y, $m, $d);
|
$notice = new Notice();
|
||||||
|
|
||||||
// XXX: estimates 1d == 24h, which screws up days
|
$begindt = sprintf('%04d-%02d-%02d 00:00:00', $y, $m, $d);
|
||||||
// with leap seconds (1d == 24h + 1s). Thankfully they're
|
|
||||||
// few and far between.
|
|
||||||
|
|
||||||
$enddt = common_sql_date(strtotime($begindt) + (24 * 60 * 60));
|
// XXX: estimates 1d == 24h, which screws up days
|
||||||
|
// with leap seconds (1d == 24h + 1s). Thankfully they're
|
||||||
|
// few and far between.
|
||||||
|
|
||||||
$notice->selectAdd();
|
$theend = strtotime($begindt) + (24 * 60 * 60);
|
||||||
$notice->selectAdd('id, created');
|
$enddt = common_sql_date($theend);
|
||||||
|
|
||||||
$notice->whereAdd("created >= '$begindt'");
|
$notice->selectAdd();
|
||||||
$notice->whereAdd("created < '$enddt'");
|
$notice->selectAdd('id, created');
|
||||||
|
|
||||||
$notice->whereAdd('is_local != 0');
|
$notice->whereAdd("created >= '$begindt'");
|
||||||
|
$notice->whereAdd("created < '$enddt'");
|
||||||
|
|
||||||
$notice->orderBy('created');
|
$notice->whereAdd('is_local != 0');
|
||||||
|
|
||||||
$notice->limit($offset, $limit);
|
$notice->orderBy('created');
|
||||||
|
|
||||||
$notice->find();
|
$offset = ($i-1) * SitemapPlugin::NOTICES_PER_MAP;
|
||||||
|
$limit = SitemapPlugin::NOTICES_PER_MAP;
|
||||||
|
|
||||||
$n = array();
|
$notice->limit($offset, $limit);
|
||||||
|
|
||||||
while ($notice->fetch()) {
|
$notice->find();
|
||||||
$n[] = array($notice->id, $notice->created);
|
|
||||||
|
$n = array();
|
||||||
|
|
||||||
|
while ($notice->fetch()) {
|
||||||
|
$n[] = array($notice->id, $notice->created);
|
||||||
|
}
|
||||||
|
|
||||||
|
$c = Cache::instance();
|
||||||
|
|
||||||
|
if (!empty($c)) {
|
||||||
|
$c->set(Cache::key("sitemap:notice:$y:$m:$d:$i"),
|
||||||
|
$n,
|
||||||
|
Cache::COMPRESSED,
|
||||||
|
((time() > $theend) ? (time() + 90 * 24 * 60 * 60) : (time() + 5 * 60)));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return $n;
|
return $n;
|
||||||
|
Loading…
Reference in New Issue
Block a user