NAME

Elastic::Model::SearchBuilder - An Elastic::Model specific subclass of ElasticSearch::SearchBuilder

VERSION

version 0.50

DESCRIPTION

Elastic::Model::SearchBuilder is a sub-class of ElasticSearch::SearchBuilder to add automatic handling of Elastic::Doc and Elastic::Model::UID values.

This document just explains the functionality that Elastic::Model::SearchBuilder adds.

For the full SearchBuilder docs, see ElasticSearch::SearchBuilder.

THE PROBLEM

Consider this class (where MyApp::User is also an Elastic::Doc class):

package MyApp::Comment;

use Elastic::Doc;

has 'user' => (
    is     => 'ro',
    isa    => 'MyApp::User,
);

has 'text' => (
    is     => 'ro',
    isa    => 'Str',
);

We can create a comment as follows:

$domain->create(
    comment => {
        text => 'I like Elastic::Model',
        user => $user,
    }
);

The comment object would be stored in Elasticsearch as something like this:

{
    text    => "I like Elastic::Model",
    user    => {
        uid => {
            index   => 'myapp',
            type    => 'user',
            id      => 'abcdefg',
        },
        .... any other user fields....
    }
}

In order to search for any comments by user $user, you would need to do this:

$view->type('comment')
     ->filterb(
            'user.uid.index' => $user->uid->index,
            'user.uid.type'  => $user->uid->type,
            'user.uid.id'    => $user->uid->id,
       )
     ->search;

THE SOLUTION

With Elastic::Model::SearchBuilder, you can do it as follows:

$view->type('comment')
     ->filterb( user => $user )
     ->search;

Or with the UID:

$view->type('comment')
     ->filterb( user => $user->uid )
     ->search;

FURTHER EXAMPLES

Query or Filter

This works for both queries and filters, eg:

$view->queryb ( user => $user )->search;
$view->filterb( user => $user )->search;

Doc or UID

You can use either the doc/object itself, or an Elastic::Model::UID object:

$uid = $user->uid;
$view->queryb ( user => $uid )->search;
$view->filterb( user => $uid )->search;

Negating queries:

$view->queryb ( user => { '!=' => $user })->search;
$view->filterb( user => { '!=' => $user })->search;

"IN" queries

$view->queryb ( user => \@users )->search;
$view->filterb( user => \@users )->search;

"NOT IN" queries

$view->queryb ( user => { '!=' => \@users })->search;
$view->filterb( user => { '!=' => \@users })->search;

AUTHOR

Clinton Gormley <drtech@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Clinton Gormley.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.