|
|
@@ -0,0 +1,1100 @@
|
|
|
+import django_tables2 as tables
|
|
|
+from django_tables2.utils import Accessor
|
|
|
+
|
|
|
+from tenancy.tables import COL_TENANT
|
|
|
+from utilities.tables import (
|
|
|
+ BaseTable, BooleanColumn, ButtonsColumn, ColorColumn, ColoredLabelColumn, TagColumn, ToggleColumn,
|
|
|
+)
|
|
|
+from .models import (
|
|
|
+ Cable, ConsolePort, ConsolePortTemplate, ConsoleServerPort, ConsoleServerPortTemplate, Device, DeviceBay,
|
|
|
+ DeviceBayTemplate, DeviceRole, DeviceType, FrontPort, FrontPortTemplate, Interface, InterfaceTemplate,
|
|
|
+ InventoryItem, Manufacturer, Platform, PowerFeed, PowerOutlet, PowerOutletTemplate, PowerPanel, PowerPort,
|
|
|
+ PowerPortTemplate, Rack, RackGroup, RackReservation, RackRole, RearPort, RearPortTemplate, Region, Site,
|
|
|
+ VirtualChassis,
|
|
|
+)
|
|
|
+
|
|
|
+MPTT_LINK = """
|
|
|
+{% if record.get_children %}
|
|
|
+ <span style="padding-left: {{ record.get_ancestors|length }}0px "><i class="fa fa-caret-right"></i>
|
|
|
+{% else %}
|
|
|
+ <span style="padding-left: {{ record.get_ancestors|length }}9px">
|
|
|
+{% endif %}
|
|
|
+ <a href="{{ record.get_absolute_url }}">{{ record.name }}</a>
|
|
|
+</span>
|
|
|
+"""
|
|
|
+
|
|
|
+SITE_REGION_LINK = """
|
|
|
+{% if record.region %}
|
|
|
+ <a href="{% url 'dcim:site_list' %}?region={{ record.region.slug }}">{{ record.region }}</a>
|
|
|
+{% else %}
|
|
|
+ —
|
|
|
+{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+COLOR_LABEL = """
|
|
|
+{% load helpers %}
|
|
|
+<label class="label" style="color: {{ record.color|fgcolor }}; background-color: #{{ record.color }}">{{ record }}</label>
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICE_LINK = """
|
|
|
+<a href="{% url 'dcim:device' pk=record.pk %}">
|
|
|
+ {{ record.name|default:'<span class="label label-info">Unnamed device</span>' }}
|
|
|
+</a>
|
|
|
+"""
|
|
|
+
|
|
|
+RACKGROUP_ELEVATIONS = """
|
|
|
+<a href="{% url 'dcim:rack_elevation_list' %}?site={{ record.site.slug }}&group_id={{ record.pk }}" class="btn btn-xs btn-primary" title="View elevations">
|
|
|
+ <i class="fa fa-eye"></i>
|
|
|
+</a>
|
|
|
+"""
|
|
|
+
|
|
|
+RACK_DEVICE_COUNT = """
|
|
|
+<a href="{% url 'dcim:device_list' %}?rack_id={{ record.pk }}">{{ value }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICE_COUNT = """
|
|
|
+<a href="{% url 'dcim:device_list' %}?role={{ record.slug }}">{{ value|default:0 }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+RACKRESERVATION_ACTIONS = """
|
|
|
+<a href="{% url 'dcim:rackreservation_changelog' pk=record.pk %}" class="btn btn-default btn-xs" title="Change log">
|
|
|
+ <i class="fa fa-history"></i>
|
|
|
+</a>
|
|
|
+{% if perms.dcim.change_rackreservation %}
|
|
|
+ <a href="{% url 'dcim:rackreservation_edit' pk=record.pk %}?return_url={{ request.path }}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
|
|
|
+{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+MANUFACTURER_ACTIONS = """
|
|
|
+<a href="{% url 'dcim:manufacturer_changelog' slug=record.slug %}" class="btn btn-default btn-xs" title="Change log">
|
|
|
+ <i class="fa fa-history"></i>
|
|
|
+</a>
|
|
|
+{% if perms.dcim.change_manufacturer %}
|
|
|
+ <a href="{% url 'dcim:manufacturer_edit' slug=record.slug %}?return_url={{ request.path }}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
|
|
|
+{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICEROLE_DEVICE_COUNT = """
|
|
|
+<a href="{% url 'dcim:device_list' %}?role={{ record.slug }}">{{ value|default:0 }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICEROLE_VM_COUNT = """
|
|
|
+<a href="{% url 'virtualization:virtualmachine_list' %}?role={{ record.slug }}">{{ value|default:0 }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICEROLE_ACTIONS = """
|
|
|
+<a href="{% url 'dcim:devicerole_changelog' slug=record.slug %}" class="btn btn-default btn-xs" title="Change log">
|
|
|
+ <i class="fa fa-history"></i>
|
|
|
+</a>
|
|
|
+{% if perms.dcim.change_devicerole %}
|
|
|
+ <a href="{% url 'dcim:devicerole_edit' slug=record.slug %}?return_url={{ request.path }}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
|
|
|
+{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+PLATFORM_DEVICE_COUNT = """
|
|
|
+<a href="{% url 'dcim:device_list' %}?platform={{ record.slug }}">{{ value|default:0 }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+PLATFORM_VM_COUNT = """
|
|
|
+<a href="{% url 'virtualization:virtualmachine_list' %}?platform={{ record.slug }}">{{ value|default:0 }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+STATUS_LABEL = """
|
|
|
+<span class="label label-{{ record.get_status_class }}">{{ record.get_status_display }}</span>
|
|
|
+"""
|
|
|
+
|
|
|
+TYPE_LABEL = """
|
|
|
+<span class="label label-{{ record.get_type_class }}">{{ record.get_type_display }}</span>
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICE_PRIMARY_IP = """
|
|
|
+{{ record.primary_ip6.address.ip|default:"" }}
|
|
|
+{% if record.primary_ip6 and record.primary_ip4 %}<br />{% endif %}
|
|
|
+{{ record.primary_ip4.address.ip|default:"" }}
|
|
|
+"""
|
|
|
+
|
|
|
+DEVICETYPE_INSTANCES_TEMPLATE = """
|
|
|
+<a href="{% url 'dcim:device_list' %}?manufacturer_id={{ record.manufacturer_id }}&device_type_id={{ record.pk }}">{{ record.instance_count }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+UTILIZATION_GRAPH = """
|
|
|
+{% load helpers %}
|
|
|
+{% utilization_graph value %}
|
|
|
+"""
|
|
|
+
|
|
|
+CABLE_TERMINATION_PARENT = """
|
|
|
+{% if value.device %}
|
|
|
+ <a href="{{ value.device.get_absolute_url }}">{{ value.device }}</a>
|
|
|
+{% elif value.circuit %}
|
|
|
+ <a href="{{ value.circuit.get_absolute_url }}">{{ value.circuit }}</a>
|
|
|
+{% elif value.power_panel %}
|
|
|
+ <a href="{{ value.power_panel.get_absolute_url }}">{{ value.power_panel }}</a>
|
|
|
+{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+CABLE_LENGTH = """
|
|
|
+{% if record.length %}{{ record.length }} {{ record.get_length_unit_display }}{% else %}—{% endif %}
|
|
|
+"""
|
|
|
+
|
|
|
+POWERPANEL_POWERFEED_COUNT = """
|
|
|
+<a href="{% url 'dcim:powerfeed_list' %}?power_panel_id={{ record.pk }}">{{ value }}</a>
|
|
|
+"""
|
|
|
+
|
|
|
+INTERFACE_IPADDRESSES = """
|
|
|
+{% for ip in record.ip_addresses.unrestricted %}
|
|
|
+ <a href="{{ ip.get_absolute_url }}">{{ ip }}</a><br />
|
|
|
+{% endfor %}
|
|
|
+"""
|
|
|
+
|
|
|
+INTERFACE_TAGGED_VLANS = """
|
|
|
+{% for vlan in record.tagged_vlans.unrestricted %}
|
|
|
+ <a href="{{ vlan.get_absolute_url }}">{{ vlan }}</a><br />
|
|
|
+{% endfor %}
|
|
|
+"""
|
|
|
+
|
|
|
+CONNECTION_STATUS = """
|
|
|
+<span class="label label-{% if record.connection_status %}success{% else %}danger{% endif %}">{{ record.get_connection_status_display }}</span>
|
|
|
+"""
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Regions
|
|
|
+#
|
|
|
+
|
|
|
+class RegionTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.TemplateColumn(
|
|
|
+ template_code=MPTT_LINK,
|
|
|
+ orderable=False
|
|
|
+ )
|
|
|
+ site_count = tables.Column(
|
|
|
+ verbose_name='Sites'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(Region)
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Region
|
|
|
+ fields = ('pk', 'name', 'slug', 'site_count', 'description', 'actions')
|
|
|
+ default_columns = ('pk', 'name', 'site_count', 'description', 'actions')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Sites
|
|
|
+#
|
|
|
+
|
|
|
+class SiteTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.LinkColumn(
|
|
|
+ order_by=('_name',)
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ region = tables.TemplateColumn(
|
|
|
+ template_code=SITE_REGION_LINK
|
|
|
+ )
|
|
|
+ tenant = tables.TemplateColumn(
|
|
|
+ template_code=COL_TENANT
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:site_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Site
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'slug', 'status', 'facility', 'region', 'tenant', 'asn', 'time_zone', 'description',
|
|
|
+ 'physical_address', 'shipping_address', 'latitude', 'longitude', 'contact_name', 'contact_phone',
|
|
|
+ 'contact_email', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'name', 'status', 'facility', 'region', 'tenant', 'asn', 'description')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Rack groups
|
|
|
+#
|
|
|
+
|
|
|
+class RackGroupTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.TemplateColumn(
|
|
|
+ template_code=MPTT_LINK,
|
|
|
+ orderable=False
|
|
|
+ )
|
|
|
+ site = tables.LinkColumn(
|
|
|
+ viewname='dcim:site',
|
|
|
+ args=[Accessor('site__slug')],
|
|
|
+ verbose_name='Site'
|
|
|
+ )
|
|
|
+ rack_count = tables.Column(
|
|
|
+ verbose_name='Racks'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=RackGroup,
|
|
|
+ prepend_template=RACKGROUP_ELEVATIONS
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = RackGroup
|
|
|
+ fields = ('pk', 'name', 'site', 'rack_count', 'description', 'slug', 'actions')
|
|
|
+ default_columns = ('pk', 'name', 'site', 'rack_count', 'description', 'actions')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Rack roles
|
|
|
+#
|
|
|
+
|
|
|
+class RackRoleTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.Column(linkify=True)
|
|
|
+ rack_count = tables.Column(verbose_name='Racks')
|
|
|
+ color = tables.TemplateColumn(COLOR_LABEL)
|
|
|
+ actions = ButtonsColumn(RackRole)
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = RackRole
|
|
|
+ fields = ('pk', 'name', 'rack_count', 'color', 'description', 'slug', 'actions')
|
|
|
+ default_columns = ('pk', 'name', 'rack_count', 'color', 'description', 'actions')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Racks
|
|
|
+#
|
|
|
+
|
|
|
+class RackTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.Column(
|
|
|
+ order_by=('_name',),
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ group = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ site = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ tenant = tables.TemplateColumn(
|
|
|
+ template_code=COL_TENANT
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ role = ColoredLabelColumn()
|
|
|
+ u_height = tables.TemplateColumn(
|
|
|
+ template_code="{{ record.u_height }}U",
|
|
|
+ verbose_name='Height'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Rack
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'site', 'group', 'status', 'facility_id', 'tenant', 'role', 'serial', 'asset_tag', 'type',
|
|
|
+ 'width', 'u_height',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'name', 'site', 'group', 'status', 'facility_id', 'tenant', 'role', 'u_height')
|
|
|
+
|
|
|
+
|
|
|
+class RackDetailTable(RackTable):
|
|
|
+ device_count = tables.TemplateColumn(
|
|
|
+ template_code=RACK_DEVICE_COUNT,
|
|
|
+ verbose_name='Devices'
|
|
|
+ )
|
|
|
+ get_utilization = tables.TemplateColumn(
|
|
|
+ template_code=UTILIZATION_GRAPH,
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Space'
|
|
|
+ )
|
|
|
+ get_power_utilization = tables.TemplateColumn(
|
|
|
+ template_code=UTILIZATION_GRAPH,
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Power'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:rack_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(RackTable.Meta):
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'site', 'group', 'status', 'facility_id', 'tenant', 'role', 'serial', 'asset_tag', 'type',
|
|
|
+ 'width', 'u_height', 'device_count', 'get_utilization', 'get_power_utilization', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'name', 'site', 'group', 'status', 'facility_id', 'tenant', 'role', 'u_height', 'device_count',
|
|
|
+ 'get_utilization', 'get_power_utilization',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Rack reservations
|
|
|
+#
|
|
|
+
|
|
|
+class RackReservationTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ reservation = tables.Column(
|
|
|
+ accessor='pk',
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ site = tables.Column(
|
|
|
+ accessor=Accessor('rack__site'),
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ tenant = tables.TemplateColumn(
|
|
|
+ template_code=COL_TENANT
|
|
|
+ )
|
|
|
+ rack = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ unit_list = tables.Column(
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Units'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:rackreservation_list'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(RackReservation)
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = RackReservation
|
|
|
+ fields = (
|
|
|
+ 'pk', 'reservation', 'site', 'rack', 'unit_list', 'user', 'created', 'tenant', 'description', 'tags',
|
|
|
+ 'actions',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'reservation', 'site', 'rack', 'unit_list', 'user', 'description', 'actions',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Manufacturers
|
|
|
+#
|
|
|
+
|
|
|
+class ManufacturerTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.LinkColumn()
|
|
|
+ devicetype_count = tables.Column(
|
|
|
+ verbose_name='Device Types'
|
|
|
+ )
|
|
|
+ inventoryitem_count = tables.Column(
|
|
|
+ verbose_name='Inventory Items'
|
|
|
+ )
|
|
|
+ platform_count = tables.Column(
|
|
|
+ verbose_name='Platforms'
|
|
|
+ )
|
|
|
+ slug = tables.Column()
|
|
|
+ actions = ButtonsColumn(Manufacturer, pk_field='slug')
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Manufacturer
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'devicetype_count', 'inventoryitem_count', 'platform_count', 'description', 'slug', 'actions',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Device types
|
|
|
+#
|
|
|
+
|
|
|
+class DeviceTypeTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ model = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='Device Type'
|
|
|
+ )
|
|
|
+ is_full_depth = BooleanColumn(
|
|
|
+ verbose_name='Full Depth'
|
|
|
+ )
|
|
|
+ instance_count = tables.TemplateColumn(
|
|
|
+ template_code=DEVICETYPE_INSTANCES_TEMPLATE,
|
|
|
+ verbose_name='Instances'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:devicetype_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = DeviceType
|
|
|
+ fields = (
|
|
|
+ 'pk', 'model', 'manufacturer', 'slug', 'part_number', 'u_height', 'is_full_depth', 'subdevice_role',
|
|
|
+ 'instance_count', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'model', 'manufacturer', 'part_number', 'u_height', 'is_full_depth', 'instance_count',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Device type components
|
|
|
+#
|
|
|
+
|
|
|
+class ComponentTemplateTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.Column(
|
|
|
+ order_by=('_name',)
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+class ConsolePortTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=ConsolePortTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_consoleports'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = ConsolePortTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class ConsoleServerPortTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=ConsoleServerPortTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_consoleserverports'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = ConsoleServerPortTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class PowerPortTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=PowerPortTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_powerports'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = PowerPortTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'maximum_draw', 'allocated_draw', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class PowerOutletTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=PowerOutletTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_poweroutlets'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = PowerOutletTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'power_port', 'feed_leg', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class InterfaceTemplateTable(ComponentTemplateTable):
|
|
|
+ mgmt_only = BooleanColumn(
|
|
|
+ verbose_name='Management Only'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=InterfaceTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_interfaces'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = InterfaceTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'mgmt_only', 'type', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class FrontPortTemplateTable(ComponentTemplateTable):
|
|
|
+ rear_port_position = tables.Column(
|
|
|
+ verbose_name='Position'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=FrontPortTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_frontports'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = FrontPortTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'rear_port', 'rear_port_position', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class RearPortTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=RearPortTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_rearports'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = RearPortTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'type', 'positions', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+class DeviceBayTemplateTable(ComponentTemplateTable):
|
|
|
+ actions = ButtonsColumn(
|
|
|
+ model=DeviceBayTemplate,
|
|
|
+ buttons=('edit', 'delete'),
|
|
|
+ return_url_extra='%23tab_devicebays'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = DeviceBayTemplate
|
|
|
+ fields = ('pk', 'name', 'label', 'description', 'actions')
|
|
|
+ empty_text = "None"
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Device roles
|
|
|
+#
|
|
|
+
|
|
|
+class DeviceRoleTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ device_count = tables.TemplateColumn(
|
|
|
+ template_code=DEVICEROLE_DEVICE_COUNT,
|
|
|
+ verbose_name='Devices'
|
|
|
+ )
|
|
|
+ vm_count = tables.TemplateColumn(
|
|
|
+ template_code=DEVICEROLE_VM_COUNT,
|
|
|
+ verbose_name='VMs'
|
|
|
+ )
|
|
|
+ color = tables.TemplateColumn(
|
|
|
+ template_code=COLOR_LABEL,
|
|
|
+ verbose_name='Label'
|
|
|
+ )
|
|
|
+ vm_role = BooleanColumn()
|
|
|
+ actions = ButtonsColumn(DeviceRole, pk_field='slug')
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = DeviceRole
|
|
|
+ fields = ('pk', 'name', 'device_count', 'vm_count', 'color', 'vm_role', 'description', 'slug', 'actions')
|
|
|
+ default_columns = ('pk', 'name', 'device_count', 'vm_count', 'color', 'vm_role', 'description', 'actions')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Platforms
|
|
|
+#
|
|
|
+
|
|
|
+class PlatformTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ device_count = tables.TemplateColumn(
|
|
|
+ template_code=PLATFORM_DEVICE_COUNT,
|
|
|
+ verbose_name='Devices'
|
|
|
+ )
|
|
|
+ vm_count = tables.TemplateColumn(
|
|
|
+ template_code=PLATFORM_VM_COUNT,
|
|
|
+ verbose_name='VMs'
|
|
|
+ )
|
|
|
+ actions = ButtonsColumn(Platform, pk_field='slug')
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Platform
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'manufacturer', 'device_count', 'vm_count', 'slug', 'napalm_driver', 'napalm_args',
|
|
|
+ 'description', 'actions',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'name', 'manufacturer', 'device_count', 'vm_count', 'napalm_driver', 'description', 'actions',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Devices
|
|
|
+#
|
|
|
+
|
|
|
+class DeviceTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.TemplateColumn(
|
|
|
+ order_by=('_name',),
|
|
|
+ template_code=DEVICE_LINK
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ tenant = tables.TemplateColumn(
|
|
|
+ template_code=COL_TENANT
|
|
|
+ )
|
|
|
+ site = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ rack = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ device_role = ColoredLabelColumn(
|
|
|
+ verbose_name='Role'
|
|
|
+ )
|
|
|
+ device_type = tables.LinkColumn(
|
|
|
+ viewname='dcim:devicetype',
|
|
|
+ args=[Accessor('device_type__pk')],
|
|
|
+ verbose_name='Type',
|
|
|
+ text=lambda record: record.device_type.display_name
|
|
|
+ )
|
|
|
+ primary_ip = tables.TemplateColumn(
|
|
|
+ template_code=DEVICE_PRIMARY_IP,
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='IP Address'
|
|
|
+ )
|
|
|
+ primary_ip4 = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='IPv4 Address'
|
|
|
+ )
|
|
|
+ primary_ip6 = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='IPv6 Address'
|
|
|
+ )
|
|
|
+ cluster = tables.LinkColumn(
|
|
|
+ viewname='virtualization:cluster',
|
|
|
+ args=[Accessor('cluster__pk')]
|
|
|
+ )
|
|
|
+ virtual_chassis = tables.LinkColumn(
|
|
|
+ viewname='dcim:virtualchassis',
|
|
|
+ args=[Accessor('virtual_chassis__pk')]
|
|
|
+ )
|
|
|
+ vc_position = tables.Column(
|
|
|
+ verbose_name='VC Position'
|
|
|
+ )
|
|
|
+ vc_priority = tables.Column(
|
|
|
+ verbose_name='VC Priority'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:device_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Device
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'status', 'tenant', 'device_role', 'device_type', 'platform', 'serial', 'asset_tag', 'site',
|
|
|
+ 'rack', 'position', 'face', 'primary_ip', 'primary_ip4', 'primary_ip6', 'cluster', 'virtual_chassis',
|
|
|
+ 'vc_position', 'vc_priority', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'name', 'status', 'tenant', 'site', 'rack', 'device_role', 'device_type', 'primary_ip',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+class DeviceImportTable(BaseTable):
|
|
|
+ name = tables.TemplateColumn(
|
|
|
+ template_code=DEVICE_LINK
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ tenant = tables.TemplateColumn(
|
|
|
+ template_code=COL_TENANT
|
|
|
+ )
|
|
|
+ site = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ rack = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ device_role = tables.Column(
|
|
|
+ verbose_name='Role'
|
|
|
+ )
|
|
|
+ device_type = tables.Column(
|
|
|
+ verbose_name='Type'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Device
|
|
|
+ fields = ('name', 'status', 'tenant', 'site', 'rack', 'position', 'device_role', 'device_type')
|
|
|
+ empty_text = False
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Device components
|
|
|
+#
|
|
|
+
|
|
|
+class DeviceComponentTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ device = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ name = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ order_by=('_name',)
|
|
|
+ )
|
|
|
+ cable = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ order_by = ('device', 'name')
|
|
|
+
|
|
|
+
|
|
|
+class ConsolePortTable(DeviceComponentTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:consoleport_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = ConsolePort
|
|
|
+ fields = ('pk', 'device', 'name', 'label', 'type', 'description', 'cable', 'tags')
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class ConsoleServerPortTable(DeviceComponentTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:consoleserverport_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = ConsoleServerPort
|
|
|
+ fields = ('pk', 'device', 'name', 'label', 'type', 'description', 'cable', 'tags')
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class PowerPortTable(DeviceComponentTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:powerport_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = PowerPort
|
|
|
+ fields = (
|
|
|
+ 'pk', 'device', 'name', 'label', 'type', 'description', 'maximum_draw', 'allocated_draw', 'cable', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'maximum_draw', 'allocated_draw', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class PowerOutletTable(DeviceComponentTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:poweroutlet_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = PowerOutlet
|
|
|
+ fields = ('pk', 'device', 'name', 'label', 'type', 'description', 'power_port', 'feed_leg', 'cable', 'tags')
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'power_port', 'feed_leg', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class BaseInterfaceTable(BaseTable):
|
|
|
+ enabled = BooleanColumn()
|
|
|
+ ip_addresses = tables.TemplateColumn(
|
|
|
+ template_code=INTERFACE_IPADDRESSES,
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='IP Addresses'
|
|
|
+ )
|
|
|
+ untagged_vlan = tables.Column(linkify=True)
|
|
|
+ tagged_vlans = tables.TemplateColumn(
|
|
|
+ template_code=INTERFACE_TAGGED_VLANS,
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Tagged VLANs'
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+class InterfaceTable(DeviceComponentTable, BaseInterfaceTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:interface_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = Interface
|
|
|
+ fields = (
|
|
|
+ 'pk', 'device', 'name', 'label', 'enabled', 'type', 'mgmt_only', 'mtu', 'mode', 'mac_address',
|
|
|
+ 'description', 'cable', 'tags', 'ip_addresses', 'untagged_vlan', 'tagged_vlans',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'enabled', 'type', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class FrontPortTable(DeviceComponentTable):
|
|
|
+ rear_port_position = tables.Column(
|
|
|
+ verbose_name='Position'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:frontport_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = FrontPort
|
|
|
+ fields = (
|
|
|
+ 'pk', 'device', 'name', 'label', 'type', 'rear_port', 'rear_port_position', 'description', 'cable', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'rear_port', 'rear_port_position', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class RearPortTable(DeviceComponentTable):
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:rearport_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = RearPort
|
|
|
+ fields = ('pk', 'device', 'name', 'label', 'type', 'positions', 'description', 'cable', 'tags')
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'type', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class DeviceBayTable(DeviceComponentTable):
|
|
|
+ installed_device = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:devicebay_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = DeviceBay
|
|
|
+ fields = ('pk', 'device', 'name', 'label', 'installed_device', 'description', 'tags')
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'installed_device', 'description')
|
|
|
+
|
|
|
+
|
|
|
+class InventoryItemTable(DeviceComponentTable):
|
|
|
+ manufacturer = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ discovered = BooleanColumn()
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:inventoryitem_list'
|
|
|
+ )
|
|
|
+ cable = None # Override DeviceComponentTable
|
|
|
+
|
|
|
+ class Meta(DeviceComponentTable.Meta):
|
|
|
+ model = InventoryItem
|
|
|
+ fields = (
|
|
|
+ 'pk', 'device', 'name', 'label', 'manufacturer', 'part_id', 'serial', 'asset_tag', 'description',
|
|
|
+ 'discovered', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = ('pk', 'device', 'name', 'label', 'manufacturer', 'part_id', 'serial', 'asset_tag')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Cables
|
|
|
+#
|
|
|
+
|
|
|
+class CableTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ id = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='ID'
|
|
|
+ )
|
|
|
+ termination_a_parent = tables.TemplateColumn(
|
|
|
+ template_code=CABLE_TERMINATION_PARENT,
|
|
|
+ accessor=Accessor('termination_a'),
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Side A'
|
|
|
+ )
|
|
|
+ termination_a = tables.LinkColumn(
|
|
|
+ accessor=Accessor('termination_a'),
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Termination A'
|
|
|
+ )
|
|
|
+ termination_b_parent = tables.TemplateColumn(
|
|
|
+ template_code=CABLE_TERMINATION_PARENT,
|
|
|
+ accessor=Accessor('termination_b'),
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Side B'
|
|
|
+ )
|
|
|
+ termination_b = tables.LinkColumn(
|
|
|
+ accessor=Accessor('termination_b'),
|
|
|
+ orderable=False,
|
|
|
+ verbose_name='Termination B'
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ length = tables.TemplateColumn(
|
|
|
+ template_code=CABLE_LENGTH,
|
|
|
+ order_by='_abs_length'
|
|
|
+ )
|
|
|
+ color = ColorColumn()
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:cable_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Cable
|
|
|
+ fields = (
|
|
|
+ 'pk', 'id', 'label', 'termination_a_parent', 'termination_a', 'termination_b_parent', 'termination_b',
|
|
|
+ 'status', 'type', 'color', 'length', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'id', 'label', 'termination_a_parent', 'termination_a', 'termination_b_parent', 'termination_b',
|
|
|
+ 'status', 'type',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Device connections
|
|
|
+#
|
|
|
+
|
|
|
+class ConsoleConnectionTable(BaseTable):
|
|
|
+ console_server = tables.LinkColumn(
|
|
|
+ viewname='dcim:device',
|
|
|
+ accessor=Accessor('connected_endpoint__device'),
|
|
|
+ args=[Accessor('connected_endpoint__device__pk')],
|
|
|
+ verbose_name='Console Server'
|
|
|
+ )
|
|
|
+ connected_endpoint = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='Port'
|
|
|
+ )
|
|
|
+ device = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ name = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='Console Port'
|
|
|
+ )
|
|
|
+ connection_status = tables.TemplateColumn(
|
|
|
+ template_code=CONNECTION_STATUS,
|
|
|
+ verbose_name='Status'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = ConsolePort
|
|
|
+ fields = ('console_server', 'connected_endpoint', 'device', 'name', 'connection_status')
|
|
|
+
|
|
|
+
|
|
|
+class PowerConnectionTable(BaseTable):
|
|
|
+ pdu = tables.LinkColumn(
|
|
|
+ viewname='dcim:device',
|
|
|
+ accessor=Accessor('connected_endpoint__device'),
|
|
|
+ args=[Accessor('connected_endpoint__device__pk')],
|
|
|
+ order_by='_connected_poweroutlet__device',
|
|
|
+ verbose_name='PDU'
|
|
|
+ )
|
|
|
+ outlet = tables.Column(
|
|
|
+ accessor=Accessor('_connected_poweroutlet'),
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='Outlet'
|
|
|
+ )
|
|
|
+ device = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ name = tables.Column(
|
|
|
+ linkify=True,
|
|
|
+ verbose_name='Power Port'
|
|
|
+ )
|
|
|
+ connection_status = tables.TemplateColumn(
|
|
|
+ template_code=CONNECTION_STATUS,
|
|
|
+ verbose_name='Status'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = PowerPort
|
|
|
+ fields = ('pdu', 'outlet', 'device', 'name', 'connection_status')
|
|
|
+
|
|
|
+
|
|
|
+class InterfaceConnectionTable(BaseTable):
|
|
|
+ device_a = tables.LinkColumn(
|
|
|
+ viewname='dcim:device',
|
|
|
+ accessor=Accessor('device'),
|
|
|
+ args=[Accessor('device__pk')],
|
|
|
+ verbose_name='Device A'
|
|
|
+ )
|
|
|
+ interface_a = tables.LinkColumn(
|
|
|
+ viewname='dcim:interface',
|
|
|
+ accessor=Accessor('name'),
|
|
|
+ args=[Accessor('pk')],
|
|
|
+ verbose_name='Interface A'
|
|
|
+ )
|
|
|
+ device_b = tables.LinkColumn(
|
|
|
+ viewname='dcim:device',
|
|
|
+ accessor=Accessor('_connected_interface__device'),
|
|
|
+ args=[Accessor('_connected_interface__device__pk')],
|
|
|
+ verbose_name='Device B'
|
|
|
+ )
|
|
|
+ interface_b = tables.LinkColumn(
|
|
|
+ viewname='dcim:interface',
|
|
|
+ accessor=Accessor('_connected_interface'),
|
|
|
+ args=[Accessor('_connected_interface__pk')],
|
|
|
+ verbose_name='Interface B'
|
|
|
+ )
|
|
|
+ connection_status = tables.TemplateColumn(
|
|
|
+ template_code=CONNECTION_STATUS,
|
|
|
+ verbose_name='Status'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = Interface
|
|
|
+ fields = (
|
|
|
+ 'device_a', 'interface_a', 'device_b', 'interface_b', 'connection_status',
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Virtual chassis
|
|
|
+#
|
|
|
+
|
|
|
+class VirtualChassisTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ master = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ member_count = tables.Column(
|
|
|
+ verbose_name='Members'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:virtualchassis_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = VirtualChassis
|
|
|
+ fields = ('pk', 'name', 'domain', 'master', 'member_count', 'tags')
|
|
|
+ default_columns = ('pk', 'name', 'domain', 'master', 'member_count')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Power panels
|
|
|
+#
|
|
|
+
|
|
|
+class PowerPanelTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.LinkColumn()
|
|
|
+ site = tables.LinkColumn(
|
|
|
+ viewname='dcim:site',
|
|
|
+ args=[Accessor('site__slug')]
|
|
|
+ )
|
|
|
+ powerfeed_count = tables.TemplateColumn(
|
|
|
+ template_code=POWERPANEL_POWERFEED_COUNT,
|
|
|
+ verbose_name='Feeds'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:powerpanel_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = PowerPanel
|
|
|
+ fields = ('pk', 'name', 'site', 'rack_group', 'powerfeed_count', 'tags')
|
|
|
+ default_columns = ('pk', 'name', 'site', 'rack_group', 'powerfeed_count')
|
|
|
+
|
|
|
+
|
|
|
+#
|
|
|
+# Power feeds
|
|
|
+#
|
|
|
+
|
|
|
+class PowerFeedTable(BaseTable):
|
|
|
+ pk = ToggleColumn()
|
|
|
+ name = tables.LinkColumn()
|
|
|
+ power_panel = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ rack = tables.Column(
|
|
|
+ linkify=True
|
|
|
+ )
|
|
|
+ status = tables.TemplateColumn(
|
|
|
+ template_code=STATUS_LABEL
|
|
|
+ )
|
|
|
+ type = tables.TemplateColumn(
|
|
|
+ template_code=TYPE_LABEL
|
|
|
+ )
|
|
|
+ max_utilization = tables.TemplateColumn(
|
|
|
+ template_code="{{ value }}%"
|
|
|
+ )
|
|
|
+ available_power = tables.Column(
|
|
|
+ verbose_name='Available power (VA)'
|
|
|
+ )
|
|
|
+ tags = TagColumn(
|
|
|
+ url_name='dcim:powerfeed_list'
|
|
|
+ )
|
|
|
+
|
|
|
+ class Meta(BaseTable.Meta):
|
|
|
+ model = PowerFeed
|
|
|
+ fields = (
|
|
|
+ 'pk', 'name', 'power_panel', 'rack', 'status', 'type', 'supply', 'voltage', 'amperage', 'phase',
|
|
|
+ 'max_utilization', 'available_power', 'tags',
|
|
|
+ )
|
|
|
+ default_columns = (
|
|
|
+ 'pk', 'name', 'power_panel', 'rack', 'status', 'type', 'supply', 'voltage', 'amperage', 'phase',
|
|
|
+ )
|