]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 521413: Hook: object-end_of_set_all
authormkanat%bugzilla.org <>
Mon, 23 Nov 2009 06:29:13 +0000 (06:29 +0000)
committermkanat%bugzilla.org <>
Mon, 23 Nov 2009 06:29:13 +0000 (06:29 +0000)
Patch by Max Kanat-Alexander <mkanat@bugzilla.org> (module owner) a=mkanat

Bugzilla/Hook.pm
Bugzilla/Object.pm
extensions/example/code/object-end_of_set_all.pl [new file with mode: 0644]

index b35a338d6bf30d4a2789abfe30fd931b1b379725..8a9e95eacac6e7e6c83d2f66a2ce27bcd322eef9 100644 (file)
@@ -671,6 +671,28 @@ validated by the C<VALIDATORS> specified for the object.
 
 =back
 
+=head2 object-end_of_set_all
+
+This happens at the end of L<Bugzilla::Object/set_all>. This is a
+good place to call custom set_ functions on objects, or to make changes
+to an object before C<update()> is called.
+
+Params:
+
+=over
+
+=item C<object>
+
+The L<Bugzilla::Object> which is being updated. 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<params>
+
+A hashref. The set of named parameters passed to C<set_all>.
+
+=back
+
 =head2 page-before_template
 
 This is a simple way to add your own pages to Bugzilla. This hooks C<page.cgi>,
index 0630a78d492af5e5fbb1b55d55d06bf4e6b127ae..05c05f886c9c9d1955879f2267f9d7482342d9b2 100644 (file)
@@ -303,6 +303,8 @@ sub set_all {
         my $method = "set_$key";
         $self->$method($params->{$key});
     }
+    Bugzilla::Hook::process('object-end_of_set_all', { object => $self,
+                                                       params => $params });
 }
 
 sub update {
diff --git a/extensions/example/code/object-end_of_set_all.pl b/extensions/example/code/object-end_of_set_all.pl
new file mode 100644 (file)
index 0000000..d4b6435
--- /dev/null
@@ -0,0 +1,34 @@
+# -*- Mode: perl; indent-tabs-mode: nil -*-
+#
+# The contents of this file are subject to the Mozilla Public
+# License Version 1.1 (the "License"); you may not use this file
+# except in compliance with the License. You may obtain a copy of
+# the License at http://www.mozilla.org/MPL/
+#
+# Software distributed under the License is distributed on an "AS
+# IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+# implied. See the License for the specific language governing
+# rights and limitations under the License.
+#
+# The Original Code is the Bugzilla Example Plugin.
+#
+# The Initial Developer of the Original Code is ITA Software
+# Portions created by the Initial Developer are Copyright (C) 2009 
+# the Initial Developer. All Rights Reserved.
+#
+# Contributor(s): Max Kanat-Alexander <mkanat@bugzilla.org>
+
+use strict;
+use warnings;
+
+my $args = Bugzilla->hook_args;
+my $object = $args->{'class'};
+my $params = $args->{'params'};
+
+# Note that this is a made-up class, for this example.
+if ($object->isa('Bugzilla::ExampleObject')) {
+    if ($params->{example_field} == 1) {
+        $object->{example_field} = 1;
+    }
+}
+