diff options
author | Max Kanat-Alexander <mkanat@bugzilla.org> | 2010-02-07 22:12:31 +0100 |
---|---|---|
committer | Max Kanat-Alexander <mkanat@bugzilla.org> | 2010-02-07 22:12:31 +0100 |
commit | 36b5893ba963132cfcfa394aa1a67badeb3aa53e (patch) | |
tree | 06b4e7d6cbdd46e8a04d69810072fea9149ab9ac /Bugzilla | |
parent | fcf51896ea64862b43e651657ea775319c1abd31 (diff) | |
download | bugzilla-36b5893ba963132cfcfa394aa1a67badeb3aa53e.tar.gz bugzilla-36b5893ba963132cfcfa394aa1a67badeb3aa53e.tar.xz |
Bug 496488: Hooks for creating, updating, and deleting groups
r=mkanat, a=mkanat (module owner)
Diffstat (limited to 'Bugzilla')
-rw-r--r-- | Bugzilla/Group.pm | 14 | ||||
-rw-r--r-- | Bugzilla/Hook.pm | 46 |
2 files changed, 60 insertions, 0 deletions
diff --git a/Bugzilla/Group.pm b/Bugzilla/Group.pm index c936593bc..65df4ee81 100644 --- a/Bugzilla/Group.pm +++ b/Bugzilla/Group.pm @@ -195,6 +195,8 @@ sub set_icon_url { $_[0]->set('icon_url', $_[1]); } sub update { my $self = shift; + my $dbh = Bugzilla->dbh; + $dbh->bz_start_transaction(); my $changes = $self->SUPER::update(@_); if (exists $changes->{name}) { @@ -214,6 +216,10 @@ sub update { && $changes->{isactive}->[1]); $self->_rederive_regexp() if exists $changes->{userregexp}; + + Bugzilla::Hook::process('group_end_of_update', + { group => $self, changes => $changes }); + $dbh->bz_commit_transaction(); return $changes; } @@ -269,12 +275,15 @@ sub remove_from_db { my $self = shift; my $dbh = Bugzilla->dbh; $self->check_remove(@_); + $dbh->bz_start_transaction(); + Bugzilla::Hook::process('group_before_delete', { group => $self }); $dbh->do('DELETE FROM whine_schedules WHERE mailto_type = ? AND mailto = ?', undef, MAILTO_GROUP, $self->id); # All the other tables will be handled by foreign keys when we # drop the main "groups" row. $self->SUPER::remove_from_db(@_); + $dbh->bz_commit_transaction(); } # Add missing entries in bug_group_map for bugs created while @@ -375,6 +384,8 @@ sub create { print get_text('install_group_create', { name => $params->{name} }) . "\n" if Bugzilla->usage_mode == USAGE_MODE_CMDLINE; + $dbh->bz_start_transaction(); + my $group = $class->SUPER::create(@_); # Since we created a new group, give the "admin" group all privileges @@ -392,6 +403,9 @@ sub create { } $group->_rederive_regexp() if $group->user_regexp; + + Bugzilla::Hook::process('group_end_of_create', { group => $group }); + $dbh->bz_commit_transaction(); return $group; } diff --git a/Bugzilla/Hook.pm b/Bugzilla/Hook.pm index 44b5c3c58..13e435e86 100644 --- a/Bugzilla/Hook.pm +++ b/Bugzilla/Hook.pm @@ -454,6 +454,52 @@ changed flags, and search for a specific condition like C<added eq 'review-'>. =back +=head2 group_before_delete + +This happens in L<Bugzilla::Group/remove_from_db>, after we've confirmed +that the group can be deleted, but before any rows have actually +been removed from the database. This occurs inside a database +transaction. + +Params: + +=over + +=item C<group> - The L<Bugzilla::Group> being deleted. + +=back + +=head2 group_end_of_create + +This happens at the end of L<Bugzilla::Group/create>, after all other +changes are made to the database. This occurs inside a database transaction. + +Params: + +=over + +=item C<group> - The changed L<Bugzilla::Group> object, with all fields set +to their updated values. + +=back + +=head2 group_end_of_update + +This happens at the end of L<Bugzilla::Group/update>, after all other +changes are made to the database. This occurs inside a database transaction. + +Params: + +=over + +=item C<group> - The changed L<Bugzilla::Group> object, with all fields set +to their updated values. + +=item C<changes> - The hash of changed fields. +C<< $changes->{$field} = [$old, $new] >> + +=back + =head2 install_before_final_checks Allows execution of custom code before the final checks are done in |