Skip to main content

Caches the groups a user is in so requests don't have to make calls to the database to check group status.

Project description

https://badge.fury.io/py/django-groups-cache.svg https://travis-ci.org/audiolion/django-groups-cache.svg?branch=master https://codecov.io/gh/audiolion/django-groups-cache/branch/master/graph/badge.svg

Caches the groups a user is in so requests don’t have to make calls to the database to check group status.

Support

Currently supporting Django 1.8, 1.11, and 2.0 with Python 2.7/Python 3 where support for versions aligns with Django’s support. See the tox.ini file for specific Python and Django version pairings.

Documentation

The full documentation is at https://django-groups-cache.readthedocs.io.

Quickstart

Install django-groups-cache:

pip install django-groups-cache

Add it to your INSTALLED_APPS:

INSTALLED_APPS = (
    ...
    'groups_cache.apps.GroupsCacheConfig',
    ...
)

Add the middleware to your MIDDLEWARE_CLASSES:

MIDDLEWARE_CLASSES = (
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    ...
    'groups_cache.middleware.GroupsCacheMiddleware',
)

Checking in a Django Template if the user is in a group name:

{% if "admins" in request.groups_cache %}
  <a href="/admin">Admin Panel</a>
{% endif %}

# or use templatetag, note that templatetag is slower

{% load has_group %}

{% if request.user|has_group:"admins" %}
  <a href="/admin">Admin Panel</a>
{% endif %}

Turn on caching:

CACHES = {
    'default': {
        'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
        'LOCATION': '127.0.0.1:11211',
    }
}

See https://docs.djangoproject.com/en/1.10/topics/cache/#memcached for more details on setting up memcached.

Note**

Using django.core.cache.backends.locmem.LocMemCache is not safe for production unless you are only running a single process (and odds are you aren’t).

See https://docs.djangoproject.com/en/1.10/topics/cache/#local-memory-caching for more details.

Features

  • Adds groups_cache property to request object

  • Provides templatetag has_group

  • Invalidates cache on User or Group model changes and on m2m groups ManyToManyField changes

  • Fully tested with high coverage

Running Tests

source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install tox
(myenv) $ tox

Credits

Tools used in rendering this package:

History

0.5.5 (2017-01-13)

  • Bug fix for templatetag has_group

  • Tests added for 100% coverage of templatetag folder

0.5.5 (2017-01-12)

  • Omit urls.py from coverage report (not used but needed for django package)

  • Omit apps.py from coverage report (default apps file)

0.5.4 (2017-01-12)

  • Removal of py32/django1.8 support from Travis CI build

0.5.3 (2017-01-12)

  • Fixing .travis.yml file and CI builds

0.5.2 (2017-01-12)

  • Typo in README.rst

0.5.1 (2017-01-12)

  • Add codecov.io support

  • Documentation updates

0.5.0 (2017-01-12)

  • Add requirements.txt to tox.ini so tests can run

  • Fix broken compatibility with Django 1.8/1.9 due to backwards incompatible changes in 1.9/1.10 code

0.4.0 (2017-01-12)

  • Add test suite that generates 100% coverage

  • Fixed a bug found by test suite with cache not invalidating on the groups ManyToManyField changing

0.3.1 (2017-01-11)

  • Documentation updates

0.3.0 (2017-01-11)

  • First stable and working release on PyPI.

0.1.0 (2017-01-11)

  • 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-groups-cache-1.0.2.tar.gz (8.1 kB view details)

Uploaded Source

Built Distribution

django_groups_cache-1.0.2-py2.py3-none-any.whl (10.4 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-groups-cache-1.0.2.tar.gz.

File metadata

File hashes

Hashes for django-groups-cache-1.0.2.tar.gz
Algorithm Hash digest
SHA256 a5b8621c2e18f5067cdbb289f9a35616539a351794cc27dbc8b6bf8dd34ac856
MD5 4dc51b97f7e1c2fe3d10dda198df5318
BLAKE2b-256 c9262c6fc2d80de0c1a84591e470edab2bc8d739bdfc68cc2d24d375ae195150

See more details on using hashes here.

File details

Details for the file django_groups_cache-1.0.2-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_groups_cache-1.0.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 349e03fc1371f7292f70682792d8d0d8f8731765e2dd8ffdfb4888d161238cec
MD5 ba4d92d5632b36989191c6a98e0245ee
BLAKE2b-256 c1d5c72d95a2b649357c1f779a23dc6872494112aacb89fbafaf9d71cb3a3873

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