1
0
mirror of https://github.com/netbox-community/netbox.git synced 2024-05-10 07:54:54 +00:00

Converted DCIM rack add/edit/delete views to CBVs

This commit is contained in:
Jeremy Stretch
2016-05-03 16:35:11 -04:00
parent d51992e98b
commit c6c1ea7466
4 changed files with 96 additions and 74 deletions

View File

@ -25,13 +25,13 @@ urlpatterns = [
# Racks # Racks
url(r'^racks/$', views.RackListView.as_view(), name='rack_list'), url(r'^racks/$', views.RackListView.as_view(), name='rack_list'),
url(r'^racks/add/$', views.rack_add, name='rack_add'), url(r'^racks/add/$', views.RackAddView.as_view(), name='rack_add'),
url(r'^racks/import/$', views.RackBulkImportView.as_view(), name='rack_import'), url(r'^racks/import/$', views.RackBulkImportView.as_view(), name='rack_import'),
url(r'^racks/edit/$', views.RackBulkEditView.as_view(), name='rack_bulk_edit'), url(r'^racks/edit/$', views.RackBulkEditView.as_view(), name='rack_bulk_edit'),
url(r'^racks/delete/$', views.RackBulkDeleteView.as_view(), name='rack_bulk_delete'), url(r'^racks/delete/$', views.RackBulkDeleteView.as_view(), name='rack_bulk_delete'),
url(r'^racks/(?P<pk>\d+)/$', views.rack, name='rack'), url(r'^racks/(?P<pk>\d+)/$', views.rack, name='rack'),
url(r'^racks/(?P<pk>\d+)/edit/$', views.rack_edit, name='rack_edit'), url(r'^racks/(?P<pk>\d+)/edit/$', views.RackEditView.as_view(), name='rack_edit'),
url(r'^racks/(?P<pk>\d+)/delete/$', views.rack_delete, name='rack_delete'), url(r'^racks/(?P<pk>\d+)/delete/$', views.RackDeleteView.as_view(), name='rack_delete'),
# Device types # Device types
url(r'^device-types/$', views.DeviceTypeListView.as_view(), name='devicetype_list'), url(r'^device-types/$', views.DeviceTypeListView.as_view(), name='devicetype_list'),

View File

@ -198,78 +198,100 @@ def rack(request, pk):
}) })
@permission_required('dcim.add_rack') class RackAddView(PermissionRequiredMixin, ObjectAddView):
def rack_add(request): permission_required = 'dcim.add_rack'
model = Rack
if request.method == 'POST': form_class = RackForm
form = RackForm(request.POST) template_name = 'dcim/rack_edit.html'
if form.is_valid(): cancel_url = 'dcim:rack_list'
rack = form.save()
messages.success(request, "Added new rack to {}: {}".format(rack.site.name, rack))
if '_addanother' in request.POST:
base_url = reverse('dcim:rack_add')
params = urlencode({
'site': rack.site.pk,
})
return HttpResponseRedirect('{}?{}'.format(base_url, params))
else:
return redirect('dcim:rack', pk=rack.pk)
else:
form = RackForm()
return render(request, 'dcim/rack_edit.html', {
'form': form,
'cancel_url': reverse('dcim:rack_list'),
})
@permission_required('dcim.change_rack') # @permission_required('dcim.add_rack')
def rack_edit(request, pk): # def rack_add(request):
#
rack = get_object_or_404(Rack, pk=pk) # if request.method == 'POST':
# form = RackForm(request.POST)
if request.method == 'POST': # if form.is_valid():
form = RackForm(request.POST, instance=rack) # rack = form.save()
if form.is_valid(): # messages.success(request, "Added new rack to {}: {}".format(rack.site.name, rack))
rack = form.save() # if '_addanother' in request.POST:
messages.success(request, "Modified rack {0}".format(rack.name)) # base_url = reverse('dcim:rack_add')
return redirect('dcim:rack', pk=rack.pk) # params = urlencode({
# 'site': rack.site.pk,
else: # })
form = RackForm(instance=rack) # return HttpResponseRedirect('{}?{}'.format(base_url, params))
# else:
return render(request, 'dcim/rack_edit.html', { # return redirect('dcim:rack', pk=rack.pk)
'rack': rack, #
'form': form, # else:
'cancel_url': reverse('dcim:rack', kwargs={'pk': rack.pk}), # form = RackForm()
}) #
# return render(request, 'dcim/rack_edit.html', {
# 'form': form,
# 'cancel_url': reverse('dcim:rack_list'),
# })
@permission_required('dcim.delete_rack') # @permission_required('dcim.change_rack')
def rack_delete(request, pk): # def rack_edit(request, pk):
#
# rack = get_object_or_404(Rack, pk=pk)
#
# if request.method == 'POST':
# form = RackForm(request.POST, instance=rack)
# if form.is_valid():
# rack = form.save()
# messages.success(request, "Modified rack {0}".format(rack.name))
# return redirect('dcim:rack', pk=rack.pk)
#
# else:
# form = RackForm(instance=rack)
#
# return render(request, 'dcim/rack_edit.html', {
# 'rack': rack,
# 'form': form,
# 'cancel_url': reverse('dcim:rack', kwargs={'pk': rack.pk}),
# })
rack = get_object_or_404(Rack, pk=pk)
if request.method == 'POST': class RackEditView(PermissionRequiredMixin, ObjectEditView):
form = ConfirmationForm(request.POST) permission_required = 'dcim.change_rack'
if form.is_valid(): model = Rack
try: form_class = RackForm
rack.delete() template_name = 'dcim/rack_edit.html'
messages.success(request, "Rack {0} has been deleted".format(rack))
return redirect('dcim:rack_list')
except ProtectedError, e:
handle_protectederror(rack, request, e)
return redirect('dcim:rack', pk=rack.pk)
else:
form = ConfirmationForm()
return render(request, 'dcim/rack_delete.html', { # @permission_required('dcim.delete_rack')
'rack': rack, # def rack_delete(request, pk):
'form': form, #
'cancel_url': reverse('dcim:rack', kwargs={'pk': rack.pk}), # rack = get_object_or_404(Rack, pk=pk)
}) #
# if request.method == 'POST':
# form = ConfirmationForm(request.POST)
# if form.is_valid():
# try:
# rack.delete()
# messages.success(request, "Rack {0} has been deleted".format(rack))
# return redirect('dcim:rack_list')
# except ProtectedError, e:
# handle_protectederror(rack, request, e)
# return redirect('dcim:rack', pk=rack.pk)
#
# else:
# form = ConfirmationForm()
#
# return render(request, 'dcim/rack_delete.html', {
# 'rack': rack,
# 'form': form,
# 'cancel_url': reverse('dcim:rack', kwargs={'pk': rack.pk}),
# })
class RackDeleteView(PermissionRequiredMixin, ObjectDeleteView):
permission_required = 'dcim.delete_rack'
model = Rack
template_name = 'dcim/rack_delete.html'
redirect_url = 'dcim:rack_list'
class RackBulkImportView(PermissionRequiredMixin, BulkImportView): class RackBulkImportView(PermissionRequiredMixin, BulkImportView):

