import django_tables2 as tables from django_tables2.utils import Accessor from utilities.tables import BaseTable, ToggleColumn from .models import ( ConsolePort, ConsolePortTemplate, ConsoleServerPortTemplate, Device, DeviceBayTemplate, DeviceRole, DeviceType, Interface, InterfaceTemplate, Manufacturer, Platform, PowerOutletTemplate, PowerPort, PowerPortTemplate, Rack, RackGroup, Site, ) COLOR_LABEL = """ """ DEVICE_LINK = """ {{ record.name|default:'Unnamed device' }} """ RACKGROUP_ACTIONS = """ {% if perms.dcim.change_rackgroup %} {% endif %} """ RACKROLE_ACTIONS = """ {% if perms.dcim.change_rackrole %} {% endif %} """ RACK_ROLE = """ {% if record.role %} {% else %} — {% endif %} """ DEVICEROLE_ACTIONS = """ {% if perms.dcim.change_devicerole %} {% endif %} """ MANUFACTURER_ACTIONS = """ {% if perms.dcim.change_manufacturer %} {% endif %} """ PLATFORM_ACTIONS = """ {% if perms.dcim.change_platform %} {% endif %} """ DEVICE_ROLE = """ """ STATUS_ICON = """ {% if record.status %} {% else %} {% endif %} """ UTILIZATION_GRAPH = """ {% load helpers %} {% utilization_graph record.get_utilization %} """ # # Sites # class SiteTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn('dcim:site', args=[Accessor('slug')], verbose_name='Name') facility = tables.Column(verbose_name='Facility') tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant') asn = tables.Column(verbose_name='ASN') rack_count = tables.Column(accessor=Accessor('count_racks'), orderable=False, verbose_name='Racks') device_count = tables.Column(accessor=Accessor('count_devices'), orderable=False, verbose_name='Devices') prefix_count = tables.Column(accessor=Accessor('count_prefixes'), orderable=False, verbose_name='Prefixes') vlan_count = tables.Column(accessor=Accessor('count_vlans'), orderable=False, verbose_name='VLANs') circuit_count = tables.Column(accessor=Accessor('count_circuits'), orderable=False, verbose_name='Circuits') class Meta(BaseTable.Meta): model = Site fields = ('pk', 'name', 'facility', 'tenant', 'asn', 'rack_count', 'device_count', 'prefix_count', 'vlan_count', 'circuit_count') # # Rack groups # class RackGroupTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn(verbose_name='Name') site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site') rack_count = tables.Column(verbose_name='Racks') slug = tables.Column(verbose_name='Slug') actions = tables.TemplateColumn(template_code=RACKGROUP_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='') class Meta(BaseTable.Meta): model = RackGroup fields = ('pk', 'name', 'site', 'rack_count', 'slug', 'actions') # # Rack roles # class RackRoleTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn(verbose_name='Name') rack_count = tables.Column(verbose_name='Racks') color = tables.TemplateColumn(COLOR_LABEL, verbose_name='Color') slug = tables.Column(verbose_name='Slug') actions = tables.TemplateColumn(template_code=RACKROLE_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='') class Meta(BaseTable.Meta): model = RackGroup fields = ('pk', 'name', 'rack_count', 'color', 'slug', 'actions') # # Racks # class RackTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn('dcim:rack', args=[Accessor('pk')], verbose_name='Name') site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site') group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group') facility_id = tables.Column(verbose_name='Facility ID') tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant') role = tables.TemplateColumn(RACK_ROLE, verbose_name='Role') u_height = tables.TemplateColumn("{{ record.u_height }}U", verbose_name='Height') devices = tables.Column(accessor=Accessor('device_count'), verbose_name='Devices') u_consumed = tables.TemplateColumn("{{ record.u_consumed|default:'0' }}U", verbose_name='Used') utilization = tables.TemplateColumn(UTILIZATION_GRAPH, orderable=False, verbose_name='Utilization') class Meta(BaseTable.Meta): model = Rack fields = ('pk', 'name', 'site', 'group', 'facility_id', 'tenant', 'role', 'u_height', 'devices', 'u_consumed', 'utilization') class RackImportTable(BaseTable): name = tables.LinkColumn('dcim:rack', args=[Accessor('pk')], verbose_name='Name') site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site') group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group') facility_id = tables.Column(verbose_name='Facility ID') tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant') u_height = tables.Column(verbose_name='Height (U)') class Meta(BaseTable.Meta): model = Rack fields = ('site', 'group', 'name', 'facility_id', 'tenant', 'u_height') # # Manufacturers # class ManufacturerTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn(verbose_name='Name') devicetype_count = tables.Column(verbose_name='Device Types') slug = tables.Column(verbose_name='Slug') actions = tables.TemplateColumn(template_code=MANUFACTURER_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='') class Meta(BaseTable.Meta): model = Manufacturer fields = ('pk', 'name', 'devicetype_count', 'slug', 'actions') # # Device types # class DeviceTypeTable(BaseTable): pk = ToggleColumn() manufacturer = tables.Column(verbose_name='Manufacturer') model = tables.LinkColumn('dcim:devicetype', args=[Accessor('pk')], verbose_name='Device Type') part_number = tables.Column(verbose_name='Part Number') class Meta(BaseTable.Meta): model = DeviceType fields = ('pk', 'model', 'manufacturer', 'part_number', 'u_height') # # Device type components # class ConsolePortTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = ConsolePortTemplate fields = ('pk', 'name') empty_text = "None" show_header = False class ConsoleServerPortTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = ConsoleServerPortTemplate fields = ('pk', 'name') empty_text = "None" show_header = False class PowerPortTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = PowerPortTemplate fields = ('pk', 'name') empty_text = "None" show_header = False class PowerOutletTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = PowerOutletTemplate fields = ('pk', 'name') empty_text = "None" show_header = False class InterfaceTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = InterfaceTemplate fields = ('pk', 'name', 'form_factor') empty_text = "None" show_header = False class DeviceBayTemplateTable(BaseTable): pk = ToggleColumn() class Meta(BaseTable.Meta): model = DeviceBayTemplate fields = ('pk', 'name') empty_text = "None" show_header = False # # Device roles # class DeviceRoleTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn(verbose_name='Name') device_count = tables.Column(verbose_name='Devices') color = tables.TemplateColumn(COLOR_LABEL, verbose_name='Color') slug = tables.Column(verbose_name='Slug') actions = tables.TemplateColumn(template_code=DEVICEROLE_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='') class Meta(BaseTable.Meta): model = DeviceRole fields = ('pk', 'name', 'device_count', 'color', 'slug', 'actions') # # Platforms # class PlatformTable(BaseTable): pk = ToggleColumn() name = tables.LinkColumn(verbose_name='Name') device_count = tables.Column(verbose_name='Devices') slug = tables.Column(verbose_name='Slug') actions = tables.TemplateColumn(template_code=PLATFORM_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='') class Meta(BaseTable.Meta): model = Platform fields = ('pk', 'name', 'device_count', 'slug', 'actions') # # Devices # class DeviceTable(BaseTable): pk = ToggleColumn() status = tables.TemplateColumn(template_code=STATUS_ICON, verbose_name='') name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name') tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant') site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site') rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack') device_role = tables.TemplateColumn(DEVICE_ROLE, verbose_name='Role') device_type = tables.Column(verbose_name='Type') primary_ip = tables.TemplateColumn(orderable=False, verbose_name='IP Address', template_code="{{ record.primary_ip.address.ip }}") class Meta(BaseTable.Meta): model = Device fields = ('pk', 'name', 'status', 'tenant', 'site', 'rack', 'device_role', 'device_type', 'primary_ip') class DeviceImportTable(BaseTable): name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name') tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant') site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site') rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack') position = tables.Column(verbose_name='Position') device_role = tables.Column(verbose_name='Role') device_type = tables.Column(verbose_name='Type') class Meta(BaseTable.Meta): model = Device fields = ('name', 'tenant', 'site', 'rack', 'position', 'device_role', 'device_type') empty_text = False # # Device connections # class ConsoleConnectionTable(BaseTable): console_server = tables.LinkColumn('dcim:device', accessor=Accessor('cs_port.device'), args=[Accessor('cs_port.device.pk')], verbose_name='Console server') cs_port = tables.Column(verbose_name='Port') device = tables.LinkColumn('dcim:device', args=[Accessor('device.pk')], verbose_name='Device') name = tables.Column(verbose_name='Console port') class Meta(BaseTable.Meta): model = ConsolePort fields = ('console_server', 'cs_port', 'device', 'name') class PowerConnectionTable(BaseTable): pdu = tables.LinkColumn('dcim:device', accessor=Accessor('power_outlet.device'), args=[Accessor('power_outlet.device.pk')], verbose_name='PDU') power_outlet = tables.Column(verbose_name='Outlet') device = tables.LinkColumn('dcim:device', args=[Accessor('device.pk')], verbose_name='Device') name = tables.Column(verbose_name='Console port') class Meta(BaseTable.Meta): model = PowerPort fields = ('pdu', 'power_outlet', 'device', 'name') class InterfaceConnectionTable(BaseTable): device_a = tables.LinkColumn('dcim:device', accessor=Accessor('interface_a.device'), args=[Accessor('interface_a.device.pk')], verbose_name='Device A') interface_a = tables.Column(verbose_name='Interface A') device_b = tables.LinkColumn('dcim:device', accessor=Accessor('interface_b.device'), args=[Accessor('interface_b.device.pk')], verbose_name='Device B') interface_b = tables.Column(verbose_name='Interface B') class Meta(BaseTable.Meta): model = Interface fields = ('device_a', 'interface_a', 'device_b', 'interface_b')