2006-05-02 09:31:56 +08:00
|
|
|
"""
|
|
|
|
Creates permissions for all installed apps that need permissions.
|
|
|
|
"""
|
|
|
|
|
|
|
|
from django.contrib.auth import models as auth_app
|
2010-11-02 04:54:39 +08:00
|
|
|
from django.db.models import get_models, signals
|
|
|
|
|
2006-05-02 09:31:56 +08:00
|
|
|
|
|
|
|
def _get_permission_codename(action, opts):
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
return u'%s_%s' % (action, opts.object_name.lower())
|
2006-05-02 09:31:56 +08:00
|
|
|
|
|
|
|
def _get_all_permissions(opts):
|
|
|
|
"Returns (codename, name) for all permissions in the given opts."
|
|
|
|
perms = []
|
|
|
|
for action in ('add', 'change', 'delete'):
|
Merged Unicode branch into trunk (r4952:5608). This should be fully
backwards compatible for all practical purposes.
Fixed #2391, #2489, #2996, #3322, #3344, #3370, #3406, #3432, #3454, #3492, #3582, #3690, #3878, #3891, #3937, #4039, #4141, #4227, #4286, #4291, #4300, #4452, #4702
git-svn-id: http://code.djangoproject.com/svn/django/trunk@5609 bcc190cf-cafb-0310-a4f2-bffc1f526a37
2007-07-04 20:11:04 +08:00
|
|
|
perms.append((_get_permission_codename(action, opts), u'Can %s %s' % (action, opts.verbose_name_raw)))
|
2006-05-02 09:31:56 +08:00
|
|
|
return perms + list(opts.permissions)
|
|
|
|
|
2008-08-06 23:32:46 +08:00
|
|
|
def create_permissions(app, created_models, verbosity, **kwargs):
|
2006-05-02 09:31:56 +08:00
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2010-11-01 00:49:36 +08:00
|
|
|
|
2006-05-02 09:31:56 +08:00
|
|
|
app_models = get_models(app)
|
2010-11-02 04:54:39 +08:00
|
|
|
|
|
|
|
# This will hold the permissions we're looking for as
|
|
|
|
# (content_type, (codename, name))
|
|
|
|
searched_perms = set()
|
|
|
|
# The codenames and ctypes that should exist.
|
|
|
|
ctypes = set()
|
|
|
|
codenames = set()
|
2006-05-02 09:31:56 +08:00
|
|
|
for klass in app_models:
|
|
|
|
ctype = ContentType.objects.get_for_model(klass)
|
2010-11-02 04:54:39 +08:00
|
|
|
ctypes.add(ctype)
|
|
|
|
for perm in _get_all_permissions(klass._meta):
|
|
|
|
codenames.add(perm[0])
|
|
|
|
searched_perms.add((ctype, perm))
|
|
|
|
|
|
|
|
# Find all the Permissions that a) have a content_type for a model we're
|
|
|
|
# looking for, and b) have a codename we're looking for. It doesn't need to
|
|
|
|
# have both, we have a list of exactly what we want, and it's faster to
|
|
|
|
# write the query with fewer conditions.
|
|
|
|
all_perms = set(auth_app.Permission.objects.filter(
|
|
|
|
content_type__in=ctypes,
|
|
|
|
codename__in=codenames
|
|
|
|
).values_list(
|
|
|
|
"content_type", "codename"
|
|
|
|
))
|
|
|
|
|
|
|
|
for ctype, (codename, name) in searched_perms:
|
|
|
|
# If the permissions exists, move on.
|
|
|
|
if (ctype.pk, codename) in all_perms:
|
|
|
|
continue
|
|
|
|
p = auth_app.Permission.objects.create(
|
|
|
|
codename=codename,
|
|
|
|
name=name,
|
|
|
|
content_type=ctype
|
|
|
|
)
|
|
|
|
if verbosity >= 2:
|
|
|
|
print "Adding permission '%s'" % p
|
|
|
|
|
2006-05-02 09:31:56 +08:00
|
|
|
|
2006-08-27 20:46:39 +08:00
|
|
|
def create_superuser(app, created_models, verbosity, **kwargs):
|
2008-06-08 13:31:16 +08:00
|
|
|
from django.core.management import call_command
|
2010-11-01 00:49:36 +08:00
|
|
|
|
|
|
|
if auth_app.User in created_models and kwargs.get('interactive', True):
|
|
|
|
msg = ("\nYou just installed Django's auth system, which means you "
|
|
|
|
"don't have any superusers defined.\nWould you like to create one "
|
|
|
|
"now? (yes/no): ")
|
2006-05-02 09:31:56 +08:00
|
|
|
confirm = raw_input(msg)
|
|
|
|
while 1:
|
|
|
|
if confirm not in ('yes', 'no'):
|
|
|
|
confirm = raw_input('Please enter either "yes" or "no": ')
|
|
|
|
continue
|
|
|
|
if confirm == 'yes':
|
2008-06-09 02:18:01 +08:00
|
|
|
call_command("createsuperuser", interactive=True)
|
2006-05-02 09:31:56 +08:00
|
|
|
break
|
|
|
|
|
2008-08-06 23:32:46 +08:00
|
|
|
signals.post_syncdb.connect(create_permissions,
|
|
|
|
dispatch_uid = "django.contrib.auth.management.create_permissions")
|
|
|
|
signals.post_syncdb.connect(create_superuser,
|
|
|
|
sender=auth_app, dispatch_uid = "django.contrib.auth.management.create_superuser")
|