View File

@ -1,8 +1,8 @@
{% extends 'utilities/confirmation_form.html' %} {% extends 'utilities/confirmation_form.html' %}
{% load form_helpers %} {% load form_helpers %}
{% block title %}Delete rack {{ rack }}?{% endblock %} {% block title %}Delete rack {{ obj }}?{% endblock %}
{% block message %} {% block message %}
<p>Are you sure you want to delete rack {{ rack }} from {{ rack.site }}?</p> <p>Are you sure you want to delete rack {{ obj }} from {{ obj.site }}?</p>
{% endblock %} {% endblock %}

View File

@ -1,11 +1,11 @@
{% extends '_base.html' %} {% extends '_base.html' %}
{% load form_helpers %} {% load form_helpers %}
{% block title %}{% if rack %}Editing rack {{ rack }}{% else %}Add a rack{% endif %}{% endblock %} {% block title %}{% if obj %}Editing rack {{ obj }}{% else %}Add a rack{% endif %}{% endblock %}
{% block content %} {% block content %}
{% if rack %} {% if obj %}
<h1>Rack {{ rack }}</h1> <h1>Rack {{ obj }}</h1>
{% else %} {% else %}
<h1>Add a Rack</h1> <h1>Add a Rack</h1>
{% endif %} {% endif %}
@ -47,9 +47,9 @@
</div> </div>
<div class="row"> <div class="row">
<div class="col-md-12 text-right"> <div class="col-md-12 text-right">
{% if rack %} {% if obj %}
<button type="submit" name="_update" class="btn btn-primary">Update</button> <button type="submit" name="_update" class="btn btn-primary">Update</button>
<a href="{% url 'dcim:rack' pk=rack.pk %}" class="btn btn-default">Cancel</a> <a href="{% url 'dcim:rack' pk=obj.pk %}" class="btn btn-default">Cancel</a>
{% else %} {% else %}
<button type="submit" name="_create" class="btn btn-primary">Create</button> <button type="submit" name="_create" class="btn btn-primary">Create</button>
<button type="submit" name="_addanother" class="btn btn-primary">Create and Add Another</button> <button type="submit" name="_addanother" class="btn btn-primary">Create and Add Another</button>