Skip to main content

Adds Client Definable Permissions to Django

Project description

.. image:: https://github.com/renderbox/django-permafrost/workflows/Permafrost%20Develop/badge.svg :target: https://github.com/renderbox/django-permafrost/workflows/Permafrost%20Develop/badge.svg :alt: Permafrost Develop

.. image:: https://github.com/renderbox/django-permafrost/workflows/Permafrost%20CI/badge.svg :target: https://github.com/renderbox/django-permafrost/workflows/Permafrost%20CI/badge.svg :alt: Permafrost CI

.. image:: https://readthedocs.org/projects/django-permafrost/badge/?version=latest :target: https://django-permafrost.readthedocs.io/en/latest/?badge=latest :alt: Documentation Status

Django Permafrost

Django Permafrost is an extension to Django's Permissions framework. It's goal is to allow developers to expose some permissions to Client Users on the site so they can create and manage custom User Roles.

It adds:

  • A View Mixin that supports user permissions based on different HTTP method types (GET, POST, PUT, etc) for extra granular control.

  • A View Mixin that captures into Django's logging setup any failed permission checks.

  • An App that supports Client User definable roles and permissions. This uses the underlying Django Permission system and controls which permissions are exposed to the users.

    • Developers can have both require permissions for the permission classes or optional permission that can be set by the Client.

For example, you have a SAAS platform where you have Administrators Clients. They manage the other users on their master account in the system (like Employees, etc) and want to be able to define different permissions for various users. They might have one Employee they want to be able to manage email lists but not let them invite users but both are considered in the staff category.

Installation

To install, just use pip

.. code-block:: shell

pip install django-permafrost

To add it to your project, add it to the list of install apps in you settings.py...

.. code-block:: python

INSTALLED_APPS = [ ... 'permafrost', ... ]

... and migrate

.. code-block:: shell

./manage.py migrate

Setup

The Goal of Django Permafrost is to allow Clients to create their own Permafrost Roles, under developer defined Categories with developer defined required and optional permissions.

An example of a developer defined categories looks like this:

.. code-block:: python

Sample Category Permission Format:

PERMAFROST_CATEGORIES = { 'user': { 'label': ("User"), 'access_level': 1, 'optional': [ {'label':('Can Add Users to Role'), 'permission': ('add_user_to_role', 'permafrost', 'permafrostrole')}, ], 'required': [ {'label':_('Can add Role'), 'permission': ('add_permafrostrole', 'permafrost', 'permafrostrole')}, ], }, }

This would be added to your Django settings.py file (or, at least, included into).

In the above, we define the User category, give it the localizable label of "User" and provide two permissions in the "Natural Key" format (since PKs can be unreliable with permissions), the first is optional and the second is required.

There is also an access_level setting to help make sorting access levels more easily.

Recommendations

It is recommended that you update your code to use PermafrotRole's built-in functions to add users and permissions. They add an extra level of checking to make sure the permissions passed in are allowed by the PERMAFROST_CATEGORIES configuration.

For example, permissions on a Group:

.. code-block:: python

group.permissions.set([permission_list]) group.permissions.add(permission, permission, ...) group.permissions.remove(permission, permission, ...) group.permissions.clear()

Can be replaced with:

.. code-block:: python

PermafrostRole.permissions_set([permission_list]) PermafrostRole.permissions_add(permission, permission, ...) PermafrostRole.permissions_remove(permission, permission, ...) PermafrostRole.permissions_clear()

Convenience tools

There is a tool to help the developer list out the permissions available in the format permafrost expects.

.. code-block:: shell

./manage permlist

using the command will produce a list like this

.. code-block:: shell

./manage.py permlist

Permlist formatted for your PermafrostRoles configuration {'label':('Can add email address'), 'permission': ('add_emailaddress', 'account', 'emailaddress')}, {'label':('Can change email address'), 'permission': ('change_emailaddress', 'account', 'emailaddress')}, {'label':_('Can delete email address'), 'permission': ('delete_emailaddress', 'account', 'emailaddress')}, ...

Each line can be copied into the PERMAFROST_CATEGORIES config in the correct format.

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-permafrost-0.2.23.tar.gz (30.4 kB view details)

Uploaded Source

Built Distribution

django_permafrost-0.2.23-py3-none-any.whl (47.0 kB view details)

Uploaded Python 3

File details

Details for the file django-permafrost-0.2.23.tar.gz.

File metadata

  • Download URL: django-permafrost-0.2.23.tar.gz
  • Upload date:
  • Size: 30.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.15

File hashes

Hashes for django-permafrost-0.2.23.tar.gz
Algorithm Hash digest
SHA256 1df1008a3c7e5b717003f0730f0ec117d562c7f8cd51d1c2c3b05cb25a8fe7b9
MD5 3bdf2328994c982e51fa9723c32e4971
BLAKE2b-256 d120b2efdf44b30dfb4aa2ab33894b68dff2479b297c5bf084d859fa4321c84a

See more details on using hashes here.

File details

Details for the file django_permafrost-0.2.23-py3-none-any.whl.

File metadata

File hashes

Hashes for django_permafrost-0.2.23-py3-none-any.whl
Algorithm Hash digest
SHA256 53f4a4ad66d71414b859b96d6f1346ad4550dbaef43f17ef9accb626023a6837
MD5 4fb221c078213775e94588aad56b0bd0
BLAKE2b-256 9e6848a1de31ff5baf33d78f5626da6e8fe47d2089d0a4d01150ee4788bd7fa9

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