aboutsummaryrefslogtreecommitdiffstats
path: root/rest_framework/reverse.py
diff options
context:
space:
mode:
authorBrandon Cazander2015-01-28 17:08:34 -0800
committerBrandon Cazander2015-02-02 20:37:33 -0800
commit77d061d234e03004f34058028707ecddfc730fae (patch)
treeb67e2414ba475a2122cb46dcd737b1a39b92911e /rest_framework/reverse.py
parente63f49bd1d55501f766ca2e3f9c0c9fa3cfa19ab (diff)
downloaddjango-rest-framework-77d061d234e03004f34058028707ecddfc730fae.tar.bz2
Provide rest_framework.resolve. Fixes #2489
Diffstat (limited to 'rest_framework/reverse.py')
-rw-r--r--rest_framework/reverse.py15
1 files changed, 14 insertions, 1 deletions
diff --git a/rest_framework/reverse.py b/rest_framework/reverse.py
index 8fcca55b..0d1d94a7 100644
--- a/rest_framework/reverse.py
+++ b/rest_framework/reverse.py
@@ -1,12 +1,25 @@
"""
-Provide reverse functions that return fully qualified URLs
+Provide urlresolver functions that return fully qualified URLs or view names
"""
from __future__ import unicode_literals
from django.core.urlresolvers import reverse as django_reverse
+from django.core.urlresolvers import resolve as django_resolve
from django.utils import six
from django.utils.functional import lazy
+def resolve(path, urlconf=None, request=None):
+ """
+ If versioning is being used then we pass any `resolve` calls through
+ to the versioning scheme instance, so that the resulting view name
+ can be modified if needed.
+ """
+ scheme = getattr(request, 'versioning_scheme', None)
+ if scheme is not None:
+ return scheme.resolve(path, urlconf, request)
+ return django_resolve(path, urlconf)
+
+
def reverse(viewname, args=None, kwargs=None, request=None, format=None, **extra):
"""
If versioning is being used then we pass any `reverse` calls through