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

2931 lines
91 KiB
Python
Raw Normal View History

from collections import OrderedDict
2016-03-01 11:23:03 -05:00
from django.contrib import messages
2019-03-21 17:47:43 -04:00
from django.contrib.contenttypes.models import ContentType
from django.core.paginator import EmptyPage, PageNotAnInteger
from django.db import transaction
from django.db.models import F, Prefetch
from django.forms import ModelMultipleChoiceField, MultipleHiddenInput, modelformset_factory
2016-03-01 11:23:03 -05:00
from django.shortcuts import get_object_or_404, redirect, render
from django.utils.html import escape
from django.utils.safestring import mark_safe
from django.views.generic import View
2016-03-01 11:23:03 -05:00
from circuits.models import Circuit
from extras.views import ObjectChangeLogView, ObjectConfigContextView, ObjectJournalView
from ipam.models import IPAddress, Prefix, Service, VLAN
2018-07-11 15:30:54 -04:00
from ipam.tables import InterfaceIPAddressTable, InterfaceVLANTable
2020-11-11 16:07:38 -05:00
from netbox.views import generic
2020-06-01 11:43:49 -04:00
from secrets.models import Secret
2016-03-01 11:23:03 -05:00
from utilities.forms import ConfirmationForm
from utilities.paginator import EnhancedPaginator, get_paginate_count
from utilities.permissions import get_permission_for_model
from utilities.tables import paginate_table
from utilities.utils import csv_format, count_related
2020-11-11 16:07:38 -05:00
from utilities.views import GetReturnURLMixin, ObjectPermissionRequiredMixin
from virtualization.models import VirtualMachine
2016-05-18 16:02:53 -04:00
from . import filters, forms, tables
from .choices import DeviceFaceChoices
from .constants import NONCONNECTABLE_IFACE_TYPES
2016-05-18 16:02:53 -04:00
from .models import (
Cable, CablePath, ConsolePort, ConsolePortTemplate, ConsoleServerPort, ConsoleServerPortTemplate, Device, DeviceBay,
DeviceBayTemplate, DeviceRole, DeviceType, FrontPort, FrontPortTemplate, Interface, InterfaceTemplate,
InventoryItem, Manufacturer, PathEndpoint, Platform, PowerFeed, PowerOutlet, PowerOutletTemplate, PowerPanel,
PowerPort, PowerPortTemplate, Rack, Location, RackReservation, RackRole, RearPort, RearPortTemplate, Region, Site,
SiteGroup, VirtualChassis,
2016-05-18 16:02:53 -04:00
)
2016-03-01 11:23:03 -05:00
2020-05-21 16:34:15 -04:00
class BulkDisconnectView(GetReturnURLMixin, ObjectPermissionRequiredMixin, View):
"""
An extendable view for disconnection console/power/interface components in bulk.
"""
queryset = None
template_name = 'dcim/bulk_disconnect.html'
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
# Create a new Form class from ConfirmationForm
class _Form(ConfirmationForm):
pk = ModelMultipleChoiceField(
queryset=self.queryset,
widget=MultipleHiddenInput()
)
self.form = _Form
def get_required_permission(self):
return get_permission_for_model(self.queryset.model, 'change')
def post(self, request):
selected_objects = []
return_url = self.get_return_url(request)
if '_confirm' in request.POST:
form = self.form(request.POST)
if form.is_valid():
with transaction.atomic():
count = 0
for obj in self.queryset.filter(pk__in=form.cleaned_data['pk']):
if obj.cable is None:
continue
obj.cable.delete()
count += 1
messages.success(request, "Disconnected {} {}".format(
count, self.queryset.model._meta.verbose_name_plural
))
return redirect(return_url)
else:
form = self.form(initial={'pk': request.POST.getlist('pk')})
selected_objects = self.queryset.filter(pk__in=form.initial['pk'])
return render(request, self.template_name, {
'form': form,
'obj_type_plural': self.queryset.model._meta.verbose_name_plural,
'selected_objects': selected_objects,
'return_url': return_url,
})
2017-02-28 12:11:43 -05:00
#
# Regions
#
2020-11-11 16:07:38 -05:00
class RegionListView(generic.ObjectListView):
queryset = Region.objects.add_related_count(
Region.objects.all(),
Site,
'region',
'site_count',
cumulative=True
)
filterset = filters.RegionFilterSet
filterset_form = forms.RegionFilterForm
2017-02-28 12:11:43 -05:00
table = tables.RegionTable
class RegionView(generic.ObjectView):
queryset = Region.objects.all()
def get_extra_context(self, request, instance):
2021-04-06 09:42:36 -04:00
child_regions = Region.objects.add_related_count(
Region.objects.all(),
Site,
'region',
'site_count',
cumulative=True
).restrict(request.user, 'view').filter(
parent__in=instance.get_descendants(include_self=True)
)
child_regions_table = tables.RegionTable(child_regions)
sites = Site.objects.restrict(request.user, 'view').filter(
region=instance
)
sites_table = tables.SiteTable(sites)
sites_table.columns.hide('region')
paginate_table(sites_table, request)
return {
2021-04-06 09:42:36 -04:00
'child_regions_table': child_regions_table,
'sites_table': sites_table,
}
2020-11-11 16:07:38 -05:00
class RegionEditView(generic.ObjectEditView):
queryset = Region.objects.all()
model_form = forms.RegionForm
2017-02-28 12:11:43 -05:00
2020-11-11 16:07:38 -05:00
class RegionDeleteView(generic.ObjectDeleteView):
queryset = Region.objects.all()
2020-11-11 16:07:38 -05:00
class RegionBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Region.objects.all()
2017-07-18 01:50:26 +03:00
model_form = forms.RegionCSVForm
table = tables.RegionTable
class RegionBulkEditView(generic.BulkEditView):
queryset = Region.objects.add_related_count(
Region.objects.all(),
Site,
'region',
'site_count',
cumulative=True
)
filterset = filters.RegionFilterSet
table = tables.RegionTable
form = forms.RegionBulkEditForm
2020-11-11 16:07:38 -05:00
class RegionBulkDeleteView(generic.BulkDeleteView):
queryset = Region.objects.add_related_count(
Region.objects.all(),
Site,
'region',
'site_count',
cumulative=True
)
filterset = filters.RegionFilterSet
table = tables.RegionTable
2017-02-28 12:11:43 -05:00
#
# Site groups
#
class SiteGroupListView(generic.ObjectListView):
queryset = SiteGroup.objects.add_related_count(
SiteGroup.objects.all(),
Site,
'group',
'site_count',
cumulative=True
)
filterset = filters.SiteGroupFilterSet
filterset_form = forms.SiteGroupFilterForm
table = tables.SiteGroupTable
class SiteGroupView(generic.ObjectView):
queryset = SiteGroup.objects.all()
def get_extra_context(self, request, instance):
2021-04-06 09:42:36 -04:00
child_groups = SiteGroup.objects.add_related_count(
SiteGroup.objects.all(),
Site,
'group',
'site_count',
cumulative=True
).restrict(request.user, 'view').filter(
parent__in=instance.get_descendants(include_self=True)
)
child_groups_table = tables.SiteGroupTable(child_groups)
sites = Site.objects.restrict(request.user, 'view').filter(
group=instance
)
sites_table = tables.SiteTable(sites)
sites_table.columns.hide('group')
paginate_table(sites_table, request)
return {
2021-04-06 09:42:36 -04:00
'child_groups_table': child_groups_table,
'sites_table': sites_table,
}
class SiteGroupEditView(generic.ObjectEditView):
queryset = SiteGroup.objects.all()
model_form = forms.SiteGroupForm
class SiteGroupDeleteView(generic.ObjectDeleteView):
queryset = SiteGroup.objects.all()
class SiteGroupBulkImportView(generic.BulkImportView):
queryset = SiteGroup.objects.all()
model_form = forms.SiteGroupCSVForm
table = tables.SiteGroupTable
class SiteGroupBulkEditView(generic.BulkEditView):
queryset = SiteGroup.objects.add_related_count(
SiteGroup.objects.all(),
Site,
'group',
'site_count',
cumulative=True
)
filterset = filters.SiteGroupFilterSet
table = tables.SiteGroupTable
form = forms.SiteGroupBulkEditForm
class SiteGroupBulkDeleteView(generic.BulkDeleteView):
queryset = SiteGroup.objects.add_related_count(
SiteGroup.objects.all(),
Site,
'group',
'site_count',
cumulative=True
)
filterset = filters.SiteGroupFilterSet
table = tables.SiteGroupTable
2016-03-01 11:23:03 -05:00
#
# Sites
#
2020-11-11 16:07:38 -05:00
class SiteListView(generic.ObjectListView):
queryset = Site.objects.all()
filterset = filters.SiteFilterSet
filterset_form = forms.SiteFilterForm
table = tables.SiteTable
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class SiteView(generic.ObjectView):
2020-05-11 14:32:10 -04:00
queryset = Site.objects.prefetch_related('region', 'tenant__group')
def get_extra_context(self, request, instance):
stats = {
'rack_count': Rack.objects.restrict(request.user, 'view').filter(site=instance).count(),
'device_count': Device.objects.restrict(request.user, 'view').filter(site=instance).count(),
'prefix_count': Prefix.objects.restrict(request.user, 'view').filter(site=instance).count(),
'vlan_count': VLAN.objects.restrict(request.user, 'view').filter(site=instance).count(),
'circuit_count': Circuit.objects.restrict(request.user, 'view').filter(terminations__site=instance).count(),
'vm_count': VirtualMachine.objects.restrict(request.user, 'view').filter(cluster__site=instance).count(),
}
locations = Location.objects.add_related_count(
Location.objects.all(),
Rack,
'location',
'rack_count',
cumulative=True
2021-04-05 11:04:12 -04:00
)
locations = Location.objects.add_related_count(
locations,
Device,
'location',
'device_count',
cumulative=True
).restrict(request.user, 'view').filter(site=instance)
return {
'stats': stats,
'locations': locations,
}
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class SiteEditView(generic.ObjectEditView):
queryset = Site.objects.all()
model_form = forms.SiteForm
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class SiteDeleteView(generic.ObjectDeleteView):
queryset = Site.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class SiteBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Site.objects.all()
model_form = forms.SiteCSVForm
2016-05-18 16:02:53 -04:00
table = tables.SiteTable
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class SiteBulkEditView(generic.BulkEditView):
queryset = Site.objects.prefetch_related('region', 'tenant')
filterset = filters.SiteFilterSet
table = tables.SiteTable
2016-07-28 15:30:29 -04:00
form = forms.SiteBulkEditForm
2020-11-11 16:07:38 -05:00
class SiteBulkDeleteView(generic.BulkDeleteView):
queryset = Site.objects.prefetch_related('region', 'tenant')
filterset = filters.SiteFilterSet
table = tables.SiteTable
2016-03-30 12:26:37 -04:00
#
# Locations
2016-03-30 12:26:37 -04:00
#
class LocationListView(generic.ObjectListView):
queryset = Location.objects.add_related_count(
Location.objects.add_related_count(
Location.objects.all(),
Device,
'location',
'device_count',
cumulative=True
),
2020-03-11 14:40:29 -04:00
Rack,
'location',
2020-03-11 14:40:29 -04:00
'rack_count',
cumulative=True
)
filterset = filters.LocationFilterSet
filterset_form = forms.LocationFilterForm
table = tables.LocationTable
2016-03-30 12:26:37 -04:00
class LocationView(generic.ObjectView):
queryset = Location.objects.all()
def get_extra_context(self, request, instance):
devices = Device.objects.restrict(request.user, 'view').filter(
location=instance
)
devices_table = tables.DeviceTable(devices)
devices_table.columns.hide('location')
paginate_table(devices_table, request)
return {
'devices_table': devices_table,
}
class LocationEditView(generic.ObjectEditView):
queryset = Location.objects.all()
model_form = forms.LocationForm
2016-03-30 12:26:37 -04:00
class LocationDeleteView(generic.ObjectDeleteView):
queryset = Location.objects.all()
class LocationBulkImportView(generic.BulkImportView):
queryset = Location.objects.all()
model_form = forms.LocationCSVForm
table = tables.LocationTable
class LocationBulkEditView(generic.BulkEditView):
queryset = Location.objects.add_related_count(
Location.objects.all(),
Rack,
'location',
'rack_count',
cumulative=True
).prefetch_related('site')
filterset = filters.LocationFilterSet
table = tables.LocationTable
form = forms.LocationBulkEditForm
class LocationBulkDeleteView(generic.BulkDeleteView):
queryset = Location.objects.add_related_count(
Location.objects.all(),
Rack,
'location',
'rack_count',
cumulative=True
).prefetch_related('site')
filterset = filters.LocationFilterSet
table = tables.LocationTable
2016-03-30 12:26:37 -04:00
2016-08-10 11:52:27 -04:00
#
# Rack roles
#
2020-11-11 16:07:38 -05:00
class RackRoleListView(generic.ObjectListView):
queryset = RackRole.objects.annotate(
rack_count=count_related(Rack, 'role')
)
2016-08-10 11:52:27 -04:00
table = tables.RackRoleTable
class RackRoleView(generic.ObjectView):
queryset = RackRole.objects.all()
def get_extra_context(self, request, instance):
racks = Rack.objects.restrict(request.user, 'view').filter(
role=instance
)
racks_table = tables.RackTable(racks)
racks_table.columns.hide('role')
paginate_table(racks_table, request)
return {
'racks_table': racks_table,
}
2020-11-11 16:07:38 -05:00
class RackRoleEditView(generic.ObjectEditView):
queryset = RackRole.objects.all()
model_form = forms.RackRoleForm
2016-08-10 11:52:27 -04:00
2020-11-11 16:07:38 -05:00
class RackRoleDeleteView(generic.ObjectDeleteView):
queryset = RackRole.objects.all()
2020-11-11 16:07:38 -05:00
class RackRoleBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = RackRole.objects.all()
model_form = forms.RackRoleCSVForm
table = tables.RackRoleTable
class RackRoleBulkEditView(generic.BulkEditView):
queryset = RackRole.objects.annotate(
rack_count=count_related(Rack, 'role')
)
filterset = filters.RackRoleFilterSet
table = tables.RackRoleTable
form = forms.RackRoleBulkEditForm
2020-11-11 16:07:38 -05:00
class RackRoleBulkDeleteView(generic.BulkDeleteView):
queryset = RackRole.objects.annotate(
rack_count=count_related(Rack, 'role')
)
table = tables.RackRoleTable
2016-08-10 11:52:27 -04:00
2016-03-01 11:23:03 -05:00
#
# Racks
#
2020-11-11 16:07:38 -05:00
class RackListView(generic.ObjectListView):
queryset = Rack.objects.prefetch_related(
'site', 'location', 'tenant', 'role', 'devices__device_type'
).annotate(
device_count=count_related(Device, 'rack')
)
filterset = filters.RackFilterSet
filterset_form = forms.RackFilterForm
table = tables.RackDetailTable
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackElevationListView(generic.ObjectListView):
"""
Display a set of rack elevations side-by-side.
"""
queryset = Rack.objects.prefetch_related('role')
def get(self, request):
racks = filters.RackFilterSet(request.GET, self.queryset).qs
total_count = racks.count()
# Determine ordering
reverse = bool(request.GET.get('reverse', False))
if reverse:
racks = racks.reverse()
# Pagination
per_page = get_paginate_count(request)
page_number = request.GET.get('page', 1)
paginator = EnhancedPaginator(racks, per_page)
try:
page = paginator.page(page_number)
except PageNotAnInteger:
page = paginator.page(1)
except EmptyPage:
page = paginator.page(paginator.num_pages)
# Determine rack face
rack_face = request.GET.get('face', DeviceFaceChoices.FACE_FRONT)
if rack_face not in DeviceFaceChoices.values():
rack_face = DeviceFaceChoices.FACE_FRONT
return render(request, 'dcim/rack_elevation_list.html', {
'paginator': paginator,
'page': page,
'total_count': total_count,
'reverse': reverse,
'rack_face': rack_face,
'filter_form': forms.RackElevationFilterForm(request.GET),
})
2020-11-11 16:07:38 -05:00
class RackView(generic.ObjectView):
queryset = Rack.objects.prefetch_related('site__region', 'tenant__group', 'location', 'role')
2016-03-01 11:23:03 -05:00
def get_extra_context(self, request, instance):
# Get 0U devices located within the rack
nonracked_devices = Device.objects.filter(
rack=instance,
position__isnull=True,
parent_bay__isnull=True
).prefetch_related('device_type__manufacturer')
peer_racks = Rack.objects.restrict(request.user, 'view').filter(site=instance.site)
if instance.location:
peer_racks = peer_racks.filter(location=instance.location)
else:
peer_racks = peer_racks.filter(location__isnull=True)
next_rack = peer_racks.filter(name__gt=instance.name).order_by('name').first()
prev_rack = peer_racks.filter(name__lt=instance.name).order_by('-name').first()
reservations = RackReservation.objects.restrict(request.user, 'view').filter(rack=instance)
power_feeds = PowerFeed.objects.restrict(request.user, 'view').filter(rack=instance).prefetch_related(
'power_panel'
)
device_count = Device.objects.restrict(request.user, 'view').filter(rack=instance).count()
return {
'device_count': device_count,
'reservations': reservations,
2019-03-12 11:36:29 -04:00
'power_feeds': power_feeds,
'nonracked_devices': nonracked_devices,
'next_rack': next_rack,
'prev_rack': prev_rack,
}
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackEditView(generic.ObjectEditView):
queryset = Rack.objects.all()
model_form = forms.RackForm
template_name = 'dcim/rack_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackDeleteView(generic.ObjectDeleteView):
queryset = Rack.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Rack.objects.all()
model_form = forms.RackCSVForm
table = tables.RackTable
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackBulkEditView(generic.BulkEditView):
queryset = Rack.objects.prefetch_related('site', 'location', 'tenant', 'role')
filterset = filters.RackFilterSet
table = tables.RackTable
2016-05-18 16:02:53 -04:00
form = forms.RackBulkEditForm
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class RackBulkDeleteView(generic.BulkDeleteView):
queryset = Rack.objects.prefetch_related('site', 'location', 'tenant', 'role')
filterset = filters.RackFilterSet
table = tables.RackTable
2016-03-01 11:23:03 -05:00
#
# Rack reservations
#
2020-11-11 16:07:38 -05:00
class RackReservationListView(generic.ObjectListView):
queryset = RackReservation.objects.all()
filterset = filters.RackReservationFilterSet
filterset_form = forms.RackReservationFilterForm
table = tables.RackReservationTable
2020-11-11 16:07:38 -05:00
class RackReservationView(generic.ObjectView):
queryset = RackReservation.objects.prefetch_related('rack')
2020-11-11 16:07:38 -05:00
class RackReservationEditView(generic.ObjectEditView):
queryset = RackReservation.objects.all()
model_form = forms.RackReservationForm
def alter_obj(self, obj, request, args, kwargs):
if not obj.pk:
if 'rack' in request.GET:
obj.rack = get_object_or_404(Rack, pk=request.GET.get('rack'))
obj.user = request.user
return obj
2020-11-11 16:07:38 -05:00
class RackReservationDeleteView(generic.ObjectDeleteView):
queryset = RackReservation.objects.all()
2020-11-11 16:07:38 -05:00
class RackReservationImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = RackReservation.objects.all()
2020-03-06 17:14:26 -05:00
model_form = forms.RackReservationCSVForm
table = tables.RackReservationTable
def _save_obj(self, obj_form, request):
"""
Assign the currently authenticated user to the RackReservation.
"""
instance = obj_form.save(commit=False)
instance.user = request.user
instance.save()
return instance
2020-03-06 17:14:26 -05:00
2020-11-11 16:07:38 -05:00
class RackReservationBulkEditView(generic.BulkEditView):
queryset = RackReservation.objects.prefetch_related('rack', 'user')
filterset = filters.RackReservationFilterSet
table = tables.RackReservationTable
form = forms.RackReservationBulkEditForm
2020-11-11 16:07:38 -05:00
class RackReservationBulkDeleteView(generic.BulkDeleteView):
queryset = RackReservation.objects.prefetch_related('rack', 'user')
filterset = filters.RackReservationFilterSet
table = tables.RackReservationTable
2016-05-13 15:22:31 -04:00
#
# Manufacturers
#
2020-11-11 16:07:38 -05:00
class ManufacturerListView(generic.ObjectListView):
queryset = Manufacturer.objects.annotate(
devicetype_count=count_related(DeviceType, 'manufacturer'),
inventoryitem_count=count_related(InventoryItem, 'manufacturer'),
platform_count=count_related(Platform, 'manufacturer')
)
2016-05-18 16:02:53 -04:00
table = tables.ManufacturerTable
2016-05-13 15:22:31 -04:00
class ManufacturerView(generic.ObjectView):
queryset = Manufacturer.objects.all()
def get_extra_context(self, request, instance):
devicetypes = DeviceType.objects.restrict(request.user, 'view').filter(
manufacturer=instance
)
devicetypes_table = tables.DeviceTypeTable(devicetypes)
devicetypes_table.columns.hide('manufacturer')
paginate_table(devicetypes_table, request)
return {
'devicetypes_table': devicetypes_table,
}
2020-11-11 16:07:38 -05:00
class ManufacturerEditView(generic.ObjectEditView):
queryset = Manufacturer.objects.all()
model_form = forms.ManufacturerForm
2016-05-13 15:22:31 -04:00
2020-11-11 16:07:38 -05:00
class ManufacturerDeleteView(generic.ObjectDeleteView):
queryset = Manufacturer.objects.all()
2020-11-11 16:07:38 -05:00
class ManufacturerBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Manufacturer.objects.all()
model_form = forms.ManufacturerCSVForm
table = tables.ManufacturerTable
class ManufacturerBulkEditView(generic.BulkEditView):
queryset = Manufacturer.objects.annotate(
devicetype_count=count_related(DeviceType, 'manufacturer')
)
filterset = filters.ManufacturerFilterSet
table = tables.ManufacturerTable
form = forms.ManufacturerBulkEditForm
2020-11-11 16:07:38 -05:00
class ManufacturerBulkDeleteView(generic.BulkDeleteView):
queryset = Manufacturer.objects.annotate(
devicetype_count=count_related(DeviceType, 'manufacturer')
)
table = tables.ManufacturerTable
2016-05-13 15:22:31 -04:00
#
# Device types
#
2020-11-11 16:07:38 -05:00
class DeviceTypeListView(generic.ObjectListView):
queryset = DeviceType.objects.prefetch_related('manufacturer').annotate(
instance_count=count_related(Device, 'device_type')
)
filterset = filters.DeviceTypeFilterSet
filterset_form = forms.DeviceTypeFilterForm
table = tables.DeviceTypeTable
2020-11-11 16:07:38 -05:00
class DeviceTypeView(generic.ObjectView):
queryset = DeviceType.objects.prefetch_related('manufacturer')
def get_extra_context(self, request, instance):
instance_count = Device.objects.restrict(request.user).filter(device_type=instance).count()
# Component tables
consoleport_table = tables.ConsolePortTemplateTable(
ConsolePortTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
orderable=False
)
consoleserverport_table = tables.ConsoleServerPortTemplateTable(
ConsoleServerPortTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
orderable=False
)
powerport_table = tables.PowerPortTemplateTable(
PowerPortTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
orderable=False
)
poweroutlet_table = tables.PowerOutletTemplateTable(
PowerOutletTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
orderable=False
)
interface_table = tables.InterfaceTemplateTable(
list(InterfaceTemplate.objects.restrict(request.user, 'view').filter(device_type=instance)),
orderable=False
)
front_port_table = tables.FrontPortTemplateTable(
FrontPortTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
2018-10-03 14:04:16 -04:00
orderable=False
)
rear_port_table = tables.RearPortTemplateTable(
RearPortTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
2018-10-03 14:04:16 -04:00
orderable=False
)
devicebay_table = tables.DeviceBayTemplateTable(
DeviceBayTemplate.objects.restrict(request.user, 'view').filter(device_type=instance),
orderable=False
)
if request.user.has_perm('dcim.change_devicetype'):
consoleport_table.columns.show('pk')
consoleserverport_table.columns.show('pk')
powerport_table.columns.show('pk')
poweroutlet_table.columns.show('pk')
interface_table.columns.show('pk')
front_port_table.columns.show('pk')
rear_port_table.columns.show('pk')
devicebay_table.columns.show('pk')
return {
'instance_count': instance_count,
'consoleport_table': consoleport_table,
'consoleserverport_table': consoleserverport_table,
'powerport_table': powerport_table,
'poweroutlet_table': poweroutlet_table,
'interface_table': interface_table,
'front_port_table': front_port_table,
'rear_port_table': rear_port_table,
'devicebay_table': devicebay_table,
}
2020-11-11 16:07:38 -05:00
class DeviceTypeEditView(generic.ObjectEditView):
queryset = DeviceType.objects.all()
model_form = forms.DeviceTypeForm
2020-11-11 16:07:38 -05:00
class DeviceTypeDeleteView(generic.ObjectDeleteView):
queryset = DeviceType.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceTypeImportView(generic.ObjectImportView):
additional_permissions = [
2019-10-01 16:54:10 -04:00
'dcim.add_devicetype',
'dcim.add_consoleporttemplate',
'dcim.add_consoleserverporttemplate',
'dcim.add_powerporttemplate',
'dcim.add_poweroutlettemplate',
'dcim.add_interfacetemplate',
'dcim.add_frontporttemplate',
'dcim.add_rearporttemplate',
'dcim.add_devicebaytemplate',
]
queryset = DeviceType.objects.all()
model_form = forms.DeviceTypeImportForm
related_object_forms = OrderedDict((
('console-ports', forms.ConsolePortTemplateImportForm),
('console-server-ports', forms.ConsoleServerPortTemplateImportForm),
('power-ports', forms.PowerPortTemplateImportForm),
('power-outlets', forms.PowerOutletTemplateImportForm),
('interfaces', forms.InterfaceTemplateImportForm),
('rear-ports', forms.RearPortTemplateImportForm),
('front-ports', forms.FrontPortTemplateImportForm),
('device-bays', forms.DeviceBayTemplateImportForm),
))
2020-11-11 16:07:38 -05:00
class DeviceTypeBulkEditView(generic.BulkEditView):
queryset = DeviceType.objects.prefetch_related('manufacturer').annotate(
instance_count=count_related(Device, 'device_type')
)
filterset = filters.DeviceTypeFilterSet
table = tables.DeviceTypeTable
2016-05-18 16:02:53 -04:00
form = forms.DeviceTypeBulkEditForm
2020-11-11 16:07:38 -05:00
class DeviceTypeBulkDeleteView(generic.BulkDeleteView):
queryset = DeviceType.objects.prefetch_related('manufacturer').annotate(
instance_count=count_related(Device, 'device_type')
)
filterset = filters.DeviceTypeFilterSet
table = tables.DeviceTypeTable
#
# Console port templates
#
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateCreateView(generic.ComponentCreateView):
queryset = ConsolePortTemplate.objects.all()
form = forms.ConsolePortTemplateCreateForm
model_form = forms.ConsolePortTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateEditView(generic.ObjectEditView):
queryset = ConsolePortTemplate.objects.all()
model_form = forms.ConsolePortTemplateForm
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateDeleteView(generic.ObjectDeleteView):
queryset = ConsolePortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateBulkEditView(generic.BulkEditView):
queryset = ConsolePortTemplate.objects.all()
table = tables.ConsolePortTemplateTable
form = forms.ConsolePortTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateBulkRenameView(generic.BulkRenameView):
queryset = ConsolePortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class ConsolePortTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = ConsolePortTemplate.objects.all()
table = tables.ConsolePortTemplateTable
#
# Console server port templates
#
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateCreateView(generic.ComponentCreateView):
queryset = ConsoleServerPortTemplate.objects.all()
form = forms.ConsoleServerPortTemplateCreateForm
model_form = forms.ConsoleServerPortTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateEditView(generic.ObjectEditView):
queryset = ConsoleServerPortTemplate.objects.all()
model_form = forms.ConsoleServerPortTemplateForm
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateDeleteView(generic.ObjectDeleteView):
queryset = ConsoleServerPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateBulkEditView(generic.BulkEditView):
queryset = ConsoleServerPortTemplate.objects.all()
table = tables.ConsoleServerPortTemplateTable
form = forms.ConsoleServerPortTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateBulkRenameView(generic.BulkRenameView):
queryset = ConsoleServerPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class ConsoleServerPortTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = ConsoleServerPortTemplate.objects.all()
table = tables.ConsoleServerPortTemplateTable
#
# Power port templates
#
2020-11-11 16:07:38 -05:00
class PowerPortTemplateCreateView(generic.ComponentCreateView):
queryset = PowerPortTemplate.objects.all()
form = forms.PowerPortTemplateCreateForm
model_form = forms.PowerPortTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class PowerPortTemplateEditView(generic.ObjectEditView):
queryset = PowerPortTemplate.objects.all()
model_form = forms.PowerPortTemplateForm
2020-11-11 16:07:38 -05:00
class PowerPortTemplateDeleteView(generic.ObjectDeleteView):
queryset = PowerPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class PowerPortTemplateBulkEditView(generic.BulkEditView):
queryset = PowerPortTemplate.objects.all()
table = tables.PowerPortTemplateTable
form = forms.PowerPortTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class PowerPortTemplateBulkRenameView(generic.BulkRenameView):
queryset = PowerPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class PowerPortTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = PowerPortTemplate.objects.all()
table = tables.PowerPortTemplateTable
#
# Power outlet templates
#
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateCreateView(generic.ComponentCreateView):
queryset = PowerOutletTemplate.objects.all()
form = forms.PowerOutletTemplateCreateForm
model_form = forms.PowerOutletTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateEditView(generic.ObjectEditView):
queryset = PowerOutletTemplate.objects.all()
model_form = forms.PowerOutletTemplateForm
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateDeleteView(generic.ObjectDeleteView):
queryset = PowerOutletTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateBulkEditView(generic.BulkEditView):
queryset = PowerOutletTemplate.objects.all()
table = tables.PowerOutletTemplateTable
form = forms.PowerOutletTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateBulkRenameView(generic.BulkRenameView):
queryset = PowerOutletTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class PowerOutletTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = PowerOutletTemplate.objects.all()
table = tables.PowerOutletTemplateTable
#
# Interface templates
#
2020-11-11 16:07:38 -05:00
class InterfaceTemplateCreateView(generic.ComponentCreateView):
queryset = InterfaceTemplate.objects.all()
form = forms.InterfaceTemplateCreateForm
model_form = forms.InterfaceTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class InterfaceTemplateEditView(generic.ObjectEditView):
queryset = InterfaceTemplate.objects.all()
model_form = forms.InterfaceTemplateForm
2020-11-11 16:07:38 -05:00
class InterfaceTemplateDeleteView(generic.ObjectDeleteView):
queryset = InterfaceTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class InterfaceTemplateBulkEditView(generic.BulkEditView):
queryset = InterfaceTemplate.objects.all()
table = tables.InterfaceTemplateTable
form = forms.InterfaceTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class InterfaceTemplateBulkRenameView(generic.BulkRenameView):
queryset = InterfaceTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class InterfaceTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = InterfaceTemplate.objects.all()
table = tables.InterfaceTemplateTable
#
# Front port templates
#
2020-11-11 16:07:38 -05:00
class FrontPortTemplateCreateView(generic.ComponentCreateView):
queryset = FrontPortTemplate.objects.all()
form = forms.FrontPortTemplateCreateForm
model_form = forms.FrontPortTemplateForm
2018-10-03 14:04:16 -04:00
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class FrontPortTemplateEditView(generic.ObjectEditView):
queryset = FrontPortTemplate.objects.all()
model_form = forms.FrontPortTemplateForm
2020-11-11 16:07:38 -05:00
class FrontPortTemplateDeleteView(generic.ObjectDeleteView):
queryset = FrontPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class FrontPortTemplateBulkEditView(generic.BulkEditView):
queryset = FrontPortTemplate.objects.all()
table = tables.FrontPortTemplateTable
form = forms.FrontPortTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class FrontPortTemplateBulkRenameView(generic.BulkRenameView):
queryset = FrontPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class FrontPortTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = FrontPortTemplate.objects.all()
table = tables.FrontPortTemplateTable
2018-10-03 14:04:16 -04:00
#
# Rear port templates
#
2020-11-11 16:07:38 -05:00
class RearPortTemplateCreateView(generic.ComponentCreateView):
queryset = RearPortTemplate.objects.all()
form = forms.RearPortTemplateCreateForm
model_form = forms.RearPortTemplateForm
2018-10-03 14:04:16 -04:00
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class RearPortTemplateEditView(generic.ObjectEditView):
queryset = RearPortTemplate.objects.all()
model_form = forms.RearPortTemplateForm
2020-11-11 16:07:38 -05:00
class RearPortTemplateDeleteView(generic.ObjectDeleteView):
queryset = RearPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class RearPortTemplateBulkEditView(generic.BulkEditView):
queryset = RearPortTemplate.objects.all()
table = tables.RearPortTemplateTable
form = forms.RearPortTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class RearPortTemplateBulkRenameView(generic.BulkRenameView):
queryset = RearPortTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class RearPortTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = RearPortTemplate.objects.all()
table = tables.RearPortTemplateTable
2018-10-03 14:04:16 -04:00
#
# Device bay templates
#
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateCreateView(generic.ComponentCreateView):
queryset = DeviceBayTemplate.objects.all()
form = forms.DeviceBayTemplateCreateForm
model_form = forms.DeviceBayTemplateForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateEditView(generic.ObjectEditView):
queryset = DeviceBayTemplate.objects.all()
model_form = forms.DeviceBayTemplateForm
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateDeleteView(generic.ObjectDeleteView):
queryset = DeviceBayTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateBulkEditView(generic.BulkEditView):
queryset = DeviceBayTemplate.objects.all()
table = tables.DeviceBayTemplateTable
form = forms.DeviceBayTemplateBulkEditForm
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateBulkRenameView(generic.BulkRenameView):
queryset = DeviceBayTemplate.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceBayTemplateBulkDeleteView(generic.BulkDeleteView):
queryset = DeviceBayTemplate.objects.all()
table = tables.DeviceBayTemplateTable
2016-05-12 14:38:34 -04:00
#
# Device roles
#
2020-11-11 16:07:38 -05:00
class DeviceRoleListView(generic.ObjectListView):
queryset = DeviceRole.objects.annotate(
device_count=count_related(Device, 'device_role'),
vm_count=count_related(VirtualMachine, 'role')
)
2016-05-18 16:02:53 -04:00
table = tables.DeviceRoleTable
2016-05-12 14:38:34 -04:00
class DeviceRoleView(generic.ObjectView):
queryset = DeviceRole.objects.all()
def get_extra_context(self, request, instance):
devices = Device.objects.restrict(request.user, 'view').filter(
device_role=instance
)
devices_table = tables.DeviceTable(devices)
devices_table.columns.hide('device_role')
paginate_table(devices_table, request)
return {
'devices_table': devices_table,
}
2020-11-11 16:07:38 -05:00
class DeviceRoleEditView(generic.ObjectEditView):
queryset = DeviceRole.objects.all()
model_form = forms.DeviceRoleForm
2016-05-12 14:38:34 -04:00
2020-11-11 16:07:38 -05:00
class DeviceRoleDeleteView(generic.ObjectDeleteView):
queryset = DeviceRole.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceRoleBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = DeviceRole.objects.all()
model_form = forms.DeviceRoleCSVForm
table = tables.DeviceRoleTable
class DeviceRoleBulkEditView(generic.BulkEditView):
queryset = DeviceRole.objects.annotate(
device_count=count_related(Device, 'device_role'),
vm_count=count_related(VirtualMachine, 'role')
)
filterset = filters.DeviceRoleFilterSet
table = tables.DeviceRoleTable
form = forms.DeviceRoleBulkEditForm
2020-11-11 16:07:38 -05:00
class DeviceRoleBulkDeleteView(generic.BulkDeleteView):
queryset = DeviceRole.objects.annotate(
device_count=count_related(Device, 'device_role'),
vm_count=count_related(VirtualMachine, 'role')
)
table = tables.DeviceRoleTable
2016-05-12 14:38:34 -04:00
2016-05-16 11:54:17 -04:00
#
# Platforms
#
2020-11-11 16:07:38 -05:00
class PlatformListView(generic.ObjectListView):
queryset = Platform.objects.annotate(
device_count=count_related(Device, 'platform'),
vm_count=count_related(VirtualMachine, 'platform')
)
2016-05-18 16:02:53 -04:00
table = tables.PlatformTable
2016-05-16 11:54:17 -04:00
class PlatformView(generic.ObjectView):
queryset = Platform.objects.all()
def get_extra_context(self, request, instance):
devices = Device.objects.restrict(request.user, 'view').filter(
platform=instance
)
devices_table = tables.DeviceTable(devices)
devices_table.columns.hide('platform')
paginate_table(devices_table, request)
return {
'devices_table': devices_table,
}
2020-11-11 16:07:38 -05:00
class PlatformEditView(generic.ObjectEditView):
queryset = Platform.objects.all()
model_form = forms.PlatformForm
2016-05-16 11:54:17 -04:00
2020-11-11 16:07:38 -05:00
class PlatformDeleteView(generic.ObjectDeleteView):
queryset = Platform.objects.all()
2020-11-11 16:07:38 -05:00
class PlatformBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Platform.objects.all()
model_form = forms.PlatformCSVForm
table = tables.PlatformTable
class PlatformBulkEditView(generic.BulkEditView):
queryset = Platform.objects.all()
filterset = filters.PlatformFilterSet
table = tables.PlatformTable
form = forms.PlatformBulkEditForm
2020-11-11 16:07:38 -05:00
class PlatformBulkDeleteView(generic.BulkDeleteView):
queryset = Platform.objects.all()
table = tables.PlatformTable
2016-05-16 11:54:17 -04:00
2016-03-01 11:23:03 -05:00
#
# Devices
#
2020-11-11 16:07:38 -05:00
class DeviceListView(generic.ObjectListView):
queryset = Device.objects.all()
filterset = filters.DeviceFilterSet
filterset_form = forms.DeviceFilterForm
2020-04-29 10:58:08 -04:00
table = tables.DeviceTable
template_name = 'dcim/device_list.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class DeviceView(generic.ObjectView):
queryset = Device.objects.prefetch_related(
'site__region', 'location', 'rack', 'tenant__group', 'device_role', 'platform', 'primary_ip4', 'primary_ip6'
)
def get_extra_context(self, request, instance):
# VirtualChassis members
if instance.virtual_chassis is not None:
2020-06-01 11:43:49 -04:00
vc_members = Device.objects.restrict(request.user, 'view').filter(
virtual_chassis=instance.virtual_chassis
).order_by('vc_position')
else:
vc_members = []
# Services
services = Service.objects.restrict(request.user, 'view').filter(device=instance)
# Secrets
secrets = Secret.objects.restrict(request.user, 'view').filter(device=instance)
# Find up to ten devices in the same site with the same functional role for quick reference.
related_devices = Device.objects.restrict(request.user, 'view').filter(
site=instance.site, device_role=instance.device_role
).exclude(
pk=instance.pk
).prefetch_related(
'rack', 'device_type__manufacturer'
)[:10]
return {
'services': services,
'secrets': secrets,
'vc_members': vc_members,
'related_devices': related_devices,
'active_tab': 'device',
}
class DeviceConsolePortsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/consoleports.html'
def get_extra_context(self, request, instance):
consoleports = ConsolePort.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related(
2020-10-05 14:47:21 -04:00
'cable', '_path__destination',
2020-06-01 11:43:49 -04:00
)
consoleport_table = tables.DeviceConsolePortTable(
data=consoleports,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_consoleport') or request.user.has_perm('dcim.delete_consoleport'):
consoleport_table.columns.show('pk')
paginate_table(consoleport_table, request)
return {
'consoleport_table': consoleport_table,
'active_tab': 'console-ports',
}
class DeviceConsoleServerPortsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/consoleserverports.html'
def get_extra_context(self, request, instance):
2020-06-01 11:43:49 -04:00
consoleserverports = ConsoleServerPort.objects.restrict(request.user, 'view').filter(
device=instance
2020-06-01 11:43:49 -04:00
).prefetch_related(
2020-10-05 14:47:21 -04:00
'cable', '_path__destination',
2020-06-01 11:43:49 -04:00
)
consoleserverport_table = tables.DeviceConsoleServerPortTable(
data=consoleserverports,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_consoleserverport') or \
request.user.has_perm('dcim.delete_consoleserverport'):
consoleserverport_table.columns.show('pk')
paginate_table(consoleserverport_table, request)
return {
'consoleserverport_table': consoleserverport_table,
'active_tab': 'console-server-ports',
}
class DevicePowerPortsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/powerports.html'
def get_extra_context(self, request, instance):
powerports = PowerPort.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related(
2020-10-05 14:47:21 -04:00
'cable', '_path__destination',
2020-06-01 11:43:49 -04:00
)
powerport_table = tables.DevicePowerPortTable(
data=powerports,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_powerport') or request.user.has_perm('dcim.delete_powerport'):
powerport_table.columns.show('pk')
paginate_table(powerport_table, request)
return {
'powerport_table': powerport_table,
'active_tab': 'power-ports',
}
class DevicePowerOutletsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/poweroutlets.html'
def get_extra_context(self, request, instance):
poweroutlets = PowerOutlet.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related(
2020-10-05 14:47:21 -04:00
'cable', 'power_port', '_path__destination',
2020-06-01 11:43:49 -04:00
)
poweroutlet_table = tables.DevicePowerOutletTable(
data=poweroutlets,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_poweroutlet') or request.user.has_perm('dcim.delete_poweroutlet'):
poweroutlet_table.columns.show('pk')
paginate_table(poweroutlet_table, request)
return {
'poweroutlet_table': poweroutlet_table,
'active_tab': 'power-outlets',
}
class DeviceInterfacesView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/interfaces.html'
def get_extra_context(self, request, instance):
interfaces = instance.vc_interfaces.restrict(request.user, 'view').prefetch_related(
Prefetch('ip_addresses', queryset=IPAddress.objects.restrict(request.user)),
Prefetch('member_interfaces', queryset=Interface.objects.restrict(request.user)),
2020-10-05 14:47:21 -04:00
'lag', 'cable', '_path__destination', 'tags',
)
interface_table = tables.DeviceInterfaceTable(
data=interfaces,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_interface') or request.user.has_perm('dcim.delete_interface'):
interface_table.columns.show('pk')
paginate_table(interface_table, request)
return {
'interface_table': interface_table,
'active_tab': 'interfaces',
}
class DeviceFrontPortsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/frontports.html'
def get_extra_context(self, request, instance):
frontports = FrontPort.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related(
2020-06-01 11:43:49 -04:00
'rear_port', 'cable',
)
frontport_table = tables.DeviceFrontPortTable(
data=frontports,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_frontport') or request.user.has_perm('dcim.delete_frontport'):
frontport_table.columns.show('pk')
paginate_table(frontport_table, request)
2018-10-03 14:04:16 -04:00
return {
'frontport_table': frontport_table,
'active_tab': 'front-ports',
}
class DeviceRearPortsView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/rearports.html'
def get_extra_context(self, request, instance):
rearports = RearPort.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related('cable')
rearport_table = tables.DeviceRearPortTable(
data=rearports,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_rearport') or request.user.has_perm('dcim.delete_rearport'):
rearport_table.columns.show('pk')
paginate_table(rearport_table, request)
2018-10-03 14:04:16 -04:00
return {
'rearport_table': rearport_table,
'active_tab': 'rear-ports',
}
class DeviceDeviceBaysView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/devicebays.html'
def get_extra_context(self, request, instance):
devicebays = DeviceBay.objects.restrict(request.user, 'view').filter(device=instance).prefetch_related(
2020-06-01 11:43:49 -04:00
'installed_device__device_type__manufacturer',
)
devicebay_table = tables.DeviceDeviceBayTable(
data=devicebays,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_devicebay') or request.user.has_perm('dcim.delete_devicebay'):
devicebay_table.columns.show('pk')
paginate_table(devicebay_table, request)
return {
'devicebay_table': devicebay_table,
'active_tab': 'device-bays',
}
class DeviceInventoryView(generic.ObjectView):
queryset = Device.objects.all()
template_name = 'dcim/device/inventory.html'
def get_extra_context(self, request, instance):
inventoryitems = InventoryItem.objects.restrict(request.user, 'view').filter(
device=instance
).prefetch_related('manufacturer')
inventoryitem_table = tables.DeviceInventoryItemTable(
data=inventoryitems,
user=request.user,
orderable=False
)
if request.user.has_perm('dcim.change_inventoryitem') or request.user.has_perm('dcim.delete_inventoryitem'):
2020-11-10 09:22:50 -05:00
inventoryitem_table.columns.show('pk')
paginate_table(inventoryitem_table, request)
return {
'inventoryitem_table': inventoryitem_table,
'active_tab': 'inventory',
}
2020-11-11 16:07:38 -05:00
class DeviceStatusView(generic.ObjectView):
additional_permissions = ['dcim.napalm_read_device']
queryset = Device.objects.all()
template_name = 'dcim/device/status.html'
2017-07-14 16:07:28 -04:00
def get_extra_context(self, request, instance):
return {
'active_tab': 'status',
}
2017-07-14 16:07:28 -04:00
2020-11-11 16:07:38 -05:00
class DeviceLLDPNeighborsView(generic.ObjectView):
additional_permissions = ['dcim.napalm_read_device']
queryset = Device.objects.all()
template_name = 'dcim/device/lldp_neighbors.html'
def get_extra_context(self, request, instance):
interfaces = instance.vc_interfaces.restrict(request.user, 'view').prefetch_related(
'_path__destination'
).exclude(
2020-06-01 11:43:49 -04:00
type__in=NONCONNECTABLE_IFACE_TYPES
)
return {
'interfaces': interfaces,
'active_tab': 'lldp-neighbors',
}
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class DeviceConfigView(generic.ObjectView):
additional_permissions = ['dcim.napalm_read_device']
queryset = Device.objects.all()
template_name = 'dcim/device/config.html'
2017-07-17 13:19:25 -04:00
def get_extra_context(self, request, instance):
return {
'active_tab': 'config',
}
2017-07-17 13:19:25 -04:00
class DeviceConfigContextView(ObjectConfigContextView):
2020-10-23 01:18:04 -04:00
queryset = Device.objects.annotate_config_context_data()
base_template = 'dcim/device/base.html'
2018-06-27 16:02:34 -04:00
class DeviceChangeLogView(ObjectChangeLogView):
base_template = 'dcim/device/base.html'
class DeviceJournalView(ObjectJournalView):
base_template = 'dcim/device/base.html'
2020-11-11 16:07:38 -05:00
class DeviceEditView(generic.ObjectEditView):
queryset = Device.objects.all()
model_form = forms.DeviceForm
template_name = 'dcim/device_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class DeviceDeleteView(generic.ObjectDeleteView):
queryset = Device.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Device.objects.all()
model_form = forms.DeviceCSVForm
2016-05-18 16:02:53 -04:00
table = tables.DeviceImportTable
2016-03-01 11:23:03 -05:00
template_name = 'dcim/device_import.html'
2020-11-11 16:07:38 -05:00
class ChildDeviceBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Device.objects.all()
model_form = forms.ChildDeviceCSVForm
table = tables.DeviceImportTable
template_name = 'dcim/device_import_child.html'
def _save_obj(self, obj_form, request):
obj = obj_form.save()
# Save the reverse relation to the parent device bay
device_bay = obj.parent_bay
device_bay.installed_device = obj
device_bay.save()
return obj
2020-11-11 16:07:38 -05:00
class DeviceBulkEditView(generic.BulkEditView):
queryset = Device.objects.prefetch_related('tenant', 'site', 'rack', 'device_role', 'device_type__manufacturer')
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
2016-05-18 16:02:53 -04:00
form = forms.DeviceBulkEditForm
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkDeleteView(generic.BulkDeleteView):
queryset = Device.objects.prefetch_related('tenant', 'site', 'rack', 'device_role', 'device_type__manufacturer')
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
2016-03-01 11:23:03 -05:00
2016-12-21 15:26:56 -05:00
#
# Console ports
#
2020-11-11 16:07:38 -05:00
class ConsolePortListView(generic.ObjectListView):
queryset = ConsolePort.objects.all()
filterset = filters.ConsolePortFilterSet
filterset_form = forms.ConsolePortFilterForm
table = tables.ConsolePortTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class ConsolePortView(generic.ObjectView):
queryset = ConsolePort.objects.all()
2020-11-11 16:07:38 -05:00
class ConsolePortCreateView(generic.ComponentCreateView):
queryset = ConsolePort.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.ConsolePortCreateForm
model_form = forms.ConsolePortForm
template_name = 'dcim/device_component_add.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsolePortEditView(generic.ObjectEditView):
queryset = ConsolePort.objects.all()
model_form = forms.ConsolePortForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsolePortDeleteView(generic.ObjectDeleteView):
queryset = ConsolePort.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsolePortBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = ConsolePort.objects.all()
model_form = forms.ConsolePortCSVForm
table = tables.ConsolePortTable
2020-11-11 16:07:38 -05:00
class ConsolePortBulkEditView(generic.BulkEditView):
queryset = ConsolePort.objects.all()
filterset = filters.ConsolePortFilterSet
table = tables.ConsolePortTable
form = forms.ConsolePortBulkEditForm
2020-11-11 16:07:38 -05:00
class ConsolePortBulkRenameView(generic.BulkRenameView):
queryset = ConsolePort.objects.all()
class ConsolePortBulkDisconnectView(BulkDisconnectView):
queryset = ConsolePort.objects.all()
2020-11-11 16:07:38 -05:00
class ConsolePortBulkDeleteView(generic.BulkDeleteView):
queryset = ConsolePort.objects.all()
filterset = filters.ConsolePortFilterSet
table = tables.ConsolePortTable
2016-03-01 11:23:03 -05:00
#
# Console server ports
#
2020-11-11 16:07:38 -05:00
class ConsoleServerPortListView(generic.ObjectListView):
queryset = ConsoleServerPort.objects.all()
filterset = filters.ConsoleServerPortFilterSet
filterset_form = forms.ConsoleServerPortFilterForm
table = tables.ConsoleServerPortTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class ConsoleServerPortView(generic.ObjectView):
queryset = ConsoleServerPort.objects.all()
2020-11-11 16:07:38 -05:00
class ConsoleServerPortCreateView(generic.ComponentCreateView):
queryset = ConsoleServerPort.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.ConsoleServerPortCreateForm
model_form = forms.ConsoleServerPortForm
template_name = 'dcim/device_component_add.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsoleServerPortEditView(generic.ObjectEditView):
queryset = ConsoleServerPort.objects.all()
model_form = forms.ConsoleServerPortForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsoleServerPortDeleteView(generic.ObjectDeleteView):
queryset = ConsoleServerPort.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class ConsoleServerPortBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = ConsoleServerPort.objects.all()
model_form = forms.ConsoleServerPortCSVForm
table = tables.ConsoleServerPortTable
2020-11-11 16:07:38 -05:00
class ConsoleServerPortBulkEditView(generic.BulkEditView):
queryset = ConsoleServerPort.objects.all()
filterset = filters.ConsoleServerPortFilterSet
table = tables.ConsoleServerPortTable
form = forms.ConsoleServerPortBulkEditForm
2020-11-11 16:07:38 -05:00
class ConsoleServerPortBulkRenameView(generic.BulkRenameView):
queryset = ConsoleServerPort.objects.all()
class ConsoleServerPortBulkDisconnectView(BulkDisconnectView):
queryset = ConsoleServerPort.objects.all()
2020-11-11 16:07:38 -05:00
class ConsoleServerPortBulkDeleteView(generic.BulkDeleteView):
queryset = ConsoleServerPort.objects.all()
filterset = filters.ConsoleServerPortFilterSet
table = tables.ConsoleServerPortTable
2016-03-01 11:23:03 -05:00
#
# Power ports
#
2020-11-11 16:07:38 -05:00
class PowerPortListView(generic.ObjectListView):
queryset = PowerPort.objects.all()
filterset = filters.PowerPortFilterSet
filterset_form = forms.PowerPortFilterForm
table = tables.PowerPortTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class PowerPortView(generic.ObjectView):
queryset = PowerPort.objects.all()
2020-11-11 16:07:38 -05:00
class PowerPortCreateView(generic.ComponentCreateView):
queryset = PowerPort.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.PowerPortCreateForm
model_form = forms.PowerPortForm
template_name = 'dcim/device_component_add.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerPortEditView(generic.ObjectEditView):
queryset = PowerPort.objects.all()
model_form = forms.PowerPortForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerPortDeleteView(generic.ObjectDeleteView):
queryset = PowerPort.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerPortBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = PowerPort.objects.all()
model_form = forms.PowerPortCSVForm
table = tables.PowerPortTable
2020-11-11 16:07:38 -05:00
class PowerPortBulkEditView(generic.BulkEditView):
queryset = PowerPort.objects.all()
filterset = filters.PowerPortFilterSet
table = tables.PowerPortTable
form = forms.PowerPortBulkEditForm
2020-11-11 16:07:38 -05:00
class PowerPortBulkRenameView(generic.BulkRenameView):
queryset = PowerPort.objects.all()
class PowerPortBulkDisconnectView(BulkDisconnectView):
queryset = PowerPort.objects.all()
2020-11-11 16:07:38 -05:00
class PowerPortBulkDeleteView(generic.BulkDeleteView):
queryset = PowerPort.objects.all()
filterset = filters.PowerPortFilterSet
table = tables.PowerPortTable
2016-03-01 11:23:03 -05:00
#
# Power outlets
#
2020-11-11 16:07:38 -05:00
class PowerOutletListView(generic.ObjectListView):
queryset = PowerOutlet.objects.all()
filterset = filters.PowerOutletFilterSet
filterset_form = forms.PowerOutletFilterForm
table = tables.PowerOutletTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class PowerOutletView(generic.ObjectView):
queryset = PowerOutlet.objects.all()
2020-11-11 16:07:38 -05:00
class PowerOutletCreateView(generic.ComponentCreateView):
queryset = PowerOutlet.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.PowerOutletCreateForm
model_form = forms.PowerOutletForm
template_name = 'dcim/device_component_add.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerOutletEditView(generic.ObjectEditView):
queryset = PowerOutlet.objects.all()
model_form = forms.PowerOutletForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerOutletDeleteView(generic.ObjectDeleteView):
queryset = PowerOutlet.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerOutletBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = PowerOutlet.objects.all()
model_form = forms.PowerOutletCSVForm
table = tables.PowerOutletTable
2020-11-11 16:07:38 -05:00
class PowerOutletBulkEditView(generic.BulkEditView):
queryset = PowerOutlet.objects.all()
filterset = filters.PowerOutletFilterSet
table = tables.PowerOutletTable
form = forms.PowerOutletBulkEditForm
2020-11-11 16:07:38 -05:00
class PowerOutletBulkRenameView(generic.BulkRenameView):
queryset = PowerOutlet.objects.all()
class PowerOutletBulkDisconnectView(BulkDisconnectView):
queryset = PowerOutlet.objects.all()
2020-11-11 16:07:38 -05:00
class PowerOutletBulkDeleteView(generic.BulkDeleteView):
queryset = PowerOutlet.objects.all()
filterset = filters.PowerOutletFilterSet
table = tables.PowerOutletTable
2016-03-01 11:23:03 -05:00
#
# Interfaces
#
2020-11-11 16:07:38 -05:00
class InterfaceListView(generic.ObjectListView):
queryset = Interface.objects.all()
filterset = filters.InterfaceFilterSet
filterset_form = forms.InterfaceFilterForm
table = tables.InterfaceTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class InterfaceView(generic.ObjectView):
queryset = Interface.objects.all()
2018-07-11 15:30:54 -04:00
def get_extra_context(self, request, instance):
2018-07-11 15:30:54 -04:00
# Get assigned IP addresses
ipaddress_table = InterfaceIPAddressTable(
data=instance.ip_addresses.restrict(request.user, 'view').prefetch_related('vrf', 'tenant'),
2018-07-11 15:30:54 -04:00
orderable=False
)
# Get child interfaces
child_interfaces = Interface.objects.restrict(request.user, 'view').filter(parent=instance)
child_interfaces_tables = tables.InterfaceTable(
child_interfaces,
orderable=False
)
child_interfaces_tables.columns.hide('device')
2018-07-11 15:30:54 -04:00
# Get assigned VLANs and annotate whether each is tagged or untagged
vlans = []
if instance.untagged_vlan is not None:
vlans.append(instance.untagged_vlan)
2018-07-11 15:30:54 -04:00
vlans[0].tagged = False
for vlan in instance.tagged_vlans.restrict(request.user).prefetch_related('site', 'group', 'tenant', 'role'):
2018-07-11 15:30:54 -04:00
vlan.tagged = True
vlans.append(vlan)
vlan_table = InterfaceVLANTable(
interface=instance,
2018-07-11 15:30:54 -04:00
data=vlans,
orderable=False
)
return {
2018-07-11 15:30:54 -04:00
'ipaddress_table': ipaddress_table,
'child_interfaces_table': child_interfaces_tables,
2018-07-11 15:30:54 -04:00
'vlan_table': vlan_table,
}
2018-07-11 15:30:54 -04:00
2020-11-11 16:07:38 -05:00
class InterfaceCreateView(generic.ComponentCreateView):
queryset = Interface.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.InterfaceCreateForm
model_form = forms.InterfaceForm
template_name = 'dcim/device_component_add.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class InterfaceEditView(generic.ObjectEditView):
queryset = Interface.objects.all()
model_form = forms.InterfaceForm
template_name = 'dcim/interface_edit.html'
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class InterfaceDeleteView(generic.ObjectDeleteView):
queryset = Interface.objects.all()
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class InterfaceBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Interface.objects.all()
model_form = forms.InterfaceCSVForm
table = tables.InterfaceTable
2020-11-11 16:07:38 -05:00
class InterfaceBulkEditView(generic.BulkEditView):
queryset = Interface.objects.all()
filterset = filters.InterfaceFilterSet
table = tables.InterfaceTable
2016-10-14 16:38:46 -04:00
form = forms.InterfaceBulkEditForm
2020-11-11 16:07:38 -05:00
class InterfaceBulkRenameView(generic.BulkRenameView):
queryset = Interface.objects.all()
class InterfaceBulkDisconnectView(BulkDisconnectView):
queryset = Interface.objects.all()
2020-11-11 16:07:38 -05:00
class InterfaceBulkDeleteView(generic.BulkDeleteView):
queryset = Interface.objects.all()
filterset = filters.InterfaceFilterSet
table = tables.InterfaceTable
2018-10-03 14:04:16 -04:00
#
# Front ports
2018-10-03 14:04:16 -04:00
#
2020-11-11 16:07:38 -05:00
class FrontPortListView(generic.ObjectListView):
queryset = FrontPort.objects.all()
filterset = filters.FrontPortFilterSet
filterset_form = forms.FrontPortFilterForm
table = tables.FrontPortTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class FrontPortView(generic.ObjectView):
queryset = FrontPort.objects.all()
2020-11-11 16:07:38 -05:00
class FrontPortCreateView(generic.ComponentCreateView):
queryset = FrontPort.objects.all()
form = forms.FrontPortCreateForm
model_form = forms.FrontPortForm
2018-10-03 14:04:16 -04:00
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class FrontPortEditView(generic.ObjectEditView):
queryset = FrontPort.objects.all()
model_form = forms.FrontPortForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2018-10-03 14:04:16 -04:00
2020-11-11 16:07:38 -05:00
class FrontPortDeleteView(generic.ObjectDeleteView):
queryset = FrontPort.objects.all()
2018-10-03 14:04:16 -04:00
2020-11-11 16:07:38 -05:00
class FrontPortBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = FrontPort.objects.all()
model_form = forms.FrontPortCSVForm
table = tables.FrontPortTable
2020-11-11 16:07:38 -05:00
class FrontPortBulkEditView(generic.BulkEditView):
queryset = FrontPort.objects.all()
filterset = filters.FrontPortFilterSet
table = tables.FrontPortTable
form = forms.FrontPortBulkEditForm
2020-11-11 16:07:38 -05:00
class FrontPortBulkRenameView(generic.BulkRenameView):
queryset = FrontPort.objects.all()
2018-10-03 14:04:16 -04:00
class FrontPortBulkDisconnectView(BulkDisconnectView):
queryset = FrontPort.objects.all()
2020-11-11 16:07:38 -05:00
class FrontPortBulkDeleteView(generic.BulkDeleteView):
queryset = FrontPort.objects.all()
filterset = filters.FrontPortFilterSet
table = tables.FrontPortTable
2018-10-03 14:04:16 -04:00
#
# Rear ports
2018-10-03 14:04:16 -04:00
#
2020-11-11 16:07:38 -05:00
class RearPortListView(generic.ObjectListView):
queryset = RearPort.objects.all()
filterset = filters.RearPortFilterSet
filterset_form = forms.RearPortFilterForm
table = tables.RearPortTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class RearPortView(generic.ObjectView):
queryset = RearPort.objects.all()
2020-11-11 16:07:38 -05:00
class RearPortCreateView(generic.ComponentCreateView):
queryset = RearPort.objects.all()
form = forms.RearPortCreateForm
model_form = forms.RearPortForm
2018-10-03 14:04:16 -04:00
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class RearPortEditView(generic.ObjectEditView):
queryset = RearPort.objects.all()
model_form = forms.RearPortForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2018-10-03 14:04:16 -04:00
2020-11-11 16:07:38 -05:00
class RearPortDeleteView(generic.ObjectDeleteView):
queryset = RearPort.objects.all()
2018-10-03 14:04:16 -04:00
2020-11-11 16:07:38 -05:00
class RearPortBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = RearPort.objects.all()
model_form = forms.RearPortCSVForm
table = tables.RearPortTable
2020-11-11 16:07:38 -05:00
class RearPortBulkEditView(generic.BulkEditView):
queryset = RearPort.objects.all()
filterset = filters.RearPortFilterSet
table = tables.RearPortTable
form = forms.RearPortBulkEditForm
2020-11-11 16:07:38 -05:00
class RearPortBulkRenameView(generic.BulkRenameView):
queryset = RearPort.objects.all()
2018-10-03 14:04:16 -04:00
class RearPortBulkDisconnectView(BulkDisconnectView):
queryset = RearPort.objects.all()
2020-11-11 16:07:38 -05:00
class RearPortBulkDeleteView(generic.BulkDeleteView):
queryset = RearPort.objects.all()
filterset = filters.RearPortFilterSet
table = tables.RearPortTable
2018-10-03 14:04:16 -04:00
#
# Device bays
#
2020-11-11 16:07:38 -05:00
class DeviceBayListView(generic.ObjectListView):
queryset = DeviceBay.objects.all()
filterset = filters.DeviceBayFilterSet
filterset_form = forms.DeviceBayFilterForm
table = tables.DeviceBayTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class DeviceBayView(generic.ObjectView):
queryset = DeviceBay.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceBayCreateView(generic.ComponentCreateView):
queryset = DeviceBay.objects.all()
2016-12-21 15:26:56 -05:00
form = forms.DeviceBayCreateForm
model_form = forms.DeviceBayForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class DeviceBayEditView(generic.ObjectEditView):
queryset = DeviceBay.objects.all()
model_form = forms.DeviceBayForm
2020-09-04 16:09:05 -04:00
template_name = 'dcim/device_component_edit.html'
2020-11-11 16:07:38 -05:00
class DeviceBayDeleteView(generic.ObjectDeleteView):
queryset = DeviceBay.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceBayPopulateView(generic.ObjectEditView):
queryset = DeviceBay.objects.all()
def get(self, request, pk):
device_bay = get_object_or_404(self.queryset, pk=pk)
form = forms.PopulateDeviceBayForm(device_bay)
return render(request, 'dcim/devicebay_populate.html', {
'device_bay': device_bay,
'form': form,
'return_url': self.get_return_url(request, device_bay),
})
def post(self, request, pk):
device_bay = get_object_or_404(self.queryset, pk=pk)
form = forms.PopulateDeviceBayForm(device_bay, request.POST)
if form.is_valid():
device_bay.installed_device = form.cleaned_data['installed_device']
device_bay.save()
messages.success(request, "Added {} to {}.".format(device_bay.installed_device, device_bay))
return redirect('dcim:device', pk=device_bay.device.pk)
return render(request, 'dcim/devicebay_populate.html', {
'device_bay': device_bay,
'form': form,
'return_url': self.get_return_url(request, device_bay),
})
2020-11-11 16:07:38 -05:00
class DeviceBayDepopulateView(generic.ObjectEditView):
queryset = DeviceBay.objects.all()
def get(self, request, pk):
device_bay = get_object_or_404(self.queryset, pk=pk)
form = ConfirmationForm()
return render(request, 'dcim/devicebay_depopulate.html', {
'device_bay': device_bay,
'form': form,
'return_url': self.get_return_url(request, device_bay),
})
def post(self, request, pk):
device_bay = get_object_or_404(self.queryset, pk=pk)
form = ConfirmationForm(request.POST)
if form.is_valid():
removed_device = device_bay.installed_device
device_bay.installed_device = None
device_bay.save()
2017-05-24 11:33:11 -04:00
messages.success(request, "{} has been removed from {}.".format(removed_device, device_bay))
return redirect('dcim:device', pk=device_bay.device.pk)
return render(request, 'dcim/devicebay_depopulate.html', {
'device_bay': device_bay,
'form': form,
'return_url': self.get_return_url(request, device_bay),
})
2020-11-11 16:07:38 -05:00
class DeviceBayBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = DeviceBay.objects.all()
model_form = forms.DeviceBayCSVForm
table = tables.DeviceBayTable
2020-11-11 16:07:38 -05:00
class DeviceBayBulkEditView(generic.BulkEditView):
queryset = DeviceBay.objects.all()
filterset = filters.DeviceBayFilterSet
table = tables.DeviceBayTable
form = forms.DeviceBayBulkEditForm
2020-11-11 16:07:38 -05:00
class DeviceBayBulkRenameView(generic.BulkRenameView):
queryset = DeviceBay.objects.all()
2020-11-11 16:07:38 -05:00
class DeviceBayBulkDeleteView(generic.BulkDeleteView):
queryset = DeviceBay.objects.all()
filterset = filters.DeviceBayFilterSet
table = tables.DeviceBayTable
#
# Inventory items
#
2020-11-11 16:07:38 -05:00
class InventoryItemListView(generic.ObjectListView):
queryset = InventoryItem.objects.all()
filterset = filters.InventoryItemFilterSet
filterset_form = forms.InventoryItemFilterForm
table = tables.InventoryItemTable
action_buttons = ('import', 'export')
2020-11-11 16:07:38 -05:00
class InventoryItemView(generic.ObjectView):
queryset = InventoryItem.objects.all()
2020-11-11 16:07:38 -05:00
class InventoryItemEditView(generic.ObjectEditView):
queryset = InventoryItem.objects.all()
model_form = forms.InventoryItemForm
2020-11-11 16:07:38 -05:00
class InventoryItemCreateView(generic.ComponentCreateView):
queryset = InventoryItem.objects.all()
form = forms.InventoryItemCreateForm
model_form = forms.InventoryItemForm
template_name = 'dcim/device_component_add.html'
2020-11-11 16:07:38 -05:00
class InventoryItemDeleteView(generic.ObjectDeleteView):
queryset = InventoryItem.objects.all()
2020-11-11 16:07:38 -05:00
class InventoryItemBulkImportView(generic.BulkImportView):
queryset = InventoryItem.objects.all()
model_form = forms.InventoryItemCSVForm
table = tables.InventoryItemTable
2020-11-11 16:07:38 -05:00
class InventoryItemBulkEditView(generic.BulkEditView):
queryset = InventoryItem.objects.prefetch_related('device', 'manufacturer')
filterset = filters.InventoryItemFilterSet
table = tables.InventoryItemTable
form = forms.InventoryItemBulkEditForm
2020-11-11 16:07:38 -05:00
class InventoryItemBulkRenameView(generic.BulkRenameView):
queryset = InventoryItem.objects.all()
2020-11-11 16:07:38 -05:00
class InventoryItemBulkDeleteView(generic.BulkDeleteView):
queryset = InventoryItem.objects.prefetch_related('device', 'manufacturer')
table = tables.InventoryItemTable
template_name = 'dcim/inventoryitem_bulk_delete.html'
2016-12-21 15:26:56 -05:00
#
# Bulk Device component creation
2016-12-21 15:26:56 -05:00
#
2020-11-11 16:07:38 -05:00
class DeviceBulkAddConsolePortView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.ConsolePortBulkCreateForm
queryset = ConsolePort.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.ConsolePortForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkAddConsoleServerPortView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.ConsoleServerPortBulkCreateForm
queryset = ConsoleServerPort.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.ConsoleServerPortForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkAddPowerPortView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.PowerPortBulkCreateForm
queryset = PowerPort.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.PowerPortForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkAddPowerOutletView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.PowerOutletBulkCreateForm
queryset = PowerOutlet.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.PowerOutletForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkAddInterfaceView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.InterfaceBulkCreateForm
queryset = Interface.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.InterfaceForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
# class DeviceBulkAddFrontPortView(generic.BulkComponentCreateView):
2020-04-22 11:26:04 -04:00
# parent_model = Device
# parent_field = 'device'
# form = forms.FrontPortBulkCreateForm
# queryset = FrontPort.objects.all()
2020-04-22 11:26:04 -04:00
# model_form = forms.FrontPortForm
# filterset = filters.DeviceFilterSet
# table = tables.DeviceTable
# default_return_url = 'dcim:device_list'
2020-11-11 16:07:38 -05:00
class DeviceBulkAddRearPortView(generic.BulkComponentCreateView):
2020-04-22 11:26:04 -04:00
parent_model = Device
parent_field = 'device'
form = forms.RearPortBulkCreateForm
queryset = RearPort.objects.all()
2020-04-22 11:26:04 -04:00
model_form = forms.RearPortForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2020-11-11 16:07:38 -05:00
class DeviceBulkAddDeviceBayView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.DeviceBayBulkCreateForm
queryset = DeviceBay.objects.all()
2016-12-21 15:26:56 -05:00
model_form = forms.DeviceBayForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2016-12-21 15:26:56 -05:00
2020-11-11 16:07:38 -05:00
class DeviceBulkAddInventoryItemView(generic.BulkComponentCreateView):
parent_model = Device
parent_field = 'device'
form = forms.InventoryItemBulkCreateForm
queryset = InventoryItem.objects.all()
model_form = forms.InventoryItemForm
filterset = filters.DeviceFilterSet
table = tables.DeviceTable
default_return_url = 'dcim:device_list'
2018-10-24 14:24:02 -04:00
#
# Cables
#
2020-11-11 16:07:38 -05:00
class CableListView(generic.ObjectListView):
queryset = Cable.objects.all()
filterset = filters.CableFilterSet
filterset_form = forms.CableFilterForm
2018-10-24 14:24:02 -04:00
table = tables.CableTable
action_buttons = ('import', 'export')
2018-10-24 14:24:02 -04:00
2020-11-11 16:07:38 -05:00
class CableView(generic.ObjectView):
queryset = Cable.objects.all()
2018-10-25 15:51:12 -04:00
2020-11-11 16:07:38 -05:00
class PathTraceView(generic.ObjectView):
2018-10-31 17:05:25 -04:00
"""
2020-10-02 14:54:16 -04:00
Trace a cable path beginning from the given path endpoint (origin).
2018-10-31 17:05:25 -04:00
"""
additional_permissions = ['dcim.view_cable']
template_name = 'dcim/cable_trace.html'
2018-10-31 17:05:25 -04:00
def dispatch(self, request, *args, **kwargs):
model = kwargs.pop('model')
self.queryset = model.objects.all()
2018-10-31 17:05:25 -04:00
return super().dispatch(request, *args, **kwargs)
def get_extra_context(self, request, instance):
related_paths = []
# If tracing a PathEndpoint, locate the CablePath (if one exists) by its origin
if isinstance(instance, PathEndpoint):
path = instance._path
2020-11-11 11:48:55 -05:00
# Otherwise, find all CablePaths which traverse the specified object
else:
related_paths = CablePath.objects.filter(path__contains=instance).prefetch_related('origin')
# Check for specification of a particular path (when tracing pass-through ports)
try:
path_id = int(request.GET.get('cablepath_id'))
except TypeError:
path_id = None
if path_id in list(related_paths.values_list('pk', flat=True)):
path = CablePath.objects.get(pk=path_id)
else:
path = related_paths.first()
# Get the total length of the cable and whether the length is definitive (fully defined)
total_length, is_definitive = path.get_total_length() if path else (None, False)
return {
2020-11-11 11:48:55 -05:00
'path': path,
'related_paths': related_paths,
'total_length': total_length,
'is_definitive': is_definitive
}
2018-10-31 17:05:25 -04:00
2020-11-11 16:07:38 -05:00
class CableCreateView(generic.ObjectEditView):
queryset = Cable.objects.all()
2018-10-24 14:24:02 -04:00
template_name = 'dcim/cable_connect.html'
2019-03-21 17:47:43 -04:00
def dispatch(self, request, *args, **kwargs):
2018-10-24 14:24:02 -04:00
# Set the model_form class based on the type of component being connected
self.model_form = {
'console-port': forms.ConnectCableToConsolePortForm,
'console-server-port': forms.ConnectCableToConsoleServerPortForm,
'power-port': forms.ConnectCableToPowerPortForm,
'power-outlet': forms.ConnectCableToPowerOutletForm,
'interface': forms.ConnectCableToInterfaceForm,
'front-port': forms.ConnectCableToFrontPortForm,
'rear-port': forms.ConnectCableToRearPortForm,
'power-feed': forms.ConnectCableToPowerFeedForm,
'circuit-termination': forms.ConnectCableToCircuitTerminationForm,
}[kwargs.get('termination_b_type')]
2019-03-21 17:47:43 -04:00
return super().dispatch(request, *args, **kwargs)
def alter_obj(self, obj, request, url_args, url_kwargs):
termination_a_type = url_kwargs.get('termination_a_type')
termination_a_id = url_kwargs.get('termination_a_id')
termination_b_type_name = url_kwargs.get('termination_b_type')
self.termination_b_type = ContentType.objects.get(model=termination_b_type_name.replace('-', ''))
# Initialize Cable termination attributes
obj.termination_a = termination_a_type.objects.get(pk=termination_a_id)
obj.termination_b_type = self.termination_b_type
return obj
2019-03-21 17:47:43 -04:00
def get(self, request, *args, **kwargs):
obj = self.alter_obj(self.get_object(kwargs), request, args, kwargs)
2019-03-21 17:47:43 -04:00
# Parse initial data manually to avoid setting field values as lists
initial_data = {k: request.GET[k] for k in request.GET}
# Set initial site and rack based on side A termination (if not already set)
termination_a_site = getattr(obj.termination_a.parent_object, 'site', None)
if termination_a_site and 'termination_b_region' not in initial_data:
initial_data['termination_b_region'] = termination_a_site.region
if termination_a_site and 'termination_b_site_group' not in initial_data:
initial_data['termination_b_site_group'] = termination_a_site.group
if 'termination_b_site' not in initial_data:
initial_data['termination_b_site'] = termination_a_site
if 'termination_b_rack' not in initial_data:
initial_data['termination_b_rack'] = getattr(obj.termination_a.parent_object, 'rack', None)
2019-03-21 17:47:43 -04:00
form = self.model_form(instance=obj, initial=initial_data)
2019-03-21 17:47:43 -04:00
return render(request, self.template_name, {
'obj': obj,
2019-03-21 17:47:43 -04:00
'obj_type': Cable._meta.verbose_name,
'termination_b_type': self.termination_b_type.name,
2019-03-21 17:47:43 -04:00
'form': form,
'return_url': self.get_return_url(request, obj),
2019-03-21 17:47:43 -04:00
})
2018-10-24 14:24:02 -04:00
2020-11-11 16:07:38 -05:00
class CableEditView(generic.ObjectEditView):
queryset = Cable.objects.all()
2018-10-25 15:51:12 -04:00
model_form = forms.CableForm
template_name = 'dcim/cable_edit.html'
2018-10-25 15:51:12 -04:00
2020-11-11 16:07:38 -05:00
class CableDeleteView(generic.ObjectDeleteView):
queryset = Cable.objects.all()
2018-10-24 14:24:02 -04:00
2020-11-11 16:07:38 -05:00
class CableBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = Cable.objects.all()
2018-10-31 17:05:25 -04:00
model_form = forms.CableCSVForm
table = tables.CableTable
2020-11-11 16:07:38 -05:00
class CableBulkEditView(generic.BulkEditView):
queryset = Cable.objects.prefetch_related('termination_a', 'termination_b')
filterset = filters.CableFilterSet
table = tables.CableTable
form = forms.CableBulkEditForm
2020-11-11 16:07:38 -05:00
class CableBulkDeleteView(generic.BulkDeleteView):
queryset = Cable.objects.prefetch_related('termination_a', 'termination_b')
filterset = filters.CableFilterSet
table = tables.CableTable
2016-03-01 11:23:03 -05:00
#
# Connections
#
2020-11-11 16:07:38 -05:00
class ConsoleConnectionsListView(generic.ObjectListView):
queryset = ConsolePort.objects.filter(_path__isnull=False).order_by('device')
filterset = filters.ConsoleConnectionFilterSet
filterset_form = forms.ConsoleConnectionFilterForm
2016-05-18 16:02:53 -04:00
table = tables.ConsoleConnectionTable
2020-11-10 16:00:21 -05:00
template_name = 'dcim/connections_list.html'
2016-03-01 11:23:03 -05:00
def queryset_to_csv(self):
csv_data = [
# Headers
','.join(['console_server', 'port', 'device', 'console_port', 'reachable'])
]
for obj in self.queryset:
csv = csv_format([
obj._path.destination.device.identifier if obj._path.destination else None,
obj._path.destination.name if obj._path.destination else None,
obj.device.identifier,
obj.name,
obj._path.is_active
])
csv_data.append(csv)
return '\n'.join(csv_data)
2020-11-10 16:00:21 -05:00
def extra_context(self):
return {
'title': 'Console Connections'
}
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class PowerConnectionsListView(generic.ObjectListView):
queryset = PowerPort.objects.filter(_path__isnull=False).order_by('device')
filterset = filters.PowerConnectionFilterSet
filterset_form = forms.PowerConnectionFilterForm
2016-05-18 16:02:53 -04:00
table = tables.PowerConnectionTable
2020-11-10 16:00:21 -05:00
template_name = 'dcim/connections_list.html'
2016-03-01 11:23:03 -05:00
def queryset_to_csv(self):
csv_data = [
# Headers
','.join(['pdu', 'outlet', 'device', 'power_port', 'reachable'])
]
for obj in self.queryset:
csv = csv_format([
obj._path.destination.device.identifier if obj._path.destination else None,
obj._path.destination.name if obj._path.destination else None,
obj.device.identifier,
obj.name,
obj._path.is_active
])
csv_data.append(csv)
return '\n'.join(csv_data)
2020-11-10 16:00:21 -05:00
def extra_context(self):
return {
'title': 'Power Connections'
}
2016-03-01 11:23:03 -05:00
2020-11-11 16:07:38 -05:00
class InterfaceConnectionsListView(generic.ObjectListView):
queryset = Interface.objects.filter(
# Avoid duplicate connections by only selecting the lower PK in a connected pair
_path__isnull=False,
pk__lt=F('_path__destination_id')
).order_by('device')
filterset = filters.InterfaceConnectionFilterSet
filterset_form = forms.InterfaceConnectionFilterForm
2016-05-18 16:02:53 -04:00
table = tables.InterfaceConnectionTable
2020-11-10 16:00:21 -05:00
template_name = 'dcim/connections_list.html'
2016-03-01 11:23:03 -05:00
def queryset_to_csv(self):
csv_data = [
# Headers
','.join([
'device_a', 'interface_a', 'device_b', 'interface_b', 'reachable'
])
]
for obj in self.queryset:
csv = csv_format([
obj._path.destination.device.identifier if obj._path.destination else None,
obj._path.destination.name if obj._path.destination else None,
obj.device.identifier,
obj.name,
obj._path.is_active
])
csv_data.append(csv)
return '\n'.join(csv_data)
2020-11-10 16:00:21 -05:00
def extra_context(self):
return {
'title': 'Interface Connections'
}
2016-03-01 11:23:03 -05:00
#
# Virtual chassis
#
2020-11-11 16:07:38 -05:00
class VirtualChassisListView(generic.ObjectListView):
queryset = VirtualChassis.objects.prefetch_related('master').annotate(
member_count=count_related(Device, 'virtual_chassis')
)
table = tables.VirtualChassisTable
filterset = filters.VirtualChassisFilterSet
filterset_form = forms.VirtualChassisFilterForm
2020-11-11 16:07:38 -05:00
class VirtualChassisView(generic.ObjectView):
queryset = VirtualChassis.objects.all()
def get_extra_context(self, request, instance):
members = Device.objects.restrict(request.user).filter(virtual_chassis=instance)
return {
'members': members,
}
2020-11-11 16:07:38 -05:00
class VirtualChassisCreateView(generic.ObjectEditView):
queryset = VirtualChassis.objects.all()
model_form = forms.VirtualChassisCreateForm
template_name = 'dcim/virtualchassis_add.html'
class VirtualChassisEditView(ObjectPermissionRequiredMixin, GetReturnURLMixin, View):
queryset = VirtualChassis.objects.all()
def get_required_permission(self):
return 'dcim.change_virtualchassis'
def get(self, request, pk):
virtual_chassis = get_object_or_404(self.queryset, pk=pk)
2018-02-14 12:05:00 -05:00
VCMemberFormSet = modelformset_factory(
model=Device,
form=forms.DeviceVCMembershipForm,
formset=forms.BaseVCMemberFormSet,
extra=0
)
members_queryset = virtual_chassis.members.prefetch_related('rack').order_by('vc_position')
vc_form = forms.VirtualChassisForm(instance=virtual_chassis)
2018-02-14 12:05:00 -05:00
vc_form.fields['master'].queryset = members_queryset
formset = VCMemberFormSet(queryset=members_queryset)
return render(request, 'dcim/virtualchassis_edit.html', {
'vc_form': vc_form,
'formset': formset,
'return_url': self.get_return_url(request, virtual_chassis),
})
def post(self, request, pk):
virtual_chassis = get_object_or_404(self.queryset, pk=pk)
2018-02-14 12:05:00 -05:00
VCMemberFormSet = modelformset_factory(
model=Device,
form=forms.DeviceVCMembershipForm,
formset=forms.BaseVCMemberFormSet,
extra=0
)
members_queryset = virtual_chassis.members.prefetch_related('rack').order_by('vc_position')
vc_form = forms.VirtualChassisForm(request.POST, instance=virtual_chassis)
2018-02-14 12:05:00 -05:00
vc_form.fields['master'].queryset = members_queryset
formset = VCMemberFormSet(request.POST, queryset=members_queryset)
if vc_form.is_valid() and formset.is_valid():
2018-02-01 15:53:59 -05:00
with transaction.atomic():
# Save the VirtualChassis
vc_form.save()
# Nullify the vc_position of each member first to allow reordering without raising an IntegrityError on
# duplicate positions. Then save each member instance.
members = formset.save(commit=False)
2019-08-20 17:16:00 -04:00
devices = Device.objects.filter(pk__in=[m.pk for m in members])
for device in devices:
device.vc_position = None
device.save()
2018-02-01 15:53:59 -05:00
for member in members:
member.save()
return redirect(virtual_chassis.get_absolute_url())
2018-02-01 11:39:13 -05:00
return render(request, 'dcim/virtualchassis_edit.html', {
'vc_form': vc_form,
'formset': formset,
'return_url': self.get_return_url(request, virtual_chassis),
})
2020-11-11 16:07:38 -05:00
class VirtualChassisDeleteView(generic.ObjectDeleteView):
queryset = VirtualChassis.objects.all()
2018-02-01 11:39:13 -05:00
class VirtualChassisAddMemberView(ObjectPermissionRequiredMixin, GetReturnURLMixin, View):
queryset = VirtualChassis.objects.all()
def get_required_permission(self):
return 'dcim.change_virtualchassis'
2018-02-01 11:39:13 -05:00
def get(self, request, pk):
virtual_chassis = get_object_or_404(self.queryset, pk=pk)
2018-02-01 11:39:13 -05:00
initial_data = {k: request.GET[k] for k in request.GET}
member_select_form = forms.VCMemberSelectForm(initial=initial_data)
membership_form = forms.DeviceVCMembershipForm(initial=initial_data)
return render(request, 'dcim/virtualchassis_add_member.html', {
'virtual_chassis': virtual_chassis,
'member_select_form': member_select_form,
'membership_form': membership_form,
'return_url': self.get_return_url(request, virtual_chassis),
})
def post(self, request, pk):
virtual_chassis = get_object_or_404(self.queryset, pk=pk)
2018-02-01 11:39:13 -05:00
member_select_form = forms.VCMemberSelectForm(request.POST)
if member_select_form.is_valid():
device = member_select_form.cleaned_data['device']
device.virtual_chassis = virtual_chassis
data = {k: request.POST[k] for k in ['vc_position', 'vc_priority']}
membership_form = forms.DeviceVCMembershipForm(data=data, validate_vc_position=True, instance=device)
2018-02-01 11:39:13 -05:00
if membership_form.is_valid():
membership_form.save()
msg = 'Added member <a href="{}">{}</a>'.format(device.get_absolute_url(), escape(device))
messages.success(request, mark_safe(msg))
if '_addanother' in request.POST:
return redirect(request.get_full_path())
return redirect(self.get_return_url(request, device))
else:
membership_form = forms.DeviceVCMembershipForm(data=request.POST)
2018-02-01 11:39:13 -05:00
return render(request, 'dcim/virtualchassis_add_member.html', {
'virtual_chassis': virtual_chassis,
'member_select_form': member_select_form,
'membership_form': membership_form,
'return_url': self.get_return_url(request, virtual_chassis),
})
class VirtualChassisRemoveMemberView(ObjectPermissionRequiredMixin, GetReturnURLMixin, View):
queryset = Device.objects.all()
def get_required_permission(self):
return 'dcim.change_device'
def get(self, request, pk):
device = get_object_or_404(self.queryset, pk=pk, virtual_chassis__isnull=False)
form = ConfirmationForm(initial=request.GET)
return render(request, 'dcim/virtualchassis_remove_member.html', {
'device': device,
'form': form,
'return_url': self.get_return_url(request, device),
})
def post(self, request, pk):
device = get_object_or_404(self.queryset, pk=pk, virtual_chassis__isnull=False)
form = ConfirmationForm(request.POST)
# Protect master device from being removed
virtual_chassis = VirtualChassis.objects.filter(master=device).first()
if virtual_chassis is not None:
msg = 'Unable to remove master device {} from the virtual chassis.'.format(escape(device))
messages.error(request, mark_safe(msg))
return redirect(device.get_absolute_url())
if form.is_valid():
2019-08-20 17:16:00 -04:00
devices = Device.objects.filter(pk=device.pk)
for device in devices:
device.virtual_chassis = None
device.vc_position = None
device.vc_priority = None
device.save()
msg = 'Removed {} from virtual chassis {}'.format(device, device.virtual_chassis)
messages.success(request, msg)
return redirect(self.get_return_url(request, device))
return render(request, 'dcim/virtualchassis_remove_member.html', {
'device': device,
'form': form,
'return_url': self.get_return_url(request, device),
})
2019-03-11 22:40:52 -04:00
2020-11-11 16:07:38 -05:00
class VirtualChassisBulkImportView(generic.BulkImportView):
2020-06-24 15:29:25 -04:00
queryset = VirtualChassis.objects.all()
model_form = forms.VirtualChassisCSVForm
table = tables.VirtualChassisTable
2020-11-11 16:07:38 -05:00
class VirtualChassisBulkEditView(generic.BulkEditView):
queryset = VirtualChassis.objects.all()
filterset = filters.VirtualChassisFilterSet
table = tables.VirtualChassisTable
form = forms.VirtualChassisBulkEditForm
2020-11-11 16:07:38 -05:00
class VirtualChassisBulkDeleteView(generic.BulkDeleteView):
queryset = VirtualChassis.objects.all()
filterset = filters.VirtualChassisFilterSet
table = tables.VirtualChassisTable
2019-03-11 22:40:52 -04:00
#
# Power panels
#
2020-11-11 16:07:38 -05:00
class PowerPanelListView(generic.ObjectListView):
queryset = PowerPanel.objects.prefetch_related(
'site', 'location'
2019-03-11 22:40:52 -04:00
).annotate(
powerfeed_count=count_related(PowerFeed, 'power_panel')
)
filterset = filters.PowerPanelFilterSet
filterset_form = forms.PowerPanelFilterForm
2019-03-11 22:40:52 -04:00
table = tables.PowerPanelTable
2020-11-11 16:07:38 -05:00
class PowerPanelView(generic.ObjectView):
queryset = PowerPanel.objects.prefetch_related('site', 'location')
2019-03-12 10:15:56 -04:00
def get_extra_context(self, request, instance):
power_feeds = PowerFeed.objects.restrict(request.user).filter(power_panel=instance).prefetch_related('rack')
2019-03-22 21:58:45 -04:00
powerfeed_table = tables.PowerFeedTable(
data=power_feeds,
2019-03-22 21:58:45 -04:00
orderable=False
)
if request.user.has_perm('dcim.delete_cable'):
powerfeed_table.columns.show('pk')
2019-03-22 21:58:45 -04:00
powerfeed_table.exclude = ['power_panel']
2019-03-12 10:15:56 -04:00
return {
2019-03-22 21:58:45 -04:00
'powerfeed_table': powerfeed_table,
}
2019-03-12 10:15:56 -04:00
2020-11-11 16:07:38 -05:00
class PowerPanelEditView(generic.ObjectEditView):
queryset = PowerPanel.objects.all()
2019-03-11 22:40:52 -04:00
model_form = forms.PowerPanelForm
2020-11-11 16:07:38 -05:00
class PowerPanelDeleteView(generic.ObjectDeleteView):
queryset = PowerPanel.objects.all()
2019-03-12 10:15:56 -04:00
2020-11-11 16:07:38 -05:00
class PowerPanelBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = PowerPanel.objects.all()
2019-03-11 22:40:52 -04:00
model_form = forms.PowerPanelCSVForm
table = tables.PowerPanelTable
2020-11-11 16:07:38 -05:00
class PowerPanelBulkEditView(generic.BulkEditView):
queryset = PowerPanel.objects.prefetch_related('site', 'location')
filterset = filters.PowerPanelFilterSet
table = tables.PowerPanelTable
form = forms.PowerPanelBulkEditForm
2020-11-11 16:07:38 -05:00
class PowerPanelBulkDeleteView(generic.BulkDeleteView):
queryset = PowerPanel.objects.prefetch_related(
'site', 'location'
2019-03-11 22:40:52 -04:00
).annotate(
powerfeed_count=count_related(PowerFeed, 'power_panel')
)
filterset = filters.PowerPanelFilterSet
2019-03-11 22:40:52 -04:00
table = tables.PowerPanelTable
#
# Power feeds
#
2020-11-11 16:07:38 -05:00
class PowerFeedListView(generic.ObjectListView):
queryset = PowerFeed.objects.all()
filterset = filters.PowerFeedFilterSet
filterset_form = forms.PowerFeedFilterForm
2019-03-11 22:40:52 -04:00
table = tables.PowerFeedTable
2020-11-11 16:07:38 -05:00
class PowerFeedView(generic.ObjectView):
queryset = PowerFeed.objects.prefetch_related('power_panel', 'rack')
2019-03-11 22:40:52 -04:00
2020-11-11 16:07:38 -05:00
class PowerFeedEditView(generic.ObjectEditView):
queryset = PowerFeed.objects.all()
2019-03-11 22:40:52 -04:00
model_form = forms.PowerFeedForm
2020-11-11 16:07:38 -05:00
class PowerFeedDeleteView(generic.ObjectDeleteView):
queryset = PowerFeed.objects.all()
2019-03-11 22:40:52 -04:00
2020-11-11 16:07:38 -05:00
class PowerFeedBulkImportView(generic.BulkImportView):
2020-05-21 11:58:27 -04:00
queryset = PowerFeed.objects.all()
2019-03-11 22:40:52 -04:00
model_form = forms.PowerFeedCSVForm
table = tables.PowerFeedTable
2020-11-11 16:07:38 -05:00
class PowerFeedBulkEditView(generic.BulkEditView):
queryset = PowerFeed.objects.prefetch_related('power_panel', 'rack')
filterset = filters.PowerFeedFilterSet
2019-03-11 22:40:52 -04:00
table = tables.PowerFeedTable
form = forms.PowerFeedBulkEditForm
class PowerFeedBulkDisconnectView(BulkDisconnectView):
queryset = PowerFeed.objects.all()
2020-11-11 16:07:38 -05:00
class PowerFeedBulkDeleteView(generic.BulkDeleteView):
queryset = PowerFeed.objects.prefetch_related('power_panel', 'rack')
filterset = filters.PowerFeedFilterSet
2019-03-11 22:40:52 -04:00
table = tables.PowerFeedTable