Here are steps for adding custom permissions to the User
model:
First create a migration file, for example under your authentication application,
Here i named it 0002_permission_fixtures.py
:
account (your authentication application)
|_migrations
|__ 0001_initial.py
|__ 0002_permission_fixtures.py
|__ __init__.py
Then adding your permission objects, as follow:
# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import migrations
def forwards_func(apps, schema_editor):
# Get models that we needs them
user = apps.get_model("auth", "User")
permission = apps.get_model("auth", "Permission")
content_type = apps.get_model("contenttypes", "ContentType")
# Get user content type object
uct = content_type.objects.get_for_model(user)
db_alias = schema_editor.connection.alias
# Adding your custom permissions to User model:
permission.objects.using(db_alias).bulk_create([
permission(codename='add_sample', name='Can add sample', content_type=uct),
permission(codename='change_sample', name='Can change sample', content_type=uct),
permission(codename='delete_sample', name='Can delete sample', content_type=uct),
])
class Migration(migrations.Migration):
dependencies = [
('contenttypes', '__latest__'),
]
operations = [
migrations.RunPython(
forwards_func,
),
]
To run this migration, first migrate contenttype
model, and then migrate your application (here is account).
$ python manage.py migrate contenttypes
$ python manage.py migrate account
INSTALLED_APPS = ('svsite', ..., 'django.contrib.contenttypes', '...', 'member')
and the user just extendsAbstractUser
. – LectionPermission
s needContentType
instances, which don't exists during migration... – Lection