2017-09-02 19:08:23 -04:00
|
|
|
============================================
|
|
|
|
Django 2.1 release notes - UNDER DEVELOPMENT
|
|
|
|
============================================
|
|
|
|
|
|
|
|
Welcome to Django 2.1!
|
|
|
|
|
|
|
|
These release notes cover the :ref:`new features <whats-new-2.1>`, as well as
|
|
|
|
some :ref:`backwards incompatible changes <backwards-incompatible-2.1>` you'll
|
|
|
|
want to be aware of when upgrading from Django 2.0 or earlier. We've
|
|
|
|
:ref:`dropped some features<removed-features-2.1>` that have reached the end of
|
|
|
|
their deprecation cycle, and we've :ref:`begun the deprecation process for some
|
|
|
|
features <deprecated-features-2.1>`.
|
|
|
|
|
|
|
|
See the :doc:`/howto/upgrade-version` guide if you're updating an existing
|
|
|
|
project.
|
|
|
|
|
|
|
|
Python compatibility
|
|
|
|
====================
|
|
|
|
|
|
|
|
Django 2.1 supports Python 3.5, 3.6, and 3.7. Django 2.0 is the last version to
|
|
|
|
support Python 3.4. We **highly recommend** and only officially support the
|
|
|
|
latest release of each series.
|
|
|
|
|
|
|
|
.. _whats-new-2.1:
|
|
|
|
|
|
|
|
What's new in Django 2.1
|
|
|
|
========================
|
|
|
|
|
|
|
|
Minor features
|
|
|
|
--------------
|
|
|
|
|
|
|
|
:mod:`django.contrib.admin`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2017-07-05 13:00:10 +02:00
|
|
|
* :attr:`.ModelAdmin.search_fields` now accepts any lookup such as
|
|
|
|
``field__exact``.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2017-12-21 15:07:17 -05:00
|
|
|
* jQuery is upgraded from version 2.2.3 to 3.2.1.
|
|
|
|
|
2017-09-04 12:24:34 +03:00
|
|
|
* The new :meth:`.ModelAdmin.delete_queryset` method allows customizing the
|
|
|
|
deletion process of the "delete selected objects" action.
|
|
|
|
|
2016-12-29 18:51:26 +01:00
|
|
|
* You can now :ref:`override the the default admin site
|
|
|
|
<overriding-default-admin-site>`.
|
|
|
|
|
2016-02-09 02:35:03 +02:00
|
|
|
* The new :attr:`.ModelAdmin.sortable_by` attribute and
|
|
|
|
:meth:`.ModelAdmin.get_sortable_by` method allow limiting the columns that
|
|
|
|
can be sorted in the change list page.
|
|
|
|
|
2018-02-16 03:00:31 +01:00
|
|
|
* The ``admin_order_field`` attribute for elements in
|
|
|
|
:attr:`.ModelAdmin.list_display` may now be a query expression.
|
|
|
|
|
2017-03-30 10:13:15 +01:00
|
|
|
* The new :meth:`.ModelAdmin.get_deleted_objects()` method allows customizing
|
|
|
|
the deletion process of the delete view and the "delete selected" action.
|
2017-01-12 17:06:00 +01:00
|
|
|
|
2018-02-28 06:55:52 -05:00
|
|
|
* The ``actions.html``, ``change_list_results.html``, ``date_hierarchy.html``,
|
|
|
|
``pagination.html``, ``prepopulated_fields_js.html``, ``search_form.html``,
|
|
|
|
and ``submit_line.html`` templates can now be :ref:`overridden per app or
|
|
|
|
per model <admin-templates-overridden-per-app-or-model>` (besides overridden
|
|
|
|
globally).
|
|
|
|
|
|
|
|
* The admin change list and change form object tools can now be :ref:`overridden
|
|
|
|
per app, per model, or globally <admin-templates-overridden-per-app-or-model>`
|
|
|
|
with ``change_list_object_tools.html`` and
|
2017-01-12 17:06:00 +01:00
|
|
|
``change_form_object_tools.html`` templates.
|
2017-03-30 10:13:15 +01:00
|
|
|
|
2018-02-21 19:11:50 -08:00
|
|
|
* :meth:`.InlineModelAdmin.has_add_permission` is now passed the parent object
|
|
|
|
as the second positional argument, ``obj``.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
:mod:`django.contrib.admindocs`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.auth`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2017-09-09 18:06:20 +01:00
|
|
|
* :djadmin:`createsuperuser` now gives a prompt to allow bypassing the
|
|
|
|
:setting:`AUTH_PASSWORD_VALIDATORS` checks.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2017-11-15 20:27:53 +08:00
|
|
|
* :class:`~django.contrib.auth.forms.UserCreationForm` and
|
|
|
|
:class:`~django.contrib.auth.forms.UserChangeForm` no longer need to be
|
|
|
|
rewritten for a custom user model.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
:mod:`django.contrib.contenttypes`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.gis`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2018-01-09 19:15:04 +03:00
|
|
|
* The new :meth:`.GEOSGeometry.buffer_with_style` method is a version of
|
|
|
|
:meth:`~.GEOSGeometry.buffer` that allows customizing the style of the
|
|
|
|
buffer.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
:mod:`django.contrib.messages`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.postgres`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.redirects`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sessions`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2018-04-13 20:58:31 -04:00
|
|
|
* Added the :setting:`SESSION_COOKIE_SAMESITE` setting to set the ``SameSite``
|
|
|
|
cookie flag on session cookies.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
:mod:`django.contrib.sitemaps`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.sites`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.staticfiles`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
:mod:`django.contrib.syndication`
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Cache
|
|
|
|
~~~~~
|
|
|
|
|
2018-01-24 09:26:19 -08:00
|
|
|
* The :ref:`local-memory cache backend <local-memory-caching>` now uses a
|
|
|
|
least-recently-used (LRU) culling strategy rather than a pseudo-random one.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
CSRF
|
|
|
|
~~~~
|
|
|
|
|
2018-04-13 20:58:31 -04:00
|
|
|
* Added the :setting:`CSRF_COOKIE_SAMESITE` setting to set the ``SameSite``
|
|
|
|
cookie flag on CSRF cookies.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
Database backends
|
|
|
|
~~~~~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Email
|
|
|
|
~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
File Storage
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
File Uploads
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
|
|
|
|
Forms
|
|
|
|
~~~~~
|
|
|
|
|
2018-04-03 12:06:08 +09:00
|
|
|
* The widget for ``ImageField`` now renders with the HTML attribute
|
|
|
|
``accept="image/*"``.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
Generic Views
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Internationalization
|
|
|
|
~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2017-06-27 16:50:26 -07:00
|
|
|
* Added the :meth:`~django.utils.translation.get_supported_language_variant`
|
|
|
|
function.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2018-02-19 19:09:33 +01:00
|
|
|
* Untranslated strings for territorial language variants now use the
|
|
|
|
translations of the generic language. For example, untranslated ``pt_BR``
|
|
|
|
strings use ``pt`` translations.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
Management Commands
|
|
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2018-01-09 16:04:56 +00:00
|
|
|
* The new :option:`inspectdb --include-views` option allows creating models
|
|
|
|
for database views.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
Migrations
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
2017-12-01 19:24:56 +05:00
|
|
|
* Added support for serialization of ``functools.partialmethod`` objects.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2018-03-15 15:32:56 -04:00
|
|
|
* To support frozen environments, migrations may be loaded from ``.pyc`` files.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
Models
|
|
|
|
~~~~~~
|
|
|
|
|
2017-10-13 21:29:00 -04:00
|
|
|
* Models can now use ``__init_subclass__()`` from :pep:`487`.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2017-12-18 21:19:57 +01:00
|
|
|
* A ``BinaryField`` may now be set to ``editable=True`` if you wish to include
|
|
|
|
it in model forms.
|
|
|
|
|
2018-02-23 09:23:22 -06:00
|
|
|
* A number of new text database functions are added:
|
|
|
|
:class:`~django.db.models.functions.Chr`,
|
|
|
|
:class:`~django.db.models.functions.Left`,
|
2018-03-19 17:35:16 +01:00
|
|
|
:class:`~django.db.models.functions.LPad`,
|
2018-03-15 20:57:23 +01:00
|
|
|
:class:`~django.db.models.functions.LTrim`,
|
|
|
|
:class:`~django.db.models.functions.Ord`,
|
2018-04-03 19:36:12 +02:00
|
|
|
:class:`~django.db.models.functions.Repeat`,
|
2018-03-15 20:57:23 +01:00
|
|
|
:class:`~django.db.models.functions.Replace`,
|
|
|
|
:class:`~django.db.models.functions.Right`,
|
2018-03-19 17:35:16 +01:00
|
|
|
:class:`~django.db.models.functions.RPad`,
|
2018-03-15 20:57:23 +01:00
|
|
|
:class:`~django.db.models.functions.RTrim`, and
|
|
|
|
:class:`~django.db.models.functions.Trim`.
|
2018-01-18 02:46:15 +01:00
|
|
|
|
2017-09-28 22:39:03 +02:00
|
|
|
* The new :class:`~django.db.models.functions.TruncWeek` function truncates
|
|
|
|
:class:`~django.db.models.DateField` and
|
|
|
|
:class:`~django.db.models.DateTimeField` to the Monday of a week.
|
|
|
|
|
2018-01-28 15:57:15 +05:30
|
|
|
* Query expressions can now be negated using a minus sign.
|
|
|
|
|
2017-06-18 16:53:40 +01:00
|
|
|
* :meth:`.QuerySet.order_by` and :meth:`distinct(*fields) <.QuerySet.distinct>`
|
|
|
|
now support using field transforms.
|
|
|
|
|
2017-05-06 10:56:28 -04:00
|
|
|
* :class:`~django.db.models.BooleanField` can now be ``null=True``. This is
|
|
|
|
encouraged instead of :class:`~django.db.models.NullBooleanField`, which will
|
|
|
|
likely be deprecated in the future.
|
|
|
|
|
2017-09-10 15:34:18 +01:00
|
|
|
* The new :meth:`.QuerySet.explain` method displays the database's execution
|
|
|
|
plan of a queryset's query.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
Requests and Responses
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
|
2017-11-07 21:58:05 +01:00
|
|
|
* Added :meth:`.HttpRequest.get_full_path_info`.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2018-04-13 20:58:31 -04:00
|
|
|
* Added the ``samesite`` argument to :meth:`.HttpResponse.set_cookie` to allow
|
|
|
|
setting the ``SameSite`` cookie flag.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
Serialization
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Signals
|
|
|
|
~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Templates
|
|
|
|
~~~~~~~~~
|
|
|
|
|
2017-10-12 20:59:38 +02:00
|
|
|
* The new :tfilter:`json_script` filter safely outputs a Python object as JSON,
|
|
|
|
wrapped in a ``<script>`` tag, ready for use with JavaScript.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
|
|
|
Tests
|
|
|
|
~~~~~
|
|
|
|
|
2017-05-22 11:49:39 +01:00
|
|
|
* Added test :class:`~django.test.Client` support for 307 and 308 redirects.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2018-02-05 10:22:24 +00:00
|
|
|
* The test :class:`~django.test.Client` now serializes a request data
|
|
|
|
dictionary as JSON if ``content_type='application/json'``. You can customize
|
|
|
|
the JSON encoder with test client's ``json_encoder`` parameter.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
URLs
|
|
|
|
~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
Validators
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
* ...
|
|
|
|
|
|
|
|
.. _backwards-incompatible-2.1:
|
|
|
|
|
|
|
|
Backwards incompatible changes in 2.1
|
|
|
|
=====================================
|
|
|
|
|
|
|
|
Database backend API
|
|
|
|
--------------------
|
|
|
|
|
2017-10-06 12:47:08 -04:00
|
|
|
* To adhere to :pep:`249`, exceptions where a database doesn't support a
|
|
|
|
feature are changed from :exc:`NotImplementedError` to
|
|
|
|
:exc:`django.db.NotSupportedError`.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2018-02-07 08:27:47 +01:00
|
|
|
* Renamed the ``allow_sliced_subqueries`` database feature flag to
|
|
|
|
``allow_sliced_subqueries_with_in``.
|
|
|
|
|
2017-06-18 16:53:40 +01:00
|
|
|
* ``DatabaseOperations.distinct_sql()`` now requires an additional ``params``
|
|
|
|
argument and returns a tuple of SQL and parameters instead of a SQL string.
|
|
|
|
|
2018-03-16 10:52:04 -04:00
|
|
|
* ``DatabaseFeatures.introspected_boolean_field_type`` is changed from a method
|
|
|
|
to a property.
|
|
|
|
|
2017-09-30 14:13:18 -04:00
|
|
|
:mod:`django.contrib.gis`
|
|
|
|
-------------------------
|
|
|
|
|
|
|
|
* Support for SpatiaLite 4.0 is removed.
|
|
|
|
|
2017-08-24 14:56:09 -04:00
|
|
|
Dropped support for MySQL 5.5
|
|
|
|
-----------------------------
|
|
|
|
|
|
|
|
The end of upstream support for MySQL 5.5 is December 2018. Django 2.1 supports
|
|
|
|
MySQL 5.6 and higher.
|
|
|
|
|
2017-09-06 10:26:45 -04:00
|
|
|
Dropped support for PostgreSQL 9.3
|
|
|
|
----------------------------------
|
|
|
|
|
|
|
|
The end of upstream support for PostgreSQL 9.3 is September 2018. Django 2.1
|
|
|
|
supports PostgreSQL 9.4 and higher.
|
|
|
|
|
2018-02-26 09:05:18 -05:00
|
|
|
Removed ``BCryptPasswordHasher`` from the default ``PASSWORD_HASHERS`` setting
|
|
|
|
------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
If you used bcrypt with Django 1.4 or 1.5 (before ``BCryptSHA256PasswordHasher``
|
|
|
|
was added in Django 1.6), you might have some passwords that use the
|
|
|
|
``BCryptPasswordHasher`` hasher.
|
|
|
|
|
|
|
|
You can check if that's the case like this::
|
|
|
|
|
|
|
|
from django.contrib.auth import get_user_model
|
|
|
|
User = get_user_model()
|
|
|
|
User.objects.filter(password__startswith='bcrypt$$')
|
|
|
|
|
|
|
|
If you want to continue to allow those passwords to be used, you'll
|
|
|
|
have to define the :setting:`PASSWORD_HASHERS` setting (if you don't already)
|
|
|
|
and include ``'django.contrib.auth.hashers.BCryptPasswordHasher'``.
|
|
|
|
|
2018-03-14 11:28:18 -04:00
|
|
|
Moved ``wrap_label`` widget template context variable
|
|
|
|
-----------------------------------------------------
|
|
|
|
|
|
|
|
To fix the lack of ``<label>`` when using ``RadioSelect`` and
|
|
|
|
``CheckboxSelectMultiple`` with ``MultiWidget``, the ``wrap_label`` context
|
|
|
|
variable now appears as an attribute of each option. For example, in a custom
|
|
|
|
``input_option.html`` template, change ``{% if wrap_label %}`` to
|
|
|
|
``{% if widget.wrap_label %}``.
|
|
|
|
|
2018-04-13 20:58:31 -04:00
|
|
|
``SameSite`` cookies
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
The cookies used for ``django.contrib.sessions``, ``django.contrib.messages``,
|
|
|
|
and Django's CSRF protection now set the ``SameSite`` flag to ``Lax`` by
|
|
|
|
default. Browsers that respect this flag won't send these cookies on
|
|
|
|
cross-origin requests. If you rely on the old behavior, set the
|
|
|
|
:setting:`SESSION_COOKIE_SAMESITE` and/or :setting:`CSRF_COOKIE_SAMESITE`
|
|
|
|
setting to ``None``.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
2017-12-29 21:55:29 +05:00
|
|
|
* The minimum supported version of ``mysqlclient`` is increased from 1.3.3 to
|
|
|
|
1.3.7.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2017-12-28 00:49:46 +03:00
|
|
|
* The date format of ``Set-Cookie``'s ``Expires`` directive is changed to
|
|
|
|
follow :rfc:`7231#section-7.1.1.1` instead of Netscape's cookie standard.
|
|
|
|
Hyphens present in dates like ``Tue, 25-Dec-2018 22:26:13 GMT`` are removed.
|
|
|
|
This change should be merely cosmetic except perhaps for antiquated browsers
|
|
|
|
that don't parse the new format.
|
|
|
|
|
2018-01-11 04:03:50 -08:00
|
|
|
* ``allowed_hosts`` is now a required argument of private API
|
|
|
|
``django.utils.http.is_safe_url()``.
|
|
|
|
|
2018-01-20 08:19:06 -08:00
|
|
|
* The ``multiple`` attribute rendered by the
|
|
|
|
:class:`~django.forms.SelectMultiple` widget now uses HTML5 boolean syntax
|
2018-01-20 22:41:40 -08:00
|
|
|
rather than XHTML's ``multiple="multiple"``.
|
2018-01-20 08:19:06 -08:00
|
|
|
|
2018-01-20 23:09:10 -08:00
|
|
|
* HTML rendered by form widgets no longer includes a closing slash on void
|
|
|
|
elements, e.g. ``<br>``. This is incompatible within XHTML, although some
|
|
|
|
widgets already used aspects of HTML5 such as boolean attributes.
|
|
|
|
|
2018-01-30 10:33:13 +01:00
|
|
|
* The value of :class:`~django.forms.SelectDateWidget`'s empty options is
|
|
|
|
changed from 0 to an empty string, which mainly may require some adjustments
|
|
|
|
in tests that compare HTML.
|
|
|
|
|
2018-03-20 17:19:27 -04:00
|
|
|
* :meth:`.User.has_usable_password` and the
|
|
|
|
:func:`~django.contrib.auth.hashers.is_password_usable` function no longer
|
|
|
|
return ``False`` if the password is ``None`` or an empty string, or if the
|
|
|
|
password uses a hasher that's not in the :setting:`PASSWORD_HASHERS` setting.
|
|
|
|
This undocumented behavior was a regression in Django 1.6 and prevented users
|
|
|
|
with such passwords from requesting a password reset. Audit your code to
|
|
|
|
confirm that your usage of these APIs don't rely on the old behavior.
|
|
|
|
|
2018-03-15 15:32:56 -04:00
|
|
|
* Since migrations are now loaded from ``.pyc`` files, you might need to delete
|
|
|
|
them if you're working in a mixed Python 2 and Python 3 environment.
|
|
|
|
|
2018-02-20 16:47:12 +01:00
|
|
|
* Using ``None`` as a :class:`~django.contrib.postgres.fields.JSONField` lookup
|
|
|
|
value now matches objects that have the specified key and a null value rather
|
|
|
|
than objects that don't have the key.
|
|
|
|
|
2018-04-05 20:25:36 +05:30
|
|
|
* The admin CSS class ``field-box`` is renamed to ``fieldBox`` to prevent
|
|
|
|
conflicts with the class given to model fields named "box".
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
.. _deprecated-features-2.1:
|
|
|
|
|
|
|
|
Features deprecated in 2.1
|
|
|
|
==========================
|
|
|
|
|
|
|
|
Miscellaneous
|
|
|
|
-------------
|
|
|
|
|
2017-11-24 22:30:53 +05:00
|
|
|
* The ``ForceRHR`` GIS function is deprecated in favor of the new
|
|
|
|
:class:`~django.contrib.gis.db.models.functions.ForcePolygonCW` function.
|
2017-09-02 19:08:23 -04:00
|
|
|
|
2017-12-30 14:19:43 -05:00
|
|
|
* ``django.utils.http.cookie_date()`` is deprecated in favor of
|
|
|
|
:func:`~django.utils.http.http_date`, which follows the format of the latest
|
|
|
|
RFC.
|
|
|
|
|
2018-01-21 13:38:52 -08:00
|
|
|
* ``{% load staticfiles %}`` and ``{% load admin_static %}`` are deprecated
|
|
|
|
in favor of ``{% load static %}``, which works the same.
|
|
|
|
|
|
|
|
* ``django.contrib.staticfiles.templatetags.static()`` is deprecated in favor
|
|
|
|
of ``django.templatetags.static.static()``.
|
|
|
|
|
2018-02-21 19:11:50 -08:00
|
|
|
* Support for :meth:`.InlineModelAdmin.has_add_permission` methods that don't
|
|
|
|
accept ``obj`` as the second positional argument will be removed in Django
|
|
|
|
3.0.
|
|
|
|
|
2017-09-02 19:08:23 -04:00
|
|
|
.. _removed-features-2.1:
|
|
|
|
|
|
|
|
Features removed in 2.1
|
|
|
|
=======================
|
|
|
|
|
|
|
|
These features have reached the end of their deprecation cycle and are removed
|
|
|
|
in Django 2.1. See :ref:`deprecated-features-1.11` for details, including how
|
|
|
|
to remove usage of these features.
|
2017-09-02 19:24:18 -04:00
|
|
|
in Django 2.1. See :ref:`deprecated-features-1.11` and for details, including
|
|
|
|
how to remove usage of these features.
|
|
|
|
|
|
|
|
* ``contrib.auth.views.login()``, ``logout()``, ``password_change()``,
|
|
|
|
``password_change_done()``, ``password_reset()``, ``password_reset_done()``,
|
|
|
|
``password_reset_confirm()``, and ``password_reset_complete()`` are removed.
|
2017-09-02 19:45:09 -04:00
|
|
|
|
|
|
|
* The ``extra_context`` parameter of ``contrib.auth.views.logout_then_login()``
|
|
|
|
is removed.
|
2017-09-02 19:48:50 -04:00
|
|
|
|
|
|
|
* ``django.test.runner.setup_databases()`` is removed.
|
2017-09-02 19:54:21 -04:00
|
|
|
|
|
|
|
* ``django.utils.translation.string_concat()`` is removed.
|
2017-09-02 19:59:45 -04:00
|
|
|
|
|
|
|
* ``django.core.cache.backends.memcached.PyLibMCCache`` no longer supports
|
|
|
|
passing ``pylibmc`` behavior settings as top-level attributes of ``OPTIONS``.
|
2017-09-02 20:12:27 -04:00
|
|
|
|
|
|
|
* The ``host`` parameter of ``django.utils.http.is_safe_url()`` is removed.
|
2017-09-02 20:24:01 -04:00
|
|
|
|
|
|
|
* Silencing of exceptions raised while rendering the ``{% include %}`` template
|
|
|
|
tag is removed.
|
2017-09-02 20:28:48 -04:00
|
|
|
|
|
|
|
* ``DatabaseIntrospection.get_indexes()`` is removed.
|
2017-09-02 20:40:47 -04:00
|
|
|
|
|
|
|
* The ``authenticate()`` method of authentication backends requires ``request``
|
|
|
|
as the first positional argument.
|
2017-09-02 20:47:47 -04:00
|
|
|
|
|
|
|
* The ``django.db.models.permalink()`` decorator is removed.
|
2017-09-02 21:09:22 -04:00
|
|
|
|
|
|
|
* The ``USE_ETAGS`` setting is removed. ``CommonMiddleware`` and
|
|
|
|
``django.utils.cache.patch_response_headers()`` no longer set ETags.
|
2017-09-02 21:11:12 -04:00
|
|
|
|
|
|
|
* The ``Model._meta.has_auto_field`` attribute is removed.
|
2017-09-02 21:16:09 -04:00
|
|
|
|
|
|
|
* Support for regular expression groups with ``iLmsu#`` in ``url()`` is removed.
|
2017-09-02 21:21:40 -04:00
|
|
|
|
|
|
|
* Support for ``Widget.render()`` methods without the ``renderer`` argument
|
|
|
|
is removed.
|