cache user data for user sitemap

This commit is contained in:
Evan Prodromou 2010-04-12 12:00:15 -04:00
parent 946cd15e8b
commit 3e8172585d

View File

@ -43,7 +43,8 @@ if (!defined('STATUSNET')) {
class UsersitemapAction extends SitemapAction class UsersitemapAction extends SitemapAction
{ {
var $user = null; var $users = null;
var $j = 0;
function prepare($args) function prepare($args)
{ {
@ -61,10 +62,29 @@ class UsersitemapAction extends SitemapAction
$d += 0; $d += 0;
$i += 0; $i += 0;
$offset = ($i-1) * SitemapPlugin::USERS_PER_MAP; $this->users = $this->getUsers($y, $m, $d, $i);
$limit = SitemapPlugin::USERS_PER_MAP; $this->j = 0;
return true;
}
$this->user = new User(); function nextUrl()
{
if ($this->j < count($this->users)) {
$nickname = $this->users[$this->j];
$this->j++;
return array(common_profile_url($nickname), null, null, null);
} else {
return null;
}
}
function getUsers($y, $m, $d, $i)
{
$u = User::cacheGet("sitemap:user:$y:$m:$d:$i");
if ($u === false) {
$user = new User();
$begindt = sprintf('%04d-%02d-%02d 00:00:00', $y, $m, $d); $begindt = sprintf('%04d-%02d-%02d 00:00:00', $y, $m, $d);
@ -72,26 +92,37 @@ class UsersitemapAction extends SitemapAction
// with leap seconds (1d == 24h + 1s). Thankfully they're // with leap seconds (1d == 24h + 1s). Thankfully they're
// few and far between. // few and far between.
$enddt = common_sql_date(strtotime($begindt) + (24 * 60 * 60)); $theend = strtotime($begindt) + (24 * 60 * 60);
$enddt = common_sql_date($theend);
$this->user->whereAdd("created >= '$begindt'"); $user->selectAdd();
$this->user->whereAdd("created < '$enddt'"); $user->selectAdd('nickname');
$user->whereAdd("created >= '$begindt'");
$user->whereAdd("created < '$enddt'");
$this->user->orderBy('created'); $user->orderBy('created');
$this->user->limit($offset, $limit); $offset = ($i-1) * SitemapPlugin::USERS_PER_MAP;
$limit = SitemapPlugin::USERS_PER_MAP;
$this->user->find(); $user->limit($offset, $limit);
return true; $user->find();
while ($user->fetch()) {
$u[] = $user->nickname;
} }
function nextUrl() $c = Cache::instance();
{
if ($this->user->fetch()) { if (!empty($c)) {
return array(common_profile_url($this->user->nickname), null, null, null); $c->set(Cache::key("sitemap:user:$y:$m:$d:$i"),
} else { $u,
return null; Cache::COMPRESSED,
((time() > $theend) ? (time() + 90 * 24 * 60 * 60) : (time() + 5 * 60)));
} }
} }
return $u;
}
} }