2👍
✅
A single Puzzle
model should be enough for that. The default User
model already has first and last name fields. The levels would be the permissions.
Hope this helps:
In some models.py
:
from django.db import models
BRONZE_LEVEL = 'access_to_bronze_level_puzzle'
SILVER_LEVEL = 'access_to_silver_level_puzzle'
GOLD_LEVEL = 'access_to_gold_level_puzzle'
class Puzzle(models.Model):
name = models.Charfield(max_length=30)
class Meta:
permissions = (
(BRONZE_LEVEL, 'Can play the puzzle in bronze level'),
(SILVER_LEVEL, 'Can play the puzzle in silver level'),
(GOLD_LEVEL, 'Can play the puzzle in gold level'),
)
With django’s built-in permissions this will allow you to give access to the gold level in ALL the puzzles to a given user (or group of users).
If you want to have individual level restrictions for each of the puzzle instances you need an external app. django-guardian is indeed appropriate.
To set up guardian in your project add the following in settings.py
:
# The auth middleware:
AUTHENTICATION_BACKENDS = (
'django.contrib.auth.backends.ModelBackend', # default
'guardian.backends.ObjectPermissionBackend', # django-guardian per object permissions
)
# Add 'guardian' to `INSTALLED_APPS`.
INSTALLED_APPS = (
# All the other apps
# ...
'guardian',
)
# Define the ID for the anonymous user
# Required because guardian supports permissions for users not logged in
ANONYMOUS_USER_ID = -1`
Now, after a manage.py syncdb
(or migrate
in case you’re using south), everything should be ok. You can assign or remove access to users or groups with:
from guardian.shortcuts import assign_perm, remove_perm
from yourapp.models import BRONZE_LEVEL, SILVER_LEVEL, GOLD_LEVEL
assign_perm(GOLD_LEVEL, some_user_instance, some_puzzle_instance)
remove_perm(GOLD_LEVEL, some_group_instance, some_puzzle_instance)
Source:stackexchange.com