aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Bugzilla/Hook.pm15
-rw-r--r--Bugzilla/Search/Quicksearch.pm2
-rw-r--r--extensions/Example/Extension.pm8
3 files changed, 25 insertions, 0 deletions
diff --git a/Bugzilla/Hook.pm b/Bugzilla/Hook.pm
index de46f9a25..cf81e9c7d 100644
--- a/Bugzilla/Hook.pm
+++ b/Bugzilla/Hook.pm
@@ -1136,6 +1136,21 @@ Params:
=back
+=head2 quicksearch_map
+
+This hook allows you to alter the Quicksearch syntax to include e.g. special
+searches for custom fields you have.
+
+Params:
+
+=over
+
+=item C<map> - a hash where the key is the name you want to use in
+Quicksearch, and the value is the name from the C<fielddefs> table that you
+want it to map to. You can modify existing mappings or add new ones.
+
+=back
+
=head2 sanitycheck_check
This hook allows for extra sanity checks to be added, for use by
diff --git a/Bugzilla/Search/Quicksearch.pm b/Bugzilla/Search/Quicksearch.pm
index b2151ba3a..340421bbb 100644
--- a/Bugzilla/Search/Quicksearch.pm
+++ b/Bugzilla/Search/Quicksearch.pm
@@ -101,6 +101,8 @@ sub FIELD_MAP {
status_whiteboard
cclist_accessible reporter_accessible)};
+ Bugzilla::Hook::process('quicksearch_map', {'map' => \%full_map} );
+
$cache->{quicksearch_fields} = \%full_map;
return $cache->{quicksearch_fields};
diff --git a/extensions/Example/Extension.pm b/extensions/Example/Extension.pm
index 14bf6df87..f56416559 100644
--- a/extensions/Example/Extension.pm
+++ b/extensions/Example/Extension.pm
@@ -649,6 +649,14 @@ sub product_end_of_create {
}
}
+sub quicksearch_map {
+ my ($self, $args) = @_;
+ my $map = $args->{'map'};
+
+ # This demonstrates adding a shorter alias for a long custom field name.
+ $map->{'impact'} = $map->{'cf_long_field_name_for_impact_field'};
+}
+
sub sanitycheck_check {
my ($self, $args) = @_;