diff --git a/setup.py b/setup.py index e7d6aaf..ed382d9 100644 --- a/setup.py +++ b/setup.py @@ -11,7 +11,8 @@ install_requires = [ - 'wagtail>=2.0b1' # Depends on Wagtail's Django and Django RestFramework depencencies + 'wagtail>=2.0b1', # Depends on Wagtail's Django and Django RestFramework depencencies + 'django-filter>=1.1.0,<2', ] # Testing dependencies diff --git a/wagtailmodelchoosers/views.py b/wagtailmodelchoosers/views.py index 8eb5337..1d57ef0 100644 --- a/wagtailmodelchoosers/views.py +++ b/wagtailmodelchoosers/views.py @@ -1,8 +1,10 @@ import requests from django.apps import apps from django.db.models import CharField, Q -from rest_framework import filters, serializers +from django_filters.rest_framework import DjangoFilterBackend +from rest_framework import serializers from rest_framework.authentication import BasicAuthentication, SessionAuthentication +from rest_framework.filters import SearchFilter from rest_framework.mixins import ListModelMixin from rest_framework.permissions import IsAuthenticated from rest_framework.response import Response @@ -20,7 +22,7 @@ class ModelView(ListModelMixin, GenericViewSet): pagination_class = GenericModelPaginator authentication_classes = (SessionAuthentication, BasicAuthentication) permission_classes = (IsAuthenticated,) - filter_backends = (filters.DjangoFilterBackend, filters.SearchFilter,) + filter_backends = (DjangoFilterBackend, SearchFilter,) def get_params(self): return self.request.parser_context.get('kwargs') @@ -100,7 +102,7 @@ def build_serializer(self, cls, model_name): class RemoteResourceView(ViewSet): authentication_classes = (SessionAuthentication, BasicAuthentication) permission_classes = (IsAuthenticated,) - filter_backends = (filters.DjangoFilterBackend, filters.SearchFilter,) + filter_backends = (DjangoFilterBackend, SearchFilter,) http_method_names = ('get', 'head', 'options') def get_params(self):