mirror of
https://gitlab2.federez.net/re2o/re2o
synced 2025-01-12 19:24:28 +00:00
670 lines
24 KiB
Python
670 lines
24 KiB
Python
# Re2o est un logiciel d'administration développé initiallement au rezometz. Il
|
|
# se veut agnostique au réseau considéré, de manière à être installable en
|
|
# quelques clics.
|
|
#
|
|
# Copyright © 2017 Gabriel Détraz
|
|
# Copyright © 2017 Goulven Kermarec
|
|
# Copyright © 2017 Augustin Lemesle
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License along
|
|
# with this program; if not, write to the Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
"""
|
|
Page des vues de l'application topologie
|
|
|
|
Permet de créer, modifier et supprimer :
|
|
- un port (add_port, edit_port, del_port)
|
|
- un switch : les vues d'ajout et d'édition font appel aux forms de creation
|
|
de switch, mais aussi aux forms de machines.forms (domain, interface et
|
|
machine). Le views les envoie et les save en même temps. TODO : rationaliser
|
|
et faire que la creation de machines (interfaces, domain etc) soit gérée
|
|
coté models et forms de topologie
|
|
- une chambre (new_room, edit_room, del_room)
|
|
- une stack
|
|
- l'historique de tous les objets cités
|
|
"""
|
|
from __future__ import unicode_literals
|
|
|
|
from django.urls import reverse
|
|
from django.shortcuts import render, redirect
|
|
from django.contrib import messages
|
|
from django.contrib.auth.decorators import login_required, permission_required
|
|
from django.db import IntegrityError
|
|
from django.db import transaction
|
|
from django.db.models import ProtectedError
|
|
from django.core.exceptions import ValidationError
|
|
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
|
|
from reversion import revisions as reversion
|
|
from reversion.models import Version
|
|
|
|
from topologie.models import (
|
|
Switch,
|
|
Port,
|
|
Room,
|
|
Stack,
|
|
ModelSwitch,
|
|
ConstructorSwitch
|
|
)
|
|
from topologie.forms import EditPortForm, NewSwitchForm, EditSwitchForm
|
|
from topologie.forms import (
|
|
AddPortForm,
|
|
EditRoomForm,
|
|
StackForm,
|
|
EditModelSwitchForm,
|
|
EditConstructorSwitchForm,
|
|
CreatePortsForm
|
|
)
|
|
from users.views import form
|
|
from re2o.utils import SortTable
|
|
from re2o.acl import (
|
|
can_create,
|
|
can_edit,
|
|
can_delete,
|
|
can_view,
|
|
can_view_all,
|
|
)
|
|
from machines.forms import (
|
|
DomainForm,
|
|
NewMachineForm,
|
|
EditMachineForm,
|
|
EditInterfaceForm,
|
|
AddInterfaceForm
|
|
)
|
|
from machines.views import generate_ipv4_mbf_param
|
|
from preferences.models import AssoOption, GeneralOption
|
|
|
|
|
|
@login_required
|
|
@can_view_all(Switch)
|
|
def index(request):
|
|
""" Vue d'affichage de tous les swicthes"""
|
|
switch_list = Switch.objects\
|
|
.select_related('switch_interface__domain__extension')\
|
|
.select_related('switch_interface__ipv4')\
|
|
.select_related('switch_interface__domain')\
|
|
.select_related('stack')
|
|
switch_list = SortTable.sort(
|
|
switch_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX
|
|
)
|
|
options, _created = GeneralOption.objects.get_or_create()
|
|
pagination_number = options.pagination_number
|
|
paginator = Paginator(switch_list, pagination_number)
|
|
page = request.GET.get('page')
|
|
try:
|
|
switch_list = paginator.page(page)
|
|
except PageNotAnInteger:
|
|
# If page is not an integer, deliver first page.
|
|
switch_list = paginator.page(1)
|
|
except EmptyPage:
|
|
# If page is out of range (e.g. 9999), deliver last page of results.
|
|
switch_list = paginator.page(paginator.num_pages)
|
|
return render(request, 'topologie/index.html', {
|
|
'switch_list': switch_list
|
|
})
|
|
|
|
|
|
@login_required
|
|
@can_view_all(Port)
|
|
@can_view(Switch)
|
|
def index_port(request, switch, switch_id):
|
|
""" Affichage de l'ensemble des ports reliés à un switch particulier"""
|
|
port_list = Port.objects.filter(switch=switch)\
|
|
.select_related('room')\
|
|
.select_related('machine_interface__domain__extension')\
|
|
.select_related('machine_interface__machine__user')\
|
|
.select_related(
|
|
'related__switch__switch_interface__domain__extension'
|
|
)\
|
|
.select_related('switch')
|
|
port_list = SortTable.sort(
|
|
port_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX_PORT
|
|
)
|
|
return render(request, 'topologie/index_p.html', {
|
|
'port_list': port_list,
|
|
'id_switch': switch_id,
|
|
'nom_switch': switch
|
|
})
|
|
|
|
|
|
@login_required
|
|
@can_view_all(Room)
|
|
def index_room(request):
|
|
""" Affichage de l'ensemble des chambres"""
|
|
room_list = Room.objects
|
|
room_list = SortTable.sort(
|
|
room_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX_ROOM
|
|
)
|
|
options, _created = GeneralOption.objects.get_or_create()
|
|
pagination_number = options.pagination_number
|
|
paginator = Paginator(room_list, pagination_number)
|
|
page = request.GET.get('page')
|
|
try:
|
|
room_list = paginator.page(page)
|
|
except PageNotAnInteger:
|
|
# If page is not an integer, deliver first page.
|
|
room_list = paginator.page(1)
|
|
except EmptyPage:
|
|
# If page is out of range (e.g. 9999), deliver last page of results.
|
|
room_list = paginator.page(paginator.num_pages)
|
|
return render(request, 'topologie/index_room.html', {
|
|
'room_list': room_list
|
|
})
|
|
|
|
|
|
@login_required
|
|
@can_view_all(Stack)
|
|
def index_stack(request):
|
|
"""Affichage de la liste des stacks (affiche l'ensemble des switches)"""
|
|
stack_list = Stack.objects\
|
|
.prefetch_related('switch_set__switch_interface__domain__extension')
|
|
stack_list = SortTable.sort(
|
|
stack_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX_STACK
|
|
)
|
|
return render(request, 'topologie/index_stack.html', {
|
|
'stack_list': stack_list
|
|
})
|
|
|
|
|
|
@login_required
|
|
@can_view_all(ModelSwitch)
|
|
@can_view_all(ConstructorSwitch)
|
|
def index_model_switch(request):
|
|
""" Affichage de l'ensemble des modèles de switches"""
|
|
model_switch_list = ModelSwitch.objects
|
|
constructor_switch_list = ConstructorSwitch.objects
|
|
model_switch_list = SortTable.sort(
|
|
model_switch_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX_MODEL_SWITCH
|
|
)
|
|
constructor_switch_list = SortTable.sort(
|
|
constructor_switch_list,
|
|
request.GET.get('col'),
|
|
request.GET.get('order'),
|
|
SortTable.TOPOLOGIE_INDEX_CONSTRUCTOR_SWITCH
|
|
)
|
|
return render(request, 'topologie/index_model_switch.html', {
|
|
'model_switch_list': model_switch_list,
|
|
'constructor_switch_list': constructor_switch_list,
|
|
})
|
|
|
|
|
|
@login_required
|
|
@can_create(Port)
|
|
def new_port(request, switch_id):
|
|
""" Nouveau port"""
|
|
try:
|
|
switch = Switch.objects.get(pk=switch_id)
|
|
except Switch.DoesNotExist:
|
|
messages.error(request, u"Switch inexistant")
|
|
return redirect(reverse('topologie:index'))
|
|
port = AddPortForm(request.POST or None)
|
|
if port.is_valid():
|
|
port = port.save(commit=False)
|
|
port.switch = switch
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
port.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "Port ajouté")
|
|
except IntegrityError:
|
|
messages.error(request, "Ce port existe déjà")
|
|
return redirect(reverse(
|
|
'topologie:index-port',
|
|
kwargs={'switch_id':switch_id}
|
|
))
|
|
return form({'id_switch': switch_id,'topoform': port}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(Port)
|
|
def edit_port(request, port_object, port_id):
|
|
""" Edition d'un port. Permet de changer le switch parent et
|
|
l'affectation du port"""
|
|
|
|
port = EditPortForm(request.POST or None, instance=port_object)
|
|
if port.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
port.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in port.changed_data
|
|
))
|
|
messages.success(request, "Le port a bien été modifié")
|
|
return redirect(reverse(
|
|
'topologie:index-port',
|
|
kwargs={'switch_id': str(port_object.switch.id)}
|
|
))
|
|
return form({'id_switch': str(port_object.switch.id), 'topoform': port}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_delete(Port)
|
|
def del_port(request, port, port_id):
|
|
""" Supprime le port"""
|
|
if request.method == "POST":
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
port.delete()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Destruction")
|
|
messages.success(request, "Le port a été détruit")
|
|
except ProtectedError:
|
|
messages.error(request, "Le port %s est affecté à un autre objet,\
|
|
impossible de le supprimer" % port)
|
|
return redirect(reverse(
|
|
'topologie:index-port',
|
|
kwargs={'switch_id':str(port.switch.id)}
|
|
))
|
|
return form({'objet': port}, 'topologie/delete.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_create(Stack)
|
|
def new_stack(request):
|
|
"""Ajoute un nouveau stack : stack_id_min, max, et nombre de switches"""
|
|
stack = StackForm(request.POST or None)
|
|
if stack.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
stack.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "Stack crée")
|
|
return form({'topoform': stack}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(Stack)
|
|
def edit_stack(request, stack, stack_id):
|
|
"""Edition d'un stack (nombre de switches, nom...)"""
|
|
|
|
stack = StackForm(request.POST or None, instance=stack)
|
|
if stack.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
stack.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment(
|
|
"Champs modifié(s) : %s" % ', '.join(
|
|
field for field in stack.changed_data
|
|
)
|
|
)
|
|
return redirect(reverse('topologie:index-stack'))
|
|
return form({'topoform': stack}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_delete(Stack)
|
|
def del_stack(request, stack, stack_id):
|
|
"""Supprime un stack"""
|
|
if request.method == "POST":
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
stack.delete()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Destruction")
|
|
messages.success(request, "La stack a eté détruite")
|
|
except ProtectedError:
|
|
messages.error(request, "La stack %s est affectée à un autre\
|
|
objet, impossible de la supprimer" % stack)
|
|
return redirect(reverse('topologie:index-stack'))
|
|
return form({'objet': stack}, 'topologie/delete.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(Stack)
|
|
def edit_switchs_stack(request, stack, stack_id):
|
|
"""Permet d'éditer la liste des switches dans une stack et l'ajouter"""
|
|
|
|
if request.method == "POST":
|
|
pass
|
|
else:
|
|
context = {'stack': stack}
|
|
context['switchs_stack'] = stack.switchs_set.all()
|
|
context['switchs_autres'] = Switch.object.filter(stack=None)
|
|
|
|
|
|
@login_required
|
|
@can_create(Switch)
|
|
def new_switch(request):
|
|
""" Creation d'un switch. Cree en meme temps l'interface et la machine
|
|
associée. Vue complexe. Appelle successivement les 4 models forms
|
|
adaptés : machine, interface, domain et switch"""
|
|
switch = NewSwitchForm(request.POST or None)
|
|
machine = NewMachineForm(
|
|
request.POST or None,
|
|
user=request.user
|
|
)
|
|
interface = AddInterfaceForm(
|
|
request.POST or None,
|
|
user=request.user
|
|
)
|
|
domain = DomainForm(
|
|
request.POST or None,
|
|
)
|
|
if switch.is_valid() and machine.is_valid() and interface.is_valid():
|
|
options, _created = AssoOption.objects.get_or_create()
|
|
user = options.utilisateur_asso
|
|
if not user:
|
|
messages.error(request, "L'user association n'existe pas encore,\
|
|
veuillez le créer ou le linker dans preferences")
|
|
return redirect(reverse('topologie:index'))
|
|
new_machine = machine.save(commit=False)
|
|
new_machine.user = user
|
|
new_interface = interface.save(commit=False)
|
|
new_switch_instance = switch.save(commit=False)
|
|
new_domain_instance = domain.save(commit=False)
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_machine.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
new_interface.machine = new_machine
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_interface.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
new_domain_instance.interface_parent = new_interface
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_domain_instance.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
new_switch_instance.switch_interface = new_interface
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_switch_instance.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "Le switch a été créé")
|
|
return redirect(reverse('topologie:index'))
|
|
i_mbf_param = generate_ipv4_mbf_param( interface, False)
|
|
return form({
|
|
'topoform': switch,
|
|
'machineform': machine,
|
|
'interfaceform': interface,
|
|
'domainform': domain,
|
|
'i_mbf_param': i_mbf_param
|
|
}, 'topologie/switch.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_create(Port)
|
|
def create_ports(request, switch_id):
|
|
""" Création d'une liste de ports pour un switch."""
|
|
try:
|
|
switch = Switch.objects.get(pk=switch_id)
|
|
except Switch.DoesNotExist:
|
|
messages.error(request, u"Switch inexistant")
|
|
return redirect("/topologie/")
|
|
|
|
s_begin = s_end = 0
|
|
nb_ports = switch.ports.count()
|
|
if nb_ports > 0:
|
|
ports = switch.ports.order_by('port').values('port')
|
|
s_begin = ports.first().get('port')
|
|
s_end = ports.last().get('port')
|
|
|
|
port_form = CreatePortsForm(
|
|
request.POST or None,
|
|
initial={'begin': s_begin, 'end': s_end}
|
|
)
|
|
|
|
if port_form.is_valid():
|
|
begin = port_form.cleaned_data['begin']
|
|
end = port_form.cleaned_data['end']
|
|
try:
|
|
switch.create_ports(begin, end)
|
|
messages.success(request, "Ports créés.")
|
|
except ValidationError as e:
|
|
messages.error(request, ''.join(e))
|
|
|
|
return redirect("/topologie/switch/" + str(switch.id))
|
|
|
|
return form({'id_switch': switch_id, 'topoform': port_form}, 'topologie/switch.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(Switch)
|
|
def edit_switch(request, switch, switch_id):
|
|
""" Edition d'un switch. Permet de chambre nombre de ports,
|
|
place dans le stack, interface et machine associée"""
|
|
|
|
switch_form = EditSwitchForm(request.POST or None, instance=switch)
|
|
machine_form = EditMachineForm(
|
|
request.POST or None,
|
|
instance=switch.switch_interface.machine
|
|
)
|
|
interface_form = EditInterfaceForm(
|
|
request.POST or None,
|
|
instance=switch.switch_interface
|
|
)
|
|
domain_form = DomainForm(
|
|
request.POST or None,
|
|
instance=switch.switch_interface.domain
|
|
)
|
|
if switch_form.is_valid() and machine_form.is_valid()\
|
|
and interface_form.is_valid():
|
|
new_interface = interface_form.save(commit=False)
|
|
new_machine = machine_form.save(commit=False)
|
|
new_switch_instance = switch_form.save(commit=False)
|
|
new_domain = domain_form.save(commit=False)
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_machine.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment(
|
|
"Champs modifié(s) : %s" % ', '.join(
|
|
field for field in machine_form.changed_data
|
|
)
|
|
)
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_interface.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in interface_form.changed_data)
|
|
)
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_domain.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in domain_form.changed_data)
|
|
)
|
|
with transaction.atomic(), reversion.create_revision():
|
|
new_switch_instance.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in switch_form.changed_data)
|
|
)
|
|
messages.success(request, "Le switch a bien été modifié")
|
|
return redirect(reverse('topologie:index'))
|
|
i_mbf_param = generate_ipv4_mbf_param( interface_form, False )
|
|
return form({
|
|
'id_switch': switch_id,
|
|
'topoform': switch_form,
|
|
'machineform': machine_form,
|
|
'interfaceform': interface_form,
|
|
'domainform': domain_form,
|
|
'i_mbf_param': i_mbf_param
|
|
}, 'topologie/switch.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_create(Room)
|
|
def new_room(request):
|
|
"""Nouvelle chambre """
|
|
room = EditRoomForm(request.POST or None)
|
|
if room.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
room.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "La chambre a été créé")
|
|
return redirect(reverse('topologie:index-room'))
|
|
return form({'topoform': room}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(Room)
|
|
def edit_room(request, room, room_id):
|
|
""" Edition numero et details de la chambre"""
|
|
|
|
room = EditRoomForm(request.POST or None, instance=room)
|
|
if room.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
room.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in room.changed_data)
|
|
)
|
|
messages.success(request, "La chambre a bien été modifiée")
|
|
return redirect(reverse('topologie:index-room'))
|
|
return form({'topoform': room}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_delete(Room)
|
|
def del_room(request, room, room_id):
|
|
""" Suppression d'un chambre"""
|
|
if request.method == "POST":
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
room.delete()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Destruction")
|
|
messages.success(request, "La chambre/prise a été détruite")
|
|
except ProtectedError:
|
|
messages.error(request, "La chambre %s est affectée à un autre objet,\
|
|
impossible de la supprimer (switch ou user)" % room)
|
|
return redirect(reverse('topologie:index-room'))
|
|
return form({
|
|
'objet': room,
|
|
'objet_name': 'Chambre'
|
|
}, 'topologie/delete.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_create(ModelSwitch)
|
|
def new_model_switch(request):
|
|
"""Nouveau modèle de switch"""
|
|
model_switch = EditModelSwitchForm(request.POST or None)
|
|
if model_switch.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
model_switch.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "Le modèle a été créé")
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({'topoform': model_switch}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(ModelSwitch)
|
|
def edit_model_switch(request, model_switch, model_switch_id):
|
|
""" Edition d'un modèle de switch"""
|
|
|
|
model_switch = EditModelSwitchForm(request.POST or None, instance=model_switch)
|
|
if model_switch.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
model_switch.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in model_switch.changed_data)
|
|
)
|
|
messages.success(request, "Le modèle a bien été modifié")
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({'topoform': model_switch}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_delete(ModelSwitch)
|
|
def del_model_switch(request, model_switch_id):
|
|
""" Suppression d'un modèle de switch"""
|
|
if request.method == "POST":
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
model_switch.delete()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Destruction")
|
|
messages.success(request, "Le modèle a été détruit")
|
|
except ProtectedError:
|
|
messages.error(request, "Le modèle %s est affectée à un autre objet,\
|
|
impossible de la supprimer (switch ou user)" % model_switch)
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({
|
|
'objet': model_switch,
|
|
'objet_name': 'Modèle de switch'
|
|
}, 'topologie/delete.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_create(ConstructorSwitch)
|
|
def new_constructor_switch(request):
|
|
"""Nouveau constructeur de switch"""
|
|
constructor_switch = EditConstructorSwitchForm(request.POST or None)
|
|
if constructor_switch.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
constructor_switch.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Création")
|
|
messages.success(request, "Le constructeur a été créé")
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({'topoform': constructor_switch}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_edit(ConstructorSwitch)
|
|
def edit_constructor_switch(request, constructor_switch, constructor_switch_id):
|
|
""" Edition d'un constructeur de switch"""
|
|
|
|
constructor_switch = EditConstructorSwitchForm(request.POST or None, instance=constructor_switch)
|
|
if constructor_switch.is_valid():
|
|
with transaction.atomic(), reversion.create_revision():
|
|
constructor_switch.save()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Champs modifié(s) : %s" % ', '.join(
|
|
field for field in constructor_switch.changed_data)
|
|
)
|
|
messages.success(request, "Le modèle a bien été modifié")
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({'topoform': constructor_switch}, 'topologie/topo.html', request)
|
|
|
|
|
|
@login_required
|
|
@can_delete(ConstructorSwitch)
|
|
def del_constructor_switch(request, constructor_switch_id):
|
|
""" Suppression d'un constructeur de switch"""
|
|
if request.method == "POST":
|
|
try:
|
|
with transaction.atomic(), reversion.create_revision():
|
|
constructor_switch.delete()
|
|
reversion.set_user(request.user)
|
|
reversion.set_comment("Destruction")
|
|
messages.success(request, "Le constructeur a été détruit")
|
|
except ProtectedError:
|
|
messages.error(request, "Le constructeur %s est affecté à un autre objet,\
|
|
impossible de la supprimer (switch ou user)" % constructor_switch)
|
|
return redirect("/topologie/index_model_switch/")
|
|
return form({
|
|
'objet': constructor_switch,
|
|
'objet_name': 'Constructeur de switch'
|
|
}, 'topologie/delete.html', request)
|