2013-07-29 21:50:58 +08:00
|
|
|
from importlib import import_module
|
2014-04-02 08:46:34 +08:00
|
|
|
import warnings
|
2013-07-29 21:50:58 +08:00
|
|
|
|
2011-09-12 06:36:16 +08:00
|
|
|
from django.core.urlresolvers import (RegexURLPattern,
|
|
|
|
RegexURLResolver, LocaleRegexURLResolver)
|
|
|
|
from django.core.exceptions import ImproperlyConfigured
|
2012-07-20 20:22:00 +08:00
|
|
|
from django.utils import six
|
2015-05-28 23:25:52 +08:00
|
|
|
from django.utils.deprecation import RemovedInDjango20Warning, RemovedInDjango21Warning
|
2011-09-12 06:36:16 +08:00
|
|
|
|
|
|
|
|
2013-05-16 07:14:28 +08:00
|
|
|
__all__ = ['handler400', 'handler403', 'handler404', 'handler500', 'include', 'patterns', 'url']
|
2011-09-12 06:36:16 +08:00
|
|
|
|
2013-05-16 07:14:28 +08:00
|
|
|
handler400 = 'django.views.defaults.bad_request'
|
2011-09-12 06:36:16 +08:00
|
|
|
handler403 = 'django.views.defaults.permission_denied'
|
|
|
|
handler404 = 'django.views.defaults.page_not_found'
|
|
|
|
handler500 = 'django.views.defaults.server_error'
|
|
|
|
|
2013-10-31 23:42:28 +08:00
|
|
|
|
2011-09-12 06:36:16 +08:00
|
|
|
def include(arg, namespace=None, app_name=None):
|
2015-02-09 02:44:07 +08:00
|
|
|
if app_name and not namespace:
|
|
|
|
raise ValueError('Must specify a namespace if specifying app_name.')
|
2015-05-28 23:25:52 +08:00
|
|
|
if app_name:
|
|
|
|
warnings.warn(
|
|
|
|
'The app_name argument to django.conf.urls.include() is deprecated. '
|
|
|
|
'Set the app_name in the included URLconf instead.',
|
|
|
|
RemovedInDjango21Warning, stacklevel=2
|
|
|
|
)
|
2015-02-09 02:44:07 +08:00
|
|
|
|
2011-09-12 06:36:16 +08:00
|
|
|
if isinstance(arg, tuple):
|
|
|
|
# callable returning a namespace hint
|
2015-05-28 23:25:52 +08:00
|
|
|
try:
|
|
|
|
urlconf_module, app_name = arg
|
|
|
|
except ValueError:
|
|
|
|
if namespace:
|
|
|
|
raise ImproperlyConfigured(
|
|
|
|
'Cannot override the namespace for a dynamic module that provides a namespace'
|
|
|
|
)
|
|
|
|
warnings.warn(
|
|
|
|
'Passing a 3-tuple to django.conf.urls.include() is deprecated. '
|
|
|
|
'Pass a 2-tuple containing the list of patterns and app_name, '
|
|
|
|
'and provide the namespace argument to include() instead.',
|
|
|
|
RemovedInDjango21Warning, stacklevel=2
|
|
|
|
)
|
|
|
|
urlconf_module, app_name, namespace = arg
|
2011-09-12 06:36:16 +08:00
|
|
|
else:
|
|
|
|
# No namespace hint - use manually provided namespace
|
|
|
|
urlconf_module = arg
|
|
|
|
|
2012-07-20 20:22:00 +08:00
|
|
|
if isinstance(urlconf_module, six.string_types):
|
2011-09-12 06:36:16 +08:00
|
|
|
urlconf_module = import_module(urlconf_module)
|
|
|
|
patterns = getattr(urlconf_module, 'urlpatterns', urlconf_module)
|
2015-05-28 23:25:52 +08:00
|
|
|
app_name = getattr(urlconf_module, 'app_name', app_name)
|
|
|
|
if namespace and not app_name:
|
|
|
|
warnings.warn(
|
|
|
|
'Specifying a namespace in django.conf.urls.include() without '
|
|
|
|
'providing an app_name is deprecated. Set the app_name attribute '
|
|
|
|
'in the included module, or pass a 2-tuple containing the list of '
|
|
|
|
'patterns and app_name instead.',
|
|
|
|
RemovedInDjango21Warning, stacklevel=2
|
|
|
|
)
|
|
|
|
|
|
|
|
namespace = namespace or app_name
|
2011-09-12 06:36:16 +08:00
|
|
|
|
|
|
|
# Make sure we can iterate through the patterns (without this, some
|
|
|
|
# testcases will break).
|
|
|
|
if isinstance(patterns, (list, tuple)):
|
|
|
|
for url_pattern in patterns:
|
|
|
|
# Test if the LocaleRegexURLResolver is used within the include;
|
|
|
|
# this should throw an error since this is not allowed!
|
|
|
|
if isinstance(url_pattern, LocaleRegexURLResolver):
|
|
|
|
raise ImproperlyConfigured(
|
|
|
|
'Using i18n_patterns in an included URLconf is not allowed.')
|
|
|
|
|
|
|
|
return (urlconf_module, app_name, namespace)
|
|
|
|
|
2013-10-31 23:42:28 +08:00
|
|
|
|
2011-09-12 06:36:16 +08:00
|
|
|
def patterns(prefix, *args):
|
2014-04-02 08:46:34 +08:00
|
|
|
warnings.warn(
|
|
|
|
'django.conf.urls.patterns() is deprecated and will be removed in '
|
|
|
|
'Django 2.0. Update your urlpatterns to be a list of '
|
|
|
|
'django.conf.urls.url() instances instead.',
|
|
|
|
RemovedInDjango20Warning, stacklevel=2
|
|
|
|
)
|
2011-09-12 06:36:16 +08:00
|
|
|
pattern_list = []
|
|
|
|
for t in args:
|
|
|
|
if isinstance(t, (list, tuple)):
|
|
|
|
t = url(prefix=prefix, *t)
|
|
|
|
elif isinstance(t, RegexURLPattern):
|
|
|
|
t.add_prefix(prefix)
|
|
|
|
pattern_list.append(t)
|
|
|
|
return pattern_list
|
|
|
|
|
2013-10-31 23:42:28 +08:00
|
|
|
|
2011-09-12 06:36:16 +08:00
|
|
|
def url(regex, view, kwargs=None, name=None, prefix=''):
|
2013-10-25 01:30:03 +08:00
|
|
|
if isinstance(view, (list, tuple)):
|
2011-09-12 06:36:16 +08:00
|
|
|
# For include(...) processing.
|
|
|
|
urlconf_module, app_name, namespace = view
|
|
|
|
return RegexURLResolver(regex, urlconf_module, kwargs, app_name=app_name, namespace=namespace)
|
|
|
|
else:
|
2012-07-20 20:22:00 +08:00
|
|
|
if isinstance(view, six.string_types):
|
2014-08-12 22:54:42 +08:00
|
|
|
warnings.warn(
|
|
|
|
'Support for string view arguments to url() is deprecated and '
|
|
|
|
'will be removed in Django 2.0 (got %s). Pass the callable '
|
|
|
|
'instead.' % view,
|
|
|
|
RemovedInDjango20Warning, stacklevel=2
|
|
|
|
)
|
2011-09-12 06:36:16 +08:00
|
|
|
if not view:
|
|
|
|
raise ImproperlyConfigured('Empty URL pattern view name not permitted (for pattern %r)' % regex)
|
|
|
|
if prefix:
|
|
|
|
view = prefix + '.' + view
|
|
|
|
return RegexURLPattern(regex, view, kwargs, name)
|