Rule registry for django
Project description
This is a simple alternative to django-rules. The core difference is that it uses as registry that can be modified on runtime, instead of database models.
One of the goal is to enable developpers of external apps to make rules, depend on it, while allowing a project to override rules.
Example your_app/rules_light_registry.py:
# Everybody can create or read a blog post (for now!): rules_light.registry['blog.post.read'] = True # Require authentication to create a blog post, using a shortcut: rules_light.registry['blog.post.create'] = rules_light.is_authenticated def is_staff_or_mine(user, rule, obj): return user.is_staff or obj.author == user # But others shouldn't mess with my posts ! rules_light.registry['blog.post.update'] = is_staff_or_mine rules_light.registry['blog.post.delete'] = is_staff_or_mine
Example your_app/views.py:
@rules_light.class_decorator class PostDetailView(generic.DetailView): model = Post @rules_light.class_decorator class PostCreateView(generic.CreateView): model = Post @rules_light.class_decorator class PostUpdateView(generic.UpdateView): model = Post @rules_light.class_decorator class PostDeleteView(generic.DeleteView): model = Post
You might want to read the tutorial for more.
What’s the catch ?
The catch is that this approach does not offer any feature to get secure querysets.
This means that the developper has to:
think about security when making querysets,
override eventual external app ListViews,
Requirements
Maintained against Python 2.7
and Django 1.4+
Quick Install
Install module: pip install django-rules-light,
Add to settings.INSTALLED_APPS: rules_light,
Add in settings.MIDDLEWARE_CLASSES: rules_light.middleware.Middleware,
Add in urls.py: rules_light.autodiscover(),
You might want to read the tutorial.
There is also a lot of documentation, from the core to the tools, including pointers to debug, log and test your security.
Resources
You could subscribe to the mailing list ask questions or just be informed of package updates.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
File details
Details for the file django-rules-light-0.0.1.tar.gz
.
File metadata
- Download URL: django-rules-light-0.0.1.tar.gz
- Upload date:
- Size: 9.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cc5a57c544281769489c10eb38225fff7336c3b1bb0d061f300ae2be6e155ca5 |
|
MD5 | e6bc5234b60598efb52b7f17e73b86a9 |
|
BLAKE2b-256 | 3cb981f811e274ec04a7c657abbbe6548dcad26b9113635d16aea3d6e6f00d48 |