NAME

Data::SearchEngine::Query - Query to pass to an engine.

SYNOPSIS

The query object has some common attributes one would expect when performing a search. It has the added benefit of producing a digest that can be used with Data::SearchEngine::Results ability to serialize to implement caching.

If you add new attributes to a subclass, be sure and add the Digestable trait to any attributes you want to be included in the digest as document in Data::SearchEngine::Meta::Attribute::Trait::Digestable.

ATTRIBUTES

count

The number of results this query should return.

filters

A HashRef of filters used with the query. The key should be the filter name and the value is the filter's value. Consult the documentation for your backend to see how this is used.

order

The order in which the results should be sorted.

original_query

The "original" query that the user searched for. Provided because some backends may need to modify the query attribute to a more palatable form. If no value is provided for this attribute then it will assume the same value as query.

page

Which page of results to show.

query

The query string to search for.

METHODS

digest

Returns a unique digest identifying this Query. Useful as a key when caching.

filter_names

Return an array of filter names that are present in this query.

get_filter

Gets the value for the specified filter.

has_filters

Predicate that returns true if this query has filters.

has_filter_like

Returns true if any of the filter names match the provided subroutine:

$query->set_filter('foo', 'bar');
$query->has_filter_like(sub { /^fo/ })s; # true!

has_query

Returns true if this Query has a query string.

set_filter

Sets the value for the specified filter.

AUTHOR

Cory G Watson, <gphat at cpan.org>

COPYRIGHT & LICENSE

Copyright 2009 Cory G Watson

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.