Skip to content

Commit

Permalink
search: possibility to specify a different query_parser
Browse files Browse the repository at this point in the history
  • Loading branch information
psaiz authored and ntarocco committed Dec 8, 2023
1 parent 8735be8 commit e9bcb74
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 1 deletion.
12 changes: 12 additions & 0 deletions invenio_records_rest/config.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ def _(x):
search_class=RecordsSearch,
indexer_class=RecordIndexer,
search_index=None,
search_query_parser=None,
record_serializers={
"application/json": (
"invenio_records_rest.serializers" ":json_v1_response"
Expand Down Expand Up @@ -80,6 +81,12 @@ def deleted_pid_error_handler(error):
'message': error.description,
'removal_reason': record.get('removal_reason')}), 410)
def query_parser_with_and(qstr=None):
if qstr:
return dsl.Q("query_string", query=qstr, default_operator="AND")
return dsl.Q()
RECORDS_REST_ENDPOINTS = {
'endpoint-prefix': {
'create_permission_factory_imp': permission_check_factory(),
Expand Down Expand Up @@ -110,6 +117,7 @@ def deleted_pid_error_handler(error):
'search_class': 'mypackage.utils:mysearchclass',
'search_factory_imp': search_factory(),
'search_index': 'search-index-name',
'search_query_parser': query_parser_with_and,
'search_serializers': {
'application/json': 'mypackage.utils:my_json_search_serializer'
},
Expand Down Expand Up @@ -193,6 +201,10 @@ def deleted_pid_error_handler(error):
:param search_index: Name of the search index used when searching records.
:param search_query_parser: Name of the function that will be used to parse the
query. The default parser does an 'OR' of all the terms that have been
specified. This could be used to do, as an example, and 'AND' of the terms.
:param search_serializers: It contains the list of records serializers for all
supported format. This configuration differ from the previous because in
this case it handle a list of records resulted by a search query instead of
Expand Down
7 changes: 6 additions & 1 deletion invenio_records_rest/views.py
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,7 @@ def create_url_rules(
links_factory_imp=None,
suggesters=None,
default_endpoint_prefix=None,
search_query_parser=None,
):
"""Create Werkzeug URL rules.
Expand Down Expand Up @@ -254,6 +255,7 @@ def create_url_rules(
:param search_factory_imp: Factory to parse queries.
:param links_factory_imp: Factory for record links generation.
:param suggesters: Suggester fields configuration.
:param search_query_parser: Function that implements the query parser
:returns: a list of dictionaries with can each be passed as keywords
arguments to ``Blueprint.add_url_rule``.
Expand Down Expand Up @@ -325,6 +327,7 @@ def links_factory(pid, record=None, **kwargs):
),
item_links_factory=links_factory,
record_class=record_class,
search_query_parser=search_query_parser,
)
item_view = RecordResource.as_view(
RecordResource.view_name.format(endpoint),
Expand Down Expand Up @@ -591,6 +594,7 @@ def __init__(
item_links_factory=None,
record_class=None,
indexer_class=None,
search_query_parser=None,
**kwargs
):
"""Constructor."""
Expand Down Expand Up @@ -623,6 +627,7 @@ def __init__(
self.loaders = record_loaders or current_records_rest.loaders
self.record_class = record_class or Record
self.indexer_class = indexer_class
self.search_query_parser = search_query_parser

@need_record_permission("list_permission_factory")
@use_paginate_args(
Expand All @@ -647,7 +652,7 @@ def get(self, pagination=None, **kwargs):
search = search[pagination["from_idx"] : pagination["to_idx"]]
search = search.extra(track_total_hits=True)

search, qs_kwargs = self.search_factory(search)
search, qs_kwargs = self.search_factory(search, self.search_query_parser)
urlkwargs.update(qs_kwargs)

# Execute search
Expand Down

0 comments on commit e9bcb74

Please sign in to comment.