diff options
Diffstat (limited to 'Bugzilla')
-rw-r--r-- | Bugzilla/Hook.pm | 28 | ||||
-rw-r--r-- | Bugzilla/Object.pm | 3 |
2 files changed, 31 insertions, 0 deletions
diff --git a/Bugzilla/Hook.pm b/Bugzilla/Hook.pm index af73814ce..556fda894 100644 --- a/Bugzilla/Hook.pm +++ b/Bugzilla/Hook.pm @@ -784,6 +784,34 @@ validated by the C<VALIDATORS> specified for the object. =back + +=head2 object_end_of_set + +Called during L<Bugzilla::Object/set>, after all the code of the function +has completed (so the value has been validated and the field has been set +to the new value). You can use this to perform actions after a value is +changed for specific fields on certain types of objects. + +The new value is not specifically passed to this hook because you can +get it as C<< $object->{$field} >>. + +Params: + +=over + +=item C<object> + +The object that C<set> was called on. You will probably want to +do something like C<< if ($object->isa('Some::Class')) >> in your code to +limit your changes to only certain subclasses of Bugzilla::Object. + +=item C<field> + +The name of the field that was updated in the object. + +=back + + =head2 object_end_of_set_all This happens at the end of L<Bugzilla::Object/set_all>. This is a diff --git a/Bugzilla/Object.pm b/Bugzilla/Object.pm index a54cf7caa..e50be1fbf 100644 --- a/Bugzilla/Object.pm +++ b/Bugzilla/Object.pm @@ -306,6 +306,9 @@ sub set { } $self->{$field} = $value; + + Bugzilla::Hook::process('object_end_of_set', + { object => $self, field => $field }); } sub set_all { |