summaryrefslogtreecommitdiff
path: root/plugins/AnonymousFave/Fave_tally.php
diff options
context:
space:
mode:
authorZach Copley <zach@status.net>2010-09-29 13:29:58 -0700
committerZach Copley <zach@status.net>2010-09-29 16:35:13 -0700
commit4d6973cd700ff3fa9c84ead56e64852832281b31 (patch)
treee62369de8248abec0478e2aa2963a0b0a485efff /plugins/AnonymousFave/Fave_tally.php
parent5b49fc25bfe89c081ad1aa5af2005616eb319484 (diff)
Intialize new fave tallys with total existing fave count per notice
Diffstat (limited to 'plugins/AnonymousFave/Fave_tally.php')
-rw-r--r--plugins/AnonymousFave/Fave_tally.php38
1 files changed, 29 insertions, 9 deletions
diff --git a/plugins/AnonymousFave/Fave_tally.php b/plugins/AnonymousFave/Fave_tally.php
index 0eaa3fdc7..35ace6d01 100644
--- a/plugins/AnonymousFave/Fave_tally.php
+++ b/plugins/AnonymousFave/Fave_tally.php
@@ -36,7 +36,7 @@ require_once INSTALLDIR . '/classes/Memcached_DataObject.php';
/**
* Data class for favorites tally
*
- * A class representing a total number of times a notice has been favorited
+ * A class representing a total number of times a notice has been favored
*
* @category Action
* @package StatusNet
@@ -159,7 +159,7 @@ class Fave_tally extends Memcached_DataObject
if (!$result) {
$msg = sprintf(
_m("Couldn't update favorite tally for notice ID %d."),
- $notice_id
+ $noticeID
);
throw new ServerException($msg);
}
@@ -189,7 +189,7 @@ class Fave_tally extends Memcached_DataObject
if (!$result) {
$msg = sprintf(
_m("Couldn't update favorite tally for notice ID %d."),
- $notice_id
+ $noticeID
);
throw new ServerException($msg);
}
@@ -200,7 +200,7 @@ class Fave_tally extends Memcached_DataObject
/**
* Ensure a tally exists for a given notice. If we can't find
- * one create one.
+ * one create one with the total number of existing faves
*
* @param integer $noticeID
*
@@ -209,18 +209,18 @@ class Fave_tally extends Memcached_DataObject
static function ensureTally($noticeID)
{
- $tally = Fave_tally::staticGet('notice_id', $notice_id);
+ $tally = Fave_tally::staticGet('notice_id', $noticeID);
if (!$tally) {
- common_debug("Fave_tally::ensureTally - creating tally for notice " . $notice_id);
+ common_debug("Fave_tally::ensureTally - creating tally for notice " . $noticeID);
$tally = new Fave_tally();
- $tally->notice_id = $notice_id;
- $tally->count = 0;
+ $tally->notice_id = $noticeID;
+ $tally->count = Fave_tally::countExistingFaves($noticeID);
$result = $tally->insert();
if (!$result) {
$msg = sprintf(
_m("Couldn't create favorite tally for notice ID %d."),
- $notice_id
+ $noticeID
);
throw new ServerException($msg);
}
@@ -228,4 +228,24 @@ class Fave_tally extends Memcached_DataObject
return $tally;
}
+
+ /**
+ * Count the number of faves a notice already has. Used to initalize
+ * a tally for a notice.
+ *
+ * @param integer $noticeID ID of the notice to count faves for
+ *
+ * @return integer $total total number of time the notice has been favored
+ */
+
+ static function countExistingFaves($noticeID)
+ {
+ $fave = new Fave();
+ $fave->notice_id = $noticeID;
+ $total = $fave->count();
+
+ common_debug("ZZZZZZZ notice " . $noticeID . ' has ' . $total . " faves");
+
+ return $total;
+ }
}