Skip to main content

Restrict Django sessions to IP and/or user agent.

Project description

https://badge.fury.io/py/django-restricted-sessions.png https://travis-ci.org/mxsasha/django-restricted-sessions.png?branch=master https://coveralls.io/repos/mxsasha/django-restricted-sessions/badge.png?branch=master&

Restricts Django sessions to IP and/or user agent.

If the IP or user agent changes after creating the session, the a 400 response is given to the request, the session is flushed (all session data deleted, new session created) and a warning is logged. The goal of this middleware is to make it harder for an attacker to use a session ID they obtained. It does not make abuse of session IDs impossible.

For compatibility with IPv6 privacy extensions, by default only the first 64 bits of an IPv6 address are checked.

Documentation

The full documentation is at https://django-restricted-sessions.readthedocs.org.

Quickstart

Install django-restricted-sessions:

pip install django-restricted-sessions

Then add it to your middleware after SessionMiddleware:

MIDDLEWARE = [
    "django.middleware.security.SecurityMiddleware",
    "django.contrib.sessions.middleware.SessionMiddleware",
    'restrictedsessions.middleware.RestrictedSessionsMiddleware',
    ....
]

If you use RESTRICTEDSESSIONS_AUTHED_ONLY, ensure this middleware is added after AuthenticationMiddleware so that the request.user is present.

History

0.4.0 (2023-06-02)

  • Updated Django support to only 3.2, 4.1 and 4.2 (thanks to @ronnievdc).

  • Various other cleanups and documentation format fixes.

0.3.0 (2019-12-03)

  • Updated Django support to 1.11, 2.2 and 3.0.

  • Fixed issues when X_FORWARDED_FOR contains multiple addresses.

0.2.0 (2017-04-06)

  • For Django 1.10+ support, changed from object to django.utils.deprecation.MiddlewareMixin

  • Added PyPI trove classifiers for Django versions and more Python versions

  • Updated travis.yml for more Python versions

0.1.4 (2016-07-02)

  • Fixed an exception that could occur when non-utf8 bytes were included in user agent strings.

0.1.3.1 (2016-05-26)

  • Version bump to avoid PyPI’s duplicate filename ban.

0.1.3 (2016-05-26)

  • Added support to redirect to known view, or use custom status code settings.

  • Added support for ignoring unauthenticated sessions.

  • Fixed short circuit when REMOTE_ADDR was unknown.

  • Dropped support for older Python versions: now requires 2.7, 3.3 or newer, with Django 1.8.

0.1.2 (2014-03-20)

  • Resolved exception being raised when session switches from IPv4 to IPv6

  • Python 3.4 support

0.1.1 (2014-02-18)

  • Added missing netaddr requirement to setup.py.

0.1.0 (2014-02-17)

  • First release on PyPI.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

django-restricted-sessions-0.4.0.tar.gz (8.5 kB view details)

Uploaded Source

Built Distribution

django_restricted_sessions-0.4.0-py2.py3-none-any.whl (5.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-restricted-sessions-0.4.0.tar.gz.

File metadata

File hashes

Hashes for django-restricted-sessions-0.4.0.tar.gz
Algorithm Hash digest
SHA256 23a6f179b1a2a2ded03a826de6530f72bf46c7c00f5abc698e9673c5227a316b
MD5 9e1d7e1bbe057a12664cde89f37fefb3
BLAKE2b-256 094421196486c19ab5828a0dbc63db988de5fd9a2e20be7d96b912b0c5bd0228

See more details on using hashes here.

File details

Details for the file django_restricted_sessions-0.4.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_restricted_sessions-0.4.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 082896f39d58524bc438b137d58eaa32faef4b264e99f2ea1f983761d4da2713
MD5 c40e6dbd32229d73afa527cce279ce39
BLAKE2b-256 aa720b0bef9d8142d06c897a30b0a13ab4c9b81aec9500442e2dbff71602e865

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page