mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2025-01-13 19:54:30 +00:00
Gestion du groupe serveur et création des groupes lorsqu'ils sont inexistants
This commit is contained in:
parent
d5fff4b0be
commit
f262421ea0
3 changed files with 73 additions and 22 deletions
|
@ -1098,7 +1098,7 @@ class JSONResponse(HttpResponse):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def mac_ip_list(request):
|
def mac_ip_list(request):
|
||||||
interfaces = all_active_assigned_interfaces()
|
interfaces = all_active_assigned_interfaces()
|
||||||
seria = InterfaceSerializer(interfaces, many=True)
|
seria = InterfaceSerializer(interfaces, many=True)
|
||||||
|
@ -1106,7 +1106,7 @@ def mac_ip_list(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def full_mac_ip_list(request):
|
def full_mac_ip_list(request):
|
||||||
interfaces = all_active_assigned_interfaces()
|
interfaces = all_active_assigned_interfaces()
|
||||||
seria = FullInterfaceSerializer(interfaces, many=True)
|
seria = FullInterfaceSerializer(interfaces, many=True)
|
||||||
|
@ -1114,7 +1114,7 @@ def full_mac_ip_list(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def alias(request):
|
def alias(request):
|
||||||
alias = Domain.objects.filter(interface_parent=None).filter(cname__in=Domain.objects.filter(interface_parent__in=Interface.objects.exclude(ipv4=None))).select_related('extension').select_related('cname__extension')
|
alias = Domain.objects.filter(interface_parent=None).filter(cname__in=Domain.objects.filter(interface_parent__in=Interface.objects.exclude(ipv4=None))).select_related('extension').select_related('cname__extension')
|
||||||
seria = DomainSerializer(alias, many=True)
|
seria = DomainSerializer(alias, many=True)
|
||||||
|
@ -1122,7 +1122,7 @@ def alias(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def corresp(request):
|
def corresp(request):
|
||||||
type = IpType.objects.all().select_related('extension')
|
type = IpType.objects.all().select_related('extension')
|
||||||
seria = TypeSerializer(type, many=True)
|
seria = TypeSerializer(type, many=True)
|
||||||
|
@ -1130,7 +1130,7 @@ def corresp(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def mx(request):
|
def mx(request):
|
||||||
mx = Mx.objects.all().select_related('zone').select_related('name__extension')
|
mx = Mx.objects.all().select_related('zone').select_related('name__extension')
|
||||||
seria = MxSerializer(mx, many=True)
|
seria = MxSerializer(mx, many=True)
|
||||||
|
@ -1138,7 +1138,7 @@ def mx(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def txt(request):
|
def txt(request):
|
||||||
txt = Txt.objects.all().select_related('zone')
|
txt = Txt.objects.all().select_related('zone')
|
||||||
seria = TxtSerializer(txt, many=True)
|
seria = TxtSerializer(txt, many=True)
|
||||||
|
@ -1146,7 +1146,7 @@ def txt(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def srv(request):
|
def srv(request):
|
||||||
srv = Srv.objects.all().select_related('extension').select_related('target__extension')
|
srv = Srv.objects.all().select_related('extension').select_related('target__extension')
|
||||||
seria = SrvSerializer(srv, many=True)
|
seria = SrvSerializer(srv, many=True)
|
||||||
|
@ -1154,7 +1154,7 @@ def srv(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def ns(request):
|
def ns(request):
|
||||||
ns = Ns.objects.exclude(ns__in=Domain.objects.filter(interface_parent__in=Interface.objects.filter(ipv4=None))).select_related('zone').select_related('ns__extension')
|
ns = Ns.objects.exclude(ns__in=Domain.objects.filter(interface_parent__in=Interface.objects.filter(ipv4=None))).select_related('zone').select_related('ns__extension')
|
||||||
seria = NsSerializer(ns, many=True)
|
seria = NsSerializer(ns, many=True)
|
||||||
|
@ -1162,7 +1162,7 @@ def ns(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def zones(request):
|
def zones(request):
|
||||||
zones = Extension.objects.all().select_related('origin')
|
zones = Extension.objects.all().select_related('origin')
|
||||||
seria = ExtensionSerializer(zones, many=True)
|
seria = ExtensionSerializer(zones, many=True)
|
||||||
|
@ -1170,21 +1170,21 @@ def zones(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def mac_ip(request):
|
def mac_ip(request):
|
||||||
seria = mac_ip_list(request)
|
seria = mac_ip_list(request)
|
||||||
return JSONResponse(seria)
|
return JSONResponse(seria)
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def mac_ip_dns(request):
|
def mac_ip_dns(request):
|
||||||
seria = full_mac_ip_list(request)
|
seria = full_mac_ip_list(request)
|
||||||
return JSONResponse(seria)
|
return JSONResponse(seria)
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def service_servers(request):
|
def service_servers(request):
|
||||||
service_link = Service_link.objects.all().select_related('server__domain').select_related('service')
|
service_link = Service_link.objects.all().select_related('server__domain').select_related('service')
|
||||||
seria = ServiceServersSerializer(service_link, many=True)
|
seria = ServiceServersSerializer(service_link, many=True)
|
||||||
|
@ -1192,7 +1192,7 @@ def service_servers(request):
|
||||||
|
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def ouverture_ports(request):
|
def ouverture_ports(request):
|
||||||
r = {'ipv4':{}, 'ipv6':{}}
|
r = {'ipv4':{}, 'ipv6':{}}
|
||||||
for o in OuverturePortList.objects.all().prefetch_related('ouvertureport_set').prefetch_related('interface_set', 'interface_set__ipv4'):
|
for o in OuverturePortList.objects.all().prefetch_related('ouvertureport_set').prefetch_related('interface_set', 'interface_set__ipv4'):
|
||||||
|
@ -1220,7 +1220,7 @@ def ouverture_ports(request):
|
||||||
return JSONResponse(r)
|
return JSONResponse(r)
|
||||||
@csrf_exempt
|
@csrf_exempt
|
||||||
@login_required
|
@login_required
|
||||||
@permission_required('serveur')
|
@permission_required('machines.serveur')
|
||||||
def regen_achieved(request):
|
def regen_achieved(request):
|
||||||
obj = Service_link.objects.filter(service__in=Service.objects.filter(service_type=request.POST['service']), server__in=Interface.objects.filter(domain__in=Domain.objects.filter(name=request.POST['server'])))
|
obj = Service_link.objects.filter(service__in=Service.objects.filter(service_type=request.POST['service']), server__in=Interface.objects.filter(domain__in=Domain.objects.filter(name=request.POST['server'])))
|
||||||
if obj:
|
if obj:
|
||||||
|
|
|
@ -227,16 +227,24 @@ class Migration(migrations.Migration):
|
||||||
|
|
||||||
rights = apps.get_model("users", "ListRight")
|
rights = apps.get_model("users", "ListRight")
|
||||||
permissions = apps.get_model("auth", "Permission")
|
permissions = apps.get_model("auth", "Permission")
|
||||||
|
groups = apps.get_model("auth", "Group")
|
||||||
db_alias = schema_editor.connection.alias
|
db_alias = schema_editor.connection.alias
|
||||||
for group in permission_groups:
|
for group in permission_groups:
|
||||||
group_object = rights.objects.using(db_alias).filter(unix_name=group).first()
|
lr_object = rights.objects.using(db_alias).filter(unix_name=group).first()
|
||||||
if group_object:
|
if not lr_object:
|
||||||
group_object = group_object.group_ptr
|
last = rights.objects.using(db_alias).all().order_by('gid').last()
|
||||||
for permission in permission_groups[group]:
|
if last:
|
||||||
perm = permissions.objects.using(db_alias).filter(codename=permission).first()
|
gid = last.gid + 1
|
||||||
if perm:
|
else:
|
||||||
group_object.permissions.add(perm)
|
gid = 501
|
||||||
group_object.save()
|
group_object = groups.objects.using(db_alias).create(name=group)
|
||||||
|
lr_object = rights.objects.using(db_alias).create(unix_name=group, gid=gid, group_ptr=group_object)
|
||||||
|
lr_object = lr_object.group_ptr
|
||||||
|
for permission in permission_groups[group]:
|
||||||
|
perm = permissions.objects.using(db_alias).filter(codename=permission).first()
|
||||||
|
if perm:
|
||||||
|
lr_object.permissions.add(perm)
|
||||||
|
lr_object.save()
|
||||||
|
|
||||||
def untransfer_permissions(apps, schema_editor):
|
def untransfer_permissions(apps, schema_editor):
|
||||||
return
|
return
|
||||||
|
|
43
users/migrations/0067_serveurpermission.py
Normal file
43
users/migrations/0067_serveurpermission.py
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Generated by Django 1.10.7 on 2017-12-31 19:53
|
||||||
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('users', '0066_grouppermissions'),
|
||||||
|
]
|
||||||
|
|
||||||
|
def transfer_permissions(apps, schema_editor):
|
||||||
|
db_alias = schema_editor.connection.alias
|
||||||
|
contenttype = apps.get_model("contenttypes", "ContentType")
|
||||||
|
rights = apps.get_model("users", "ListRight")
|
||||||
|
permissions = apps.get_model("auth", "Permission")
|
||||||
|
groups = apps.get_model("auth", "Group")
|
||||||
|
machine = apps.get_model("machines", "Machine")
|
||||||
|
perm = permissions.objects.using(db_alias).filter(codename='serveur').first()
|
||||||
|
if not perm:
|
||||||
|
perm = permissions.objects.using(db_alias).create(
|
||||||
|
codename='serveur',
|
||||||
|
name='Serveur',
|
||||||
|
content_type=contenttype.objects.using(db_alias).get_for_model(machine)
|
||||||
|
)
|
||||||
|
group_object = rights.objects.using(db_alias).filter(unix_name='serveur').first()
|
||||||
|
if not group_object:
|
||||||
|
last_gid = rights.objects.using(db_alias).all().order_by('gid').last().gid
|
||||||
|
gid = last_gid + 1
|
||||||
|
abstract_group = groups.objects.using(db_alias).create(name='serveur')
|
||||||
|
group_object = rights.objects.using(db_alias).create(group_ptr=abstract_group, unix_name='serveur', gid=gid)
|
||||||
|
group_object = group_object.group_ptr
|
||||||
|
group_object.permissions.add(perm)
|
||||||
|
group_object.save()
|
||||||
|
|
||||||
|
def untransfer_permissions(apps, schema_editor):
|
||||||
|
return
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RunPython(transfer_permissions, untransfer_permissions),
|
||||||
|
]
|
Loading…
Reference in a new issue