A simple FeinCMS extension that adds permission-checking to a model.
Project description
A simple FeinCMS extension that adds permission-checking to a model. The model is assumed to be a Page, but it could be any FeinCMS model.
Usage
Install using pip, which should get any requirements, eg:
pip install git+git://github.com/ebrelsford/feincms-pagepermissions@master
Change your Django settings to include pagepermissions:
INSTALLED_APPS += ( 'pagepermissions', )
Then add the extension to your content type:
Page.register_extensions( ... 'pagepermissions.extension', )
This will add a permissions field to your content type that you will have to add yourself through syncdb or South or otherwise.
When you edit or add a page you will have the option of setting the permissions required for a user to view that page. You can select multiple permissions, and if the user has any of those they will be able to view the page. Otherwise they will receive a 403.
Finally, you may also want to keep a page out of the navigation if the user has no permission to view it. For this, there is a template filter called “check_page_permission”. Use it as follows in your template:
{% load feincms_page_tags feincms_pagepermissions_tags %} {% feincms_nav feincms_page level=1 depth=1 as level1 %} {% for page in level1 %} {% if page|check_page_permission:user %} ...display page navigation... {% endif %} {% endfor %}
Contributing
Your pull requests are very welcome! Please follow the established code style.
License
feincms-pagepermissions is released under the BSD license.
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
Hashes for feincms-pagepermissions-0.3.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 61e2545bc2d521a4e40cd35476dbe92d29554c046615eb7aa0d28b0c66acebb3 |
|
MD5 | e8fca0d1b728704dbc3e60e8c5c17a74 |
|
BLAKE2b-256 | 22241119afcac787fd2ee224f60aedfa7084353af27a433be32f08b679c3ffc0 |