summaryrefslogtreecommitdiff
path: root/classes
diff options
context:
space:
mode:
authorEvan Prodromou <evan@status.net>2010-10-13 22:44:06 -0400
committerEvan Prodromou <evan@status.net>2010-10-13 22:44:06 -0400
commit76038fe20c7ebd732ffbc659827ab812ee5a4b6e (patch)
tree7b838c9dd69b7351e98eeb2bb7abadaf5b1e0bfb /classes
parentddb60a8191de23fc11f6711954575ac7b6f49998 (diff)
better deletion of related objects in User_group::delete()
Diffstat (limited to 'classes')
-rw-r--r--classes/User_group.php17
1 files changed, 16 insertions, 1 deletions
diff --git a/classes/User_group.php b/classes/User_group.php
index 1f7005785..7d6e21914 100644
--- a/classes/User_group.php
+++ b/classes/User_group.php
@@ -559,16 +559,27 @@ class User_group extends Memcached_DataObject
function delete()
{
if ($this->id) {
+
// Safe to delete in bulk for now
+
$related = array('Group_inbox',
'Group_block',
'Group_member',
'Related_group');
+
Event::handle('UserGroupDeleteRelated', array($this, &$related));
+
foreach ($related as $cls) {
+
$inst = new $cls();
$inst->group_id = $this->id;
- $inst->delete();
+
+ if ($inst->find()) {
+ while ($inst->fetch()) {
+ $dup = clone($inst);
+ $dup->delete();
+ }
+ }
}
// And related groups in the other direction...
@@ -584,6 +595,10 @@ class User_group extends Memcached_DataObject
if ($local) {
$local->delete();
}
+
+ // blow the cached ids
+ self::blow('user_group:notice_ids:%d', $this->id);
+
} else {
common_log(LOG_WARN, "Ambiguous user_group->delete(); skipping related tables.");
}