Improve cache-friendliness of user_group->delete().

Doesn't clear all possible cached entries, but this should get the ones that matter most: lookups by id, nickname, and alias. This should ensure that if a group name gets reused as a new group or alias, it should work properly.
There are some user-visible areas that aren't clear such as the 'top groups' lists on the GroupsAction sidebar; if a deleted group appears in those lists it'll go away within an hour when the cached query expires.
This commit is contained in:
Brion Vibber 2010-10-12 16:29:13 -07:00
parent 3579ccac8e
commit 112b6c4079

View File

@ -551,29 +551,39 @@ class User_group extends Memcached_DataObject
/** /**
* Handle cascading deletion, on the model of notice and profile. * Handle cascading deletion, on the model of notice and profile.
* *
* Pretty sure some caching won't get handled properly here. * This should handle freeing up cached entries for the group's
* id, nickname, URI, and aliases. There may be other areas that
* are not de-cached in the UI, including the sidebar lists on
* GroupsAction
*/ */
function delete() function delete()
{ {
if ($this->id) { if ($this->id) {
// Safe to delete in bulk for now
$related = array('Group_inbox', $related = array('Group_inbox',
'Group_alias',
'Group_block', 'Group_block',
'Group_member', 'Group_member',
'Local_group', 'Related_group');
'Related_group',
);
Event::handle('UserGroupDeleteRelated', array($this, &$related)); Event::handle('UserGroupDeleteRelated', array($this, &$related));
foreach ($related as $cls) { foreach ($related as $cls) {
$inst = new $cls(); $inst = new $cls();
$inst->group_id = $this->id; $inst->group_id = $this->id;
$inst->delete(); $inst->delete();
} }
// And related groups in the other direction...
$inst = new Related_group(); $inst = new Related_group();
$inst->related_group_id = $this->id; $inst->related_group_id = $this->id;
$inst->delete(); $inst->delete();
// Aliases and the local_group entry need to be cleared explicitly
// or we'll miss clearing some cache keys; that can make it hard
// to create a new group with one of those names or aliases.
$this->setAliases(array());
$local = Local_group::staticGet('group_id', $this->id);
if ($local) {
$local->delete();
}
} else { } else {
common_log(LOG_WARN, "Ambiguous user_group->delete(); skipping related tables."); common_log(LOG_WARN, "Ambiguous user_group->delete(); skipping related tables.");
} }