user, group, & permissions fix

This commit is contained in:
ryanmerolle 2021-04-20 17:47:49 -04:00
parent f2731d3fe6
commit 5d4ecb7f9e
7 changed files with 100 additions and 90 deletions

View file

@ -1,7 +1,7 @@
import sys
from django.contrib.auth.models import User
from startup_script_utils import load_yaml, set_permissions
from startup_script_utils import load_yaml
from users.models import Token
users = load_yaml("/opt/netbox/initializers/users.yml")
@ -19,6 +19,3 @@ for username, user_details in users.items():
if user_details.get("api_token", 0):
Token.objects.create(user=user, key=user_details["api_token"])
yaml_permissions = user_details.get("permissions", [])
set_permissions(user.user_permissions, yaml_permissions)

View file

@ -1,23 +1,27 @@
import sys
from django.contrib.auth.models import Group, User
from startup_script_utils import load_yaml, set_permissions
from users.models import AdminGroup, AdminUser
from startup_script_utils import load_yaml
groups = load_yaml("/opt/netbox/initializers/groups.yml")
if groups is None:
sys.exit()
for groupname, group_details in groups.items():
group, created = Group.objects.get_or_create(name=groupname)
for params in groups:
groupname=params['name']
group, created = AdminGroup.objects.get_or_create(
name=groupname
)
if created:
print("👥 Created group", groupname)
for username in group_details.get("users", []):
user = User.objects.get(username=username)
for username in params.get("users", []):
user = AdminUser.objects.get(username=username)
if user:
user.groups.add(group)
group.user_set.add(user)
print(" 👤 Assigned user %s to group %s" % (username, AdminGroup.name))
yaml_permissions = group_details.get("permissions", [])
set_permissions(group.permissions, yaml_permissions)
group.save()

View file

@ -0,0 +1,44 @@
import sys
from users.models import ObjectPermission, AdminGroup, AdminUser
from startup_script_utils import load_yaml
from django.contrib.contenttypes.models import ContentType
object_permissions = load_yaml("/opt/netbox/initializers/object_permissions.yml")
if object_permissions is None:
sys.exit()
for params in object_permissions:
object_permission, created = ObjectPermission.objects.get_or_create(
name=params['name'],
description=params['description'],
enabled=params['enabled'],
actions=params['actions']
)
# Need to try to pass a list of model_name and app_label for more than just the current all objects.
#object_types = ContentType.objects.filter(app_label__in=params.pop("object_types"))
#object_permission.object_types.set(ContentType.objects.filter(app_label__in=params.pop("object_types")))
object_permission.object_types.set(ContentType.objects.all())
object_permission.save()
print("🔓 Created object permission", object_permission.name)
for groupname in params.get("groups", []):
group = AdminGroup.objects.get(name=groupname)
if group:
object_permission.groups.add(group)
print(" 👥 Assigned group %s object permission of %s" % (groupname, object_permission.name))
for username in params.get("users", []):
user = AdminUser.objects.get(username=username)
if user:
object_permission.users.add(user)
print(" 👤 Assigned user %s object permission of %s" % (username, object_permission.name))
object_permission.save()

View file

@ -1,22 +0,0 @@
from django.contrib.auth.models import Permission
def set_permissions(subject, permission_filters):
if subject is None or permission_filters is None:
return
subject.clear()
for permission_filter in permission_filters:
if "*" in permission_filter:
permission_filter_regex = "^" + permission_filter.replace("*", ".*") + "$"
permissions = Permission.objects.filter(codename__iregex=permission_filter_regex)
print(
" ⚿ Granting",
permissions.count(),
"permissions matching '" + permission_filter + "'",
)
else:
permissions = Permission.objects.filter(codename=permission_filter)
print(" ⚿ Granting permission", permission_filter)
for permission in permissions:
subject.add(permission)