Commit 7d331618 authored by mkanat%bugzilla.org's avatar mkanat%bugzilla.org

Bug 523762: Prevent the template_before_process hook from causing an infinite…

Bug 523762: Prevent the template_before_process hook from causing an infinite recursion when an error is thrown Patch by Max Kanat-Alexander <mkanat@bugzilla.org> r=dkl, a=mkanat
parent 6ffb51d5
...@@ -25,11 +25,32 @@ use strict; ...@@ -25,11 +25,32 @@ use strict;
sub process { sub process {
my ($name, $args) = @_; my ($name, $args) = @_;
_entering($name);
foreach my $extension (@{ Bugzilla->extensions }) { foreach my $extension (@{ Bugzilla->extensions }) {
if ($extension->can($name)) { if ($extension->can($name)) {
$extension->$name($args); $extension->$name($args);
} }
} }
_leaving($name);
}
sub in {
my $hook_name = shift;
my $currently_in = Bugzilla->request_cache->{hook_stack}->[-1] || '';
return $hook_name eq $currently_in ? 1 : 0;
}
sub _entering {
my ($hook_name) = @_;
my $hook_stack = Bugzilla->request_cache->{hook_stack} ||= [];
push(@$hook_stack, $hook_name);
}
sub _leaving {
pop @{ Bugzilla->request_cache->{hook_stack} };
} }
1; 1;
...@@ -395,6 +416,8 @@ L</config_add_panels> if you want to add new panels. ...@@ -395,6 +416,8 @@ L</config_add_panels> if you want to add new panels.
=head2 enter_bug_entrydefaultvars =head2 enter_bug_entrydefaultvars
B<DEPRECATED> - Use L</template_before_process> instead.
This happens right before the template is loaded on enter_bug.cgi. This happens right before the template is loaded on enter_bug.cgi.
Params: Params:
...@@ -635,6 +658,8 @@ your template. ...@@ -635,6 +658,8 @@ your template.
=head2 product_confirm_delete =head2 product_confirm_delete
B<DEPRECATED> - Use L</template_before_process> instead.
Called before displaying the confirmation message when deleting a product. Called before displaying the confirmation message when deleting a product.
Params: Params:
...@@ -715,6 +740,10 @@ to operating only if a certain file is being loaded (which is why you ...@@ -715,6 +740,10 @@ to operating only if a certain file is being loaded (which is why you
get a C<file> argument below). Otherwise, modifying the C<vars> argument get a C<file> argument below). Otherwise, modifying the C<vars> argument
will affect every single template in Bugzilla. will affect every single template in Bugzilla.
Note that this is only called on the top-level C<< $template->process >>
call. It is not called for C<[% PROCESS %]> or C<[% INCLUDE %]> statements
in templates.
Params: Params:
=over =over
...@@ -738,6 +767,11 @@ The L<Bugzilla::Template> object that C<process> was called on. ...@@ -738,6 +767,11 @@ The L<Bugzilla::Template> object that C<process> was called on.
=back =back
B<Note:> This hook is not called if you are already in this hook.
(That is, it won't call itself recursively.) This prevents infinite
recursion in situations where this hook needs to process a template
(such as if this hook throws an error).
=head2 webservice =head2 webservice
This hook allows you to add your own modules to the WebService. (See This hook allows you to add your own modules to the WebService. (See
......
...@@ -86,9 +86,15 @@ sub process { ...@@ -86,9 +86,15 @@ sub process {
my $self = shift; my $self = shift;
my ($file, $vars) = @_; my ($file, $vars) = @_;
#Bugzilla::Hook::process('template_before_process', # This hook can't call itself recursively, because otherwise we
# { vars => $vars, file => $file, # end up with problems when we throw an error inside of extensions
# template => $self }); # (they end up in infinite recursion, because throwing an error involves
# processing a template).
if (!Bugzilla::Hook::in('template_before_process')) {
Bugzilla::Hook::process('template_before_process',
{ vars => $vars, file => $file,
template => $self });
}
return $self->SUPER::process(@_); return $self->SUPER::process(@_);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment