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 users.models import Token
|
|
|
|
|
2020-02-05 15:31:01 +01:00
|
|
|
from startup_script_utils import load_yaml
|
2018-12-19 14:25:58 +01:00
|
|
|
import sys
|
2018-02-16 10:25:26 +01:00
|
|
|
|
2020-02-05 15:31:01 +01:00
|
|
|
users = load_yaml('/opt/netbox/initializers/users.yml')
|
|
|
|
|
|
|
|
if users is None:
|
2018-12-19 14:25:58 +01:00
|
|
|
sys.exit()
|
|
|
|
|
2020-02-05 15:31:01 +01:00
|
|
|
for username, user_details in users.items():
|
|
|
|
if not User.objects.filter(username=username):
|
|
|
|
user = User.objects.create_user(
|
|
|
|
username = username,
|
|
|
|
password = user_details.get('password', 0) or User.objects.make_random_password)
|
|
|
|
|
|
|
|
print("👤 Created user",username)
|
|
|
|
|
|
|
|
if user_details.get('api_token', 0):
|
|
|
|
Token.objects.create(user=user, key=user_details['api_token'])
|
|
|
|
|
|
|
|
yaml_permissions = user_details.get('permissions', [])
|
|
|
|
if yaml_permissions:
|
|
|
|
subject = user.user_permissions
|
|
|
|
subject.clear()
|
|
|
|
for yaml_permission in yaml_permissions:
|
|
|
|
if '*' in yaml_permission:
|
|
|
|
permission_filter = '^' + yaml_permission.replace('*','.*') + '$'
|
|
|
|
permissions = Permission.objects.filter(codename__iregex=permission_filter)
|
|
|
|
print(" ⚿ Granting", permissions.count(), "permissions matching '" + yaml_permission + "'")
|
|
|
|
else:
|
|
|
|
permissions = Permission.objects.filter(codename=yaml_permission)
|
|
|
|
print(" ⚿ Granting permission", yaml_permission)
|
|
|
|
|
|
|
|
for permission in permissions:
|
|
|
|
subject.add(permission)
|