2018-10-13 17:44:01 +02:00
|
|
|
from django.contrib.auth.models import Permission, Group, User
|
2018-02-16 10:25:26 +01:00
|
|
|
from ruamel.yaml import YAML
|
2018-12-19 14:25:58 +01:00
|
|
|
from pathlib import Path
|
|
|
|
import sys
|
2018-02-16 10:25:26 +01:00
|
|
|
|
2018-12-19 14:25:58 +01:00
|
|
|
file = Path('/opt/netbox/initializers/groups.yml')
|
|
|
|
if not file.is_file():
|
|
|
|
sys.exit()
|
|
|
|
|
|
|
|
with file.open('r') as stream:
|
2018-02-16 10:25:26 +01:00
|
|
|
yaml=YAML(typ='safe')
|
|
|
|
groups = yaml.load(stream)
|
|
|
|
|
|
|
|
if groups is not None:
|
|
|
|
for groupname, group_details in groups.items():
|
|
|
|
group, created = Group.objects.get_or_create(name=groupname)
|
|
|
|
|
|
|
|
if created:
|
|
|
|
print("👥 Created group", groupname)
|
|
|
|
|
2018-10-13 17:44:01 +02:00
|
|
|
for username in group_details.get('users', []):
|
2018-02-16 10:25:26 +01:00
|
|
|
user = User.objects.get(username=username)
|
|
|
|
|
|
|
|
if user:
|
|
|
|
user.groups.add(group)
|
2018-10-13 17:44:01 +02:00
|
|
|
|
2019-12-05 16:41:11 +01:00
|
|
|
yaml_permissions = group_details.get('permissions', [])
|
|
|
|
if yaml_permissions:
|
2020-02-02 09:48:02 +01:00
|
|
|
subject = group.permissions
|
2020-01-31 11:39:05 +01:00
|
|
|
subject.clear()
|
2019-12-05 16:41:11 +01:00
|
|
|
for yaml_permission in yaml_permissions:
|
2019-12-11 17:14:38 +01:00
|
|
|
if '*' in yaml_permission:
|
2020-01-31 11:39:05 +01:00
|
|
|
permission_filter = '^' + yaml_permission.replace('*','.*') + '$'
|
|
|
|
permissions = Permission.objects.filter(codename__iregex=permission_filter)
|
|
|
|
print(" ⚿ Granting", permissions.count(), "permissions matching '" + yaml_permission + "'")
|
2019-12-05 16:41:11 +01:00
|
|
|
else:
|
2020-01-31 11:39:05 +01:00
|
|
|
permissions = Permission.objects.filter(codename=yaml_permission)
|
|
|
|
print(" ⚿ Granting permission", yaml_permission)
|
|
|
|
|
|
|
|
for permission in permissions:
|
|
|
|
subject.add(permission)
|