Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

django-user-sessions-ng

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

django-user-sessions-ng

Django User Sessions NG - a Django package to manage multiple user sessions.

  • 0.1.7
  • PyPI
  • Socket score

Maintainers
1

django-user-sessions-ng

django-user-sessions-ng is a Django package which allows users to have multiple sessions and provides session management through the Django admin interface.

This project is originally inspired by (and based on) the following projects:

  1. django-user-sessions
  2. django-qsessions

The changes made in this repo, however, are very minimal, and the package itself is more like an adaptation for personal use.

Features

  1. Multiple sessions per user.
  2. Session management through the Django admin interface.
  3. Cached session data for faster access.
  4. Device information for each session.
  5. IP address for each session.
  6. (Optional) Location information for each session.

Installation

  1. Install the package using your favorite package manager, for example pip:

    pip install django-user-sessions-ng
    
  2. Add django_user_sessions_ng to your INSTALLED_APPS setting like this::

    INSTALLED_APPS = [
        ...,
        "django_user_sessions_ng",
    ]
    
  3. Add django_user_sessions_ng.middleware.SessionMiddleware to your MIDDLEWARE setting like this:

    MIDDLEWARE = [
        ...,
        "django_user_sessions_ng.middleware.SessionMiddleware",
    ]
    
  4. Set SESSION_ENGINE to django_user_sessions_ng.backends.db or django_user_sessions_ng.backends.cached_db depending on your preferences and whether you need cached db in your Django settings file:

    SESSION_ENGINE = "django_user_sessions_ng.backends.db"
    

    or

    SESSION_ENGINE = "django_user_sessions_ng.backends.cached_db"
    
  5. Run python manage.py migrate to create the necessary models.

  6. (Optional) In order to enable the location information for each session, you will need to install the package called geoip2 and download the GeoLite2 database from MaxMind or using the built-in python manage.py download_geoip_db -k MAXMIND_LICENSE_KEY command (you can get the MAXMIND_LICENSE_KEY by registering at their website and registering a new license key) and set the GEOIP_PATH setting in your Django settings file to the path of the database file or directory containing multiple databases.

    For example:

    GEOIP_PATH = "/path/to/GeoLite2"
    

    or

    GEOIP_PATH = "/path/to/GeoLite2/GeoLite2-City.mmdb"
    

Notes

  1. Since this package replaces the functionality of the default Django session application (django.contrib.sessions), it is recommended to remove the django.contrib.sessions from the INSTALLED_APPS setting as well as django.contrib.sessions.middleware.SessionMiddleware from the MIDDLEWARE setting.

  2. The package provides a management command clearsessions (simply imports the one from the original django.contrib.sessions package) which can be used to clear expired sessions. This command can be run using the following command:

    python manage.py django_user_sessions_ng clearsessions
    
  3. If for some reason the MaxMind base url for download changes, and the package doesn't get updated in time, there's an optional argument -u or --maxmind-geoip-download-base-url for the download_geoip_db command which can be used to specify the base url for downloading the database files.

    For example:

    python manage.py download_geoip_db -k MAXMIND_LICENSE_KEY -u "https://download.maxmind.com/app/geoip_download"
    

Credits

  1. Thanks to JazzBand for their original django-user-sessions implementation.
  2. Thanks to QueraTeam for their original django-qsessions, particularly for their tests and cached_db implementation.

License

MIT

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc