mirror of
https://github.com/netbox-community/netbox.git
synced 2024-05-10 07:54:54 +00:00
Converted DCIM DeviceType add/edit/delete views to CBVs
This commit is contained in:
@ -293,6 +293,9 @@ class DeviceType(models.Model):
|
|||||||
def __unicode__(self):
|
def __unicode__(self):
|
||||||
return "{0} {1}".format(self.manufacturer, self.model)
|
return "{0} {1}".format(self.manufacturer, self.model)
|
||||||
|
|
||||||
|
def get_absolute_url(self):
|
||||||
|
return reverse('dcim:devicetype', args=[self.pk])
|
||||||
|
|
||||||
|
|
||||||
class ConsolePortTemplate(models.Model):
|
class ConsolePortTemplate(models.Model):
|
||||||
"""
|
"""
|
||||||
|
@ -35,12 +35,12 @@ urlpatterns = [
|
|||||||
|
|
||||||
# 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'),
|
||||||
url(r'^device-types/add/$', views.devicetype_add, name='devicetype_add'),
|
url(r'^device-types/add/$', views.DeviceTypeAddView.as_view(), name='devicetype_add'),
|
||||||
url(r'^device-types/edit/$', views.DeviceTypeBulkEditView.as_view(), name='devicetype_bulk_edit'),
|
url(r'^device-types/edit/$', views.DeviceTypeBulkEditView.as_view(), name='devicetype_bulk_edit'),
|
||||||
url(r'^device-types/delete/$', views.DeviceTypeBulkDeleteView.as_view(), name='devicetype_bulk_delete'),
|
url(r'^device-types/delete/$', views.DeviceTypeBulkDeleteView.as_view(), name='devicetype_bulk_delete'),
|
||||||
url(r'^device-types/(?P<pk>\d+)/$', views.devicetype, name='devicetype'),
|
url(r'^device-types/(?P<pk>\d+)/$', views.devicetype, name='devicetype'),
|
||||||
url(r'^device-types/(?P<pk>\d+)/edit/$', views.devicetype_edit, name='devicetype_edit'),
|
url(r'^device-types/(?P<pk>\d+)/edit/$', views.DeviceTypeEditView.as_view(), name='devicetype_edit'),
|
||||||
url(r'^device-types/(?P<pk>\d+)/delete/$', views.devicetype_delete, name='devicetype_delete'),
|
url(r'^device-types/(?P<pk>\d+)/delete/$', views.DeviceTypeDeleteView.as_view(), name='devicetype_delete'),
|
||||||
|
|
||||||
# Component templates
|
# Component templates
|
||||||
url(r'^device-types/(?P<pk>\d+)/console-ports/add/$', views.ConsolePortTemplateAddView.as_view(),
|
url(r'^device-types/(?P<pk>\d+)/console-ports/add/$', views.ConsolePortTemplateAddView.as_view(),
|
||||||
|
@ -206,54 +206,6 @@ class RackAddView(PermissionRequiredMixin, ObjectAddView):
|
|||||||
cancel_url = 'dcim:rack_list'
|
cancel_url = 'dcim:rack_list'
|
||||||
|
|
||||||
|
|
||||||
# @permission_required('dcim.add_rack')
|
|
||||||
# def rack_add(request):
|
|
||||||
#
|
|
||||||
# if request.method == 'POST':
|
|
||||||
# form = RackForm(request.POST)
|
|
||||||
# if form.is_valid():
|
|
||||||
# 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')
|
|
||||||
# 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}),
|
|
||||||
# })
|
|
||||||
|
|
||||||
|
|
||||||
class RackEditView(PermissionRequiredMixin, ObjectEditView):
|
class RackEditView(PermissionRequiredMixin, ObjectEditView):
|
||||||
permission_required = 'dcim.change_rack'
|
permission_required = 'dcim.change_rack'
|
||||||
model = Rack
|
model = Rack
|
||||||
@ -261,32 +213,6 @@ class RackEditView(PermissionRequiredMixin, ObjectEditView):
|
|||||||
template_name = 'dcim/rack_edit.html'
|
template_name = 'dcim/rack_edit.html'
|
||||||
|
|
||||||
|
|
||||||
# @permission_required('dcim.delete_rack')
|
|
||||||
# def rack_delete(request, 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):
|
class RackDeleteView(PermissionRequiredMixin, ObjectDeleteView):
|
||||||
permission_required = 'dcim.delete_rack'
|
permission_required = 'dcim.delete_rack'
|
||||||
model = Rack
|
model = Rack
|
||||||
@ -370,74 +296,26 @@ def devicetype(request, pk):
|
|||||||
})
|
})
|
||||||
|
|
||||||
|
|
||||||
@permission_required('dcim.add_devicetype')
|
class DeviceTypeAddView(PermissionRequiredMixin, ObjectAddView):
|
||||||
def devicetype_add(request):
|
permission_required = 'dcim.add_devicetype'
|
||||||
|
model = DeviceType
|
||||||
if request.method == 'POST':
|
form_class = DeviceTypeForm
|
||||||
form = DeviceTypeForm(request.POST)
|
template_name = 'dcim/devicetype_edit.html'
|
||||||
if form.is_valid():
|
cancel_url = 'dcim:devicetype_list'
|
||||||
devicetype = form.save()
|
|
||||||
messages.success(request, "Added new device type: {}".format(devicetype))
|
|
||||||
if '_addanother' in request.POST:
|
|
||||||
return redirect('dcim:devicetype_add')
|
|
||||||
else:
|
|
||||||
return redirect('dcim:devicetype', pk=devicetype.pk)
|
|
||||||
|
|
||||||
else:
|
|
||||||
form = DeviceTypeForm()
|
|
||||||
|
|
||||||
return render(request, 'dcim/devicetype_edit.html', {
|
|
||||||
'form': form,
|
|
||||||
'cancel_url': reverse('dcim:devicetype_list'),
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
@permission_required('dcim.change_devicetype')
|
class DeviceTypeEditView(PermissionRequiredMixin, ObjectEditView):
|
||||||
def devicetype_edit(request, pk):
|
permission_required = 'dcim.change_devicetype'
|
||||||
|
model = DeviceType
|
||||||
devicetype = get_object_or_404(DeviceType, pk=pk)
|
form_class = DeviceTypeForm
|
||||||
|
template_name = 'dcim/devicetype_edit.html'
|
||||||
if request.method == 'POST':
|
|
||||||
form = DeviceTypeForm(request.POST, instance=devicetype)
|
|
||||||
if form.is_valid():
|
|
||||||
devicetype = form.save()
|
|
||||||
messages.success(request, "Modified device type {}".format(devicetype))
|
|
||||||
return redirect('dcim:devicetype', pk=devicetype.pk)
|
|
||||||
|
|
||||||
else:
|
|
||||||
form = DeviceTypeForm(instance=devicetype)
|
|
||||||
|
|
||||||
return render(request, 'dcim/devicetype_edit.html', {
|
|
||||||
'devicetype': devicetype,
|
|
||||||
'form': form,
|
|
||||||
'cancel_url': reverse('dcim:devicetype', kwargs={'pk': devicetype.pk}),
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
@permission_required('dcim.delete_devicetype')
|
class DeviceTypeDeleteView(PermissionRequiredMixin, ObjectDeleteView):
|
||||||
def devicetype_delete(request, pk):
|
permission_required = 'dcim.delete_devicetype'
|
||||||
|
model = DeviceType
|
||||||
devicetype = get_object_or_404(DeviceType, pk=pk)
|
template_name = 'dcim/devicetype_delete.html'
|
||||||
|
redirect_url = 'dcim:devicetype_list'
|
||||||
if request.method == 'POST':
|
|
||||||
form = ConfirmationForm(request.POST)
|
|
||||||
if form.is_valid():
|
|
||||||
try:
|
|
||||||
devicetype.delete()
|
|
||||||
messages.success(request, "Device type {} has been deleted".format(devicetype))
|
|
||||||
return redirect('dcim:devicetype_list')
|
|
||||||
except ProtectedError, e:
|
|
||||||
handle_protectederror(devicetype, request, e)
|
|
||||||
return redirect('dcim:devicetype', pk=devicetype.pk)
|
|
||||||
|
|
||||||
else:
|
|
||||||
form = ConfirmationForm()
|
|
||||||
|
|
||||||
return render(request, 'dcim/devicetype_delete.html', {
|
|
||||||
'devicetype': device,
|
|
||||||
'form': form,
|
|
||||||
'cancel_url': reverse('dcim:devicetype', kwargs={'pk': devicetype.pk}),
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
class DeviceTypeBulkEditView(PermissionRequiredMixin, BulkEditView):
|
class DeviceTypeBulkEditView(PermissionRequiredMixin, BulkEditView):
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
{% extends 'utilities/confirmation_form.html' %}
|
{% extends 'utilities/confirmation_form.html' %}
|
||||||
{% load form_helpers %}
|
{% load form_helpers %}
|
||||||
|
|
||||||
{% block title %}Delete device type {{ devicetype }}?{% endblock %}
|
{% block title %}Delete device type {{ obj }}?{% endblock %}
|
||||||
|
|
||||||
{% block message %}
|
{% block message %}
|
||||||
<p>Are you sure you want to delete <strong>{{ devicetype }}</strong>?</p>
|
<p>Are you sure you want to delete <strong>{{ obj }}</strong>?</p>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
{% extends '_base.html' %}
|
{% extends '_base.html' %}
|
||||||
{% load form_helpers %}
|
{% load form_helpers %}
|
||||||
|
|
||||||
{% block title %}{% if devicetype %}Editing device type {{ devicetype }}{% else %}Add a Device Type{% endif %}{% endblock %}
|
{% block title %}{% if obj %}Editing device type {{ obj }}{% else %}Add a Device Type{% endif %}{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
{% if devicetype %}
|
{% if obj %}
|
||||||
<h1>{{ devicetype }}</h1>
|
<h1>{{ obj }}</h1>
|
||||||
{% else %}
|
{% else %}
|
||||||
<h1>Add a Device Type</h1>
|
<h1>Add a Device Type</h1>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
@ -35,9 +35,9 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-md-6 col-md-offset-3 text-center">
|
<div class="col-md-6 col-md-offset-3 text-center">
|
||||||
{% if devicetype %}
|
{% 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:devicetype' pk=devicetype.pk %}" class="btn btn-default">Cancel</a>
|
<a href="{% url 'dcim:devicetype' 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>
|
||||||
|
Reference in New Issue
Block a user