diff options
| author | Jamie Matthews | 2012-01-05 14:07:31 +0000 | 
|---|---|---|
| committer | Jamie Matthews | 2012-01-05 14:07:31 +0000 | 
| commit | 18535c7a387731b0e290ff59bb604bfd1a275ccc (patch) | |
| tree | 0c0aeefd5c12b065f13ec3a58f8a79092de8c422 | |
| parent | b745d0c2f46b901ed7a6b8e92d4ea3faf2a47736 (diff) | |
| download | django-rest-framework-18535c7a387731b0e290ff59bb604bfd1a275ccc.tar.bz2 | |
Preserve existing query params in PaginatorMixin
Previously, generation of next/previous links would discard any existing
query parameters. This commit introduces a dependency on URLObject, which
is used to intelligently parse and modify URLs to ensure existing params
are preserved.
Addresses issues #107
| -rw-r--r-- | djangorestframework/mixins.py | 6 | ||||
| -rw-r--r-- | djangorestframework/tests/mixins.py | 11 | ||||
| -rw-r--r-- | requirements.txt | 1 | ||||
| -rw-r--r-- | setup.py | 1 | 
4 files changed, 17 insertions, 2 deletions
| diff --git a/djangorestframework/mixins.py b/djangorestframework/mixins.py index b1a634a0..e01de3fc 100644 --- a/djangorestframework/mixins.py +++ b/djangorestframework/mixins.py @@ -7,6 +7,7 @@ from django.contrib.auth.models import AnonymousUser  from django.core.paginator import Paginator  from django.db.models.fields.related import ForeignKey  from django.http import HttpResponse +from urlobject import URLObject  from djangorestframework import status  from djangorestframework.renderers import BaseRenderer @@ -659,11 +660,12 @@ class PaginatorMixin(object):      def url_with_page_number(self, page_number):          """ Constructs a url used for getting the next/previous urls """ -        url = "%s?page=%d" % (self.request.path, page_number) +        url = URLObject.parse(self.request.get_full_path()) +        url = url.add_query_param('page', page_number)          limit = self.get_limit()          if limit != self.limit: -            url = "%s&limit=%d" % (url, limit) +            url = url.add_query_param('limit', limit)          return url diff --git a/djangorestframework/tests/mixins.py b/djangorestframework/tests/mixins.py index 3b814aa7..2913160d 100644 --- a/djangorestframework/tests/mixins.py +++ b/djangorestframework/tests/mixins.py @@ -237,3 +237,14 @@ class TestPagination(TestCase):          response = MockPaginatorView.as_view()(request)          content = json.loads(response.content)          self.assertEqual(response.status_code, status.NOT_FOUND) + +    def test_existing_query_parameters_are_preserved(self): +        """ Tests that existing query parameters are preserved when +        generating next/previous page links """ +        request = self.req.get('/paginator/?foo=bar&another=something') +        response = MockPaginatorView.as_view()(request) +        content = json.loads(response.content) +        self.assertEqual(response.status_code, status.OK) +        self.assertTrue('foo=bar' in content['next']) +        self.assertTrue('another=something' in content['next']) +        self.assertTrue('page=2' in content['next']) diff --git a/requirements.txt b/requirements.txt index 2b54c95b..56926c0f 100644 --- a/requirements.txt +++ b/requirements.txt @@ -3,3 +3,4 @@  Django>=1.2  coverage>=3.4 +URLObject>=0.6.0 @@ -26,6 +26,7 @@ setup(      package_dir={'djangorestframework': 'djangorestframework'},      package_data = {'djangorestframework': ['templates/*', 'static/*']},      test_suite = 'djangorestframework.runtests.runcoverage.main', +    install_requires=['URLObject>=0.6.0'],      classifiers = [          'Development Status :: 4 - Beta',          'Environment :: Web Environment', | 
