Haystack for Django REST Framework¶
Contents:
About¶
Small library aiming to simplify using Haystack with Django REST Framework
Requirements¶
- A Supported Django install
- Django REST Framework v3.2.0 and later
- Haystack v2.5 and later
- A supported search engine such as Solr, Elasticsearch, Whoosh, etc.
- Python bindings for the chosen backend (see below).
- (geopy and libgeos if you want to use geo spatial filtering)
Python bindings¶
You will also need to install python bindings for the search engine you’ll use.
Elasticsearch¶
See haystack Elasticsearch docs for details
$ pip install elasticsearch<2.0.0 # For Elasticsearch 1.x
$ pip install elasticsearch>=2.0.0,<3.0.0 # For Elasticsearch 2.x
Contributors¶
This library has mainly been written by me while working at Inonit. I have also had some help from these amazing people! Thanks guys!
- See the full list of contributors.
Changelog¶
v1.8.6¶
Release date: 2019-10-13
- Fixed #139. Overriding declared fields must now use
serializers.SerializerMethodField()and are handled by stock DRF. We don’t need any custom functionality for this.- Added support for Django REST Framework v3.10.x
- Dropped Python 2.x support
v1.8.4¶
Release date: 2018-08-15
- Fixed Django2.1 support
- Replaced requirements.txt with Pipfile for development dependencies management
v1.8.3¶
Release date: 2018-06-16
- Fixed issues with
__in=[...]and__range=[...]filters. Closes #128.
v1.8.1¶
Release date: 2018-04-20
- Fixed errors in test suite which caused all tests to run on Elasticsearch 1.x
v1.8.0¶
Release date: 2018-04-16
This release was pulled because of critical errors in the test suite.
- Dropped support for Django v1.10.x and added support for Django v2.0.x
- Updated minimum Django REST Framework requirement to v3.7
- Updated minimum Haystack requirements to v2.8
v1.7.1rc2¶
Release date: 2018-01-30
- Fixes issues with building documentation.
- Fixed some minor typos in documentation.
- Dropped unittest2 in favor of standard lib unittest
v1.7.1rc1¶
Release date: 2018-01-06
- Locked Django versions in order to comply with Haystack requirements.
- Requires development release of Haystack (v2.7.1dev0).
v1.7.0¶
Release date: 2018-01-06 (Removed from pypi due to critical bugs)
- Bumping minimum support for Django to v1.10.
- Bumping minimum support for Django REST Framework to v1.6.0
- Adding support for Elasticsearch 2.x Haystack backend
v1.6.0rc3¶
Release date: 2016-06-29
- Fixed #61. Introduction of custom serializers for serializing faceted objects contained a breaking change.
v1.6.0rc2¶
Release date: 2016-06-28
- Restructured and updated documentation
- Added support for using a custom serializer when serializing faceted objects.
v1.6.0rc1¶
Release date: 2016-06-24
Note
This release include breaking changes to the API
- Dropped support for Python 2.6, Django 1.5, 1.6 and 1.7
- Will follow Haystack’s supported versions
- Removed deprecated
SQHighlighterMixin.- Removed redundant
BaseHaystackGEOSpatialFilter. If name ofindexes.LocationFieldneeds to be changed, subclass theHaystackGEOSpatialFilterdirectly.
- Reworked filters:
- More consistent naming of methods.
- All filters follow the same logic for building and applying filters and exclusions.
- All filter classes use a
QueryBuilderclass for working out validation and building queries which are to be passed to theSearchQuerySet.- Most filters does not inherit from
HaystackFilteranymore (exceptHaystackAutocompleteFilterandHaystackHighlightFilter) and will no longer do basic field filtering. Filters should be properly placed in thefilter_backendsclass attribute in their respective order to be applied. This solves issues where inherited filters responds to query parameters they should ignore.- HaystackFacetSerializer
narrow_urlnow returns an absolute url.- HaystackFacetSerializer now properly serializes
MultiValueFieldandFacetMultiValueFielditems as a JSON Array.HaystackGenericAPIView.get_object()optionalmodelquery parameter now requires aapp_label.modelinstead of just themodel.- Extracted internal fields and serializer from the
HaystackFacetSerializerin order to ease customization.HaystackFacetSerializernow supports all three builtin pagination classes, and a hook to support custom pagination classes.
- Extracted the
more-like-thisdetail route andfacetslist route from the generic HaystackViewSet.
- Support for
more-like-thisis available as adrf_haystack.mixins.MoreLikeThisMixinclass.- Support for
facetsis available as adrf_haystack.mixins.FacetMixinclass.
v1.5.6¶
Release date: 2015-12-02
- Fixed a bug where
ignore_fieldsonHaystackSerializerdid not work unlessexcludeevaluates toTrue.- Removed
elasticsearchfrominstall_requires. Elasticsearch should not be a mandatory requirement, since it’s useless if not using Elasticsearch as backend.
v1.5.5¶
Release date: 2015-10-31
- Added support for Django REST Framework 3.3.0 (Only for Python 2.7/Django 1.7 and above)
- Locked elasticsearch < 2.0.0 (See #29)
v1.5.2¶
Release date: 2015-08-23
- Proper support for Multiple search indexes (Github #22).
- Experimental support for Term Boost (This seems to have some issues upstreams, so unfortunately it does not really work as expected).
- Support for negate in filters.
v1.5.0¶
Release date: 2015-06-29
- Added support for field lookups in queries, such as
field__contains=foobar. Check out Haystack docs for details.- Added default
permission_classesonHaystackGenericAPIViewin order to avoid crash when using global permission classes on REST Framework. See Permissions for details.
v1.4¶
Release date: 2015-06-15
- Fixed issues for Geo spatial filtering on django-haystack v2.4.x with Elasticsearch.
- A serializer class now accepts a list or tuple of
ignore_fieldto bypass serialization.- Added support for Highlighting.
v1.3¶
Release date: 2015-05-19
HaystackGenericAPIView().get_object()now returns Http404 instead of an emptySearchQuerysetif no object is found. This mimics the behaviour fromGenericAPIView().get_object().- Removed hard dependencies for
geopyandlibgeos(See Github #5). This means that if you want to use theHaystackGEOSpatialFilter, you have to install these libraries manually.
v1.2¶
Release date: 2015-03-23
- Fixed
MissingDependencyerror when using another search backend than Elasticsearch.- Fixed converting distance to D object before filtering in HaystackGEOSpatialFilter.
- Added Python 3 classifier.
v1.1¶
Release date: 2015-02-16
- Full coverage (almost) test suite
- Documentation
- Beta release Development classifier