Allow multiple views to match the same URL.
Project description
django-multiurl
Have you ever wanted multiple views to match to the same URL? Now you can.
You may once have tried something like this::
urlpatterns = [
url('/app/(\w+)/$', app.views.people),
url('/app/(\w+)/$', app.views.place),
]
However, if you try this, /app/san-francisco/
will only map to
app.views.people
. Raising an Http404
from app.views.people
doesn't
help: you only get a 404 in the browser because Django stops resolving
URLs at the first match.
Well, django-multiurl
solves this problem. Just
pip install django-multiurl
, then do this::
from multiurl import multiurl
urlpatterns = [
multiurl(
url('/app/(\w+)/$', app.views.people),
url('/app/(\w+)/$', app.views.place),
)
]
Now in your views, raise multiurl.ContinueResolving
anywhere you'd like
to break out of the view and keep resolving. For example, here's what
app.views.people
might look like::
from multiurl import ContinueResolving
def people(request, name):
try:
person = Person.objects.get(name=name)
except Person.DoesNotExist:
raise ContinueResolving
return render(...)
That's it! ContinueResolving
will cause multiurl
to continue onto the
next view (app.views.place
, in this example).
A few notes to round things out:
-
If you don't want to use
ContinueResolving
-- perhaps you'd rather continue usingget_object_or_404
, or you're using third-party views that you can't modify to raiseContinueResolving
, you can pass acatch
argument intomultiurl
to control which exceptions are considered "continue" statements. For example, to allowHttp404
exceptions to continue resolving, do this::urlpatterns = [ multiurl( url('/app/(\w+)/$', app.views.people), url('/app/(\w+)/$', app.views.place), catch = (Http404, ContinueResolving) ) ]
As you can see,
catch
should be a tuple of exceptions. It's probably a good idea to always includeContinueResolving
in the tuple. -
If the last view in a
multiurl
raisesContinueResolving
(or another "continuing" exception), a 404 will be raised instead. That is, if resolving "falls off the end" of some multi-urls, you'll get the 404 you expect. -
Reverse URL resolution just works as expected. Name your sub-URLs and then reverse your heart out.
Contributing
Development takes place
on GitHub <http://github.com/jacobian/django-multiurl>
; pull requests are
welcome. Run tests with tox <http://tox.readthedocs.org/>
.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for django_multiurl-1.5.1a0-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | a5ae6c47ad0d49c29f95df21d176619276028fe06e43f5b73f68553f00d97e96 |
|
MD5 | 9a45ad1573ff114a8eb5fb528853bb04 |
|
BLAKE2b-256 | b7dadbded9cbb0fee6d52573ffb76d51da9d1b681090973ebbe36f0ef3c89d26 |