diff options
author | Dylan William Hardison <dylan@hardison.net> | 2017-03-17 21:53:57 +0100 |
---|---|---|
committer | Dylan William Hardison <dylan@hardison.net> | 2017-03-17 21:53:57 +0100 |
commit | 1ad85fd04a2268a660fbf35068e730dda917d137 (patch) | |
tree | 3155f5d6d82532810cb653fa04b7e466199f7e71 /Bugzilla/Elastic.pm | |
parent | 4cc54c4c9acd39b1b0850c9d5a937f5f909d18d0 (diff) | |
download | bugzilla-1ad85fd04a2268a660fbf35068e730dda917d137.tar.gz bugzilla-1ad85fd04a2268a660fbf35068e730dda917d137.tar.xz |
Bug 1307485 - Add code to run a subset of buglist.cgi search queries against the ES backend
This not the cause of test failures, so should live on in master now.
Diffstat (limited to 'Bugzilla/Elastic.pm')
-rw-r--r-- | Bugzilla/Elastic.pm | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/Bugzilla/Elastic.pm b/Bugzilla/Elastic.pm new file mode 100644 index 000000000..6384269fd --- /dev/null +++ b/Bugzilla/Elastic.pm @@ -0,0 +1,47 @@ +# This Source Code Form is subject to the terms of the Mozilla Public +# License, v. 2.0. If a copy of the MPL was not distributed with this +# file, You can obtain one at http://mozilla.org/MPL/2.0/. +# +# This Source Code Form is "Incompatible With Secondary Licenses", as +# defined by the Mozilla Public License, v. 2.0. +package Bugzilla::Elastic; +use 5.10.1; +use Moo; + +use Bugzilla::Elastic::Search; +use Bugzilla::Util qw(trick_taint); + +with 'Bugzilla::Elastic::Role::HasClient'; +with 'Bugzilla::Elastic::Role::HasIndexName'; + +sub suggest_users { + my ($self, $text) = @_; + my $field = 'suggest_user'; + if ($text =~ /^:(.+)$/) { + $text = $1; + $field = 'suggest_nick'; + } + + my $result = eval { + $self->client->suggest( + index => $self->index_name, + body => { + $field => { + text => $text, + completion => { field => $field, size => 25 }, + } + } + ); + }; + if (defined $result) { + return [ map { $_->{payload} } @{$result->{$field}[0]{options}} ]; + } + else { + warn "suggest_users error: $@"; + my $users = Bugzilla::User::match($text, 25, 0); + return [ map { { real_name => $_->name, name => $_->login } } @$users]; + } +} + + +1; |