123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519 |
- import django_tables2 as tables
- from django_tables2.utils import Accessor
- from utilities.tables import BaseTable, SearchTable, ToggleColumn
- from .models import (
- ConsolePort, ConsolePortTemplate, ConsoleServerPortTemplate, Device, DeviceBayTemplate, DeviceRole, DeviceType,
- Interface, InterfaceTemplate, Manufacturer, Platform, PowerOutletTemplate, PowerPort, PowerPortTemplate, Rack,
- RackGroup, RackReservation, Region, Site,
- )
- REGION_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="{% url 'dcim:site_list' %}?region={{ record.slug }}">{{ 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 = """
- <label class="label" style="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>
- """
- REGION_ACTIONS = """
- {% if perms.dcim.change_region %}
- <a href="{% url 'dcim:region_edit' pk=record.pk %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- RACKGROUP_ACTIONS = """
- {% if perms.dcim.change_rackgroup %}
- <a href="{% url 'dcim:rackgroup_edit' pk=record.pk %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- RACKROLE_ACTIONS = """
- {% if perms.dcim.change_rackrole %}
- <a href="{% url 'dcim:rackrole_edit' pk=record.pk %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- RACK_ROLE = """
- {% if record.role %}
- <label class="label" style="background-color: #{{ record.role.color }}">{{ value }}</label>
- {% else %}
- —
- {% endif %}
- """
- RACKRESERVATION_ACTIONS = """
- {% if perms.dcim.change_rackreservation %}
- <a href="{% url 'dcim:rackreservation_edit' pk=record.pk %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- DEVICEROLE_ACTIONS = """
- {% if perms.dcim.change_devicerole %}
- <a href="{% url 'dcim:devicerole_edit' slug=record.slug %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- MANUFACTURER_ACTIONS = """
- {% if perms.dcim.change_manufacturer %}
- <a href="{% url 'dcim:manufacturer_edit' slug=record.slug %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- PLATFORM_ACTIONS = """
- {% if perms.dcim.change_platform %}
- <a href="{% url 'dcim:platform_edit' slug=record.slug %}" class="btn btn-xs btn-warning"><i class="glyphicon glyphicon-pencil" aria-hidden="true"></i></a>
- {% endif %}
- """
- DEVICE_ROLE = """
- <label class="label" style="background-color: #{{ record.device_role.color }}">{{ value }}</label>
- """
- DEVICE_STATUS = """
- <span class="label label-{{ record.get_status_class }}">{{ record.get_status_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:"" }}
- """
- SUBDEVICE_ROLE_TEMPLATE = """
- {% if record.subdevice_role == True %}Parent{% elif record.subdevice_role == False %}Child{% else %}—{% endif %}
- """
- UTILIZATION_GRAPH = """
- {% load helpers %}
- {% utilization_graph value %}
- """
- #
- # Regions
- #
- class RegionTable(BaseTable):
- pk = ToggleColumn()
- name = tables.TemplateColumn(template_code=REGION_LINK, orderable=False)
- site_count = tables.Column(verbose_name='Sites')
- slug = tables.Column(verbose_name='Slug')
- actions = tables.TemplateColumn(
- template_code=REGION_ACTIONS,
- attrs={'td': {'class': 'text-right'}},
- verbose_name=''
- )
- class Meta(BaseTable.Meta):
- model = Region
- fields = ('pk', 'name', 'site_count', 'slug', 'actions')
- #
- # Sites
- #
- class SiteTable(BaseTable):
- pk = ToggleColumn()
- name = tables.LinkColumn()
- region = tables.TemplateColumn(template_code=SITE_REGION_LINK)
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- 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', 'region', 'tenant', 'asn', 'rack_count', 'device_count', 'prefix_count',
- 'vlan_count', 'circuit_count',
- )
- class SiteSearchTable(SearchTable):
- name = tables.LinkColumn()
- region = tables.TemplateColumn(template_code=SITE_REGION_LINK)
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- class Meta(SearchTable.Meta):
- model = Site
- fields = ('name', 'facility', 'region', 'tenant', 'asn')
- #
- # 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()
- site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')])
- group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group')
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- role = tables.TemplateColumn(RACK_ROLE)
- u_height = tables.TemplateColumn("{{ record.u_height }}U", verbose_name='Height')
- devices = tables.Column(accessor=Accessor('device_count'))
- get_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', 'get_utilization'
- )
- class RackSearchTable(SearchTable):
- name = tables.LinkColumn()
- site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')])
- group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group')
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- role = tables.TemplateColumn(RACK_ROLE)
- u_height = tables.TemplateColumn("{{ record.u_height }}U", verbose_name='Height')
- class Meta(SearchTable.Meta):
- model = Rack
- fields = ('name', 'site', 'group', 'facility_id', 'tenant', 'role', 'u_height')
- 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')
- #
- # Rack reservations
- #
- class RackReservationTable(BaseTable):
- pk = ToggleColumn()
- rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')])
- unit_list = tables.Column(orderable=False, verbose_name='Units')
- actions = tables.TemplateColumn(
- template_code=RACKRESERVATION_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name=''
- )
- class Meta(BaseTable.Meta):
- model = RackReservation
- fields = ('pk', 'rack', 'unit_list', 'user', 'created', 'description', 'actions')
- #
- # 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()
- model = tables.LinkColumn('dcim:devicetype', args=[Accessor('pk')], verbose_name='Device Type')
- is_full_depth = tables.BooleanColumn(verbose_name='Full Depth')
- is_console_server = tables.BooleanColumn(verbose_name='CS')
- is_pdu = tables.BooleanColumn(verbose_name='PDU')
- is_network_device = tables.BooleanColumn(verbose_name='Net')
- subdevice_role = tables.TemplateColumn(SUBDEVICE_ROLE_TEMPLATE, verbose_name='Subdevice Role')
- instance_count = tables.Column(verbose_name='Instances')
- class Meta(BaseTable.Meta):
- model = DeviceType
- fields = (
- 'pk', 'model', 'manufacturer', 'part_number', 'u_height', 'is_full_depth', 'is_console_server', 'is_pdu',
- 'is_network_device', 'subdevice_role', 'instance_count'
- )
- class DeviceTypeSearchTable(SearchTable):
- model = tables.LinkColumn('dcim:devicetype', args=[Accessor('pk')], verbose_name='Device Type')
- is_full_depth = tables.BooleanColumn(verbose_name='Full Depth')
- is_console_server = tables.BooleanColumn(verbose_name='CS')
- is_pdu = tables.BooleanColumn(verbose_name='PDU')
- is_network_device = tables.BooleanColumn(verbose_name='Net')
- subdevice_role = tables.TemplateColumn(SUBDEVICE_ROLE_TEMPLATE, verbose_name='Subdevice Role')
- class Meta(SearchTable.Meta):
- model = DeviceType
- fields = (
- 'model', 'manufacturer', 'part_number', 'u_height', 'is_full_depth', 'is_console_server', 'is_pdu',
- 'is_network_device', 'subdevice_role',
- )
- #
- # 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')
- rpc_client = tables.Column(accessor='get_rpc_client_display', orderable=False, verbose_name='RPC Client')
- 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', 'rpc_client', 'actions')
- #
- # Devices
- #
- class DeviceTable(BaseTable):
- pk = ToggleColumn()
- name = tables.TemplateColumn(template_code=DEVICE_LINK)
- status = tables.TemplateColumn(template_code=DEVICE_STATUS, verbose_name='Status')
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')])
- rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')])
- device_role = tables.TemplateColumn(DEVICE_ROLE, verbose_name='Role')
- device_type = tables.LinkColumn(
- 'dcim:devicetype', args=[Accessor('device_type.pk')], verbose_name='Type',
- text=lambda record: record.device_type.full_name
- )
- primary_ip = tables.TemplateColumn(
- orderable=False, verbose_name='IP Address', template_code=DEVICE_PRIMARY_IP
- )
- class Meta(BaseTable.Meta):
- model = Device
- fields = ('pk', 'name', 'status', 'tenant', 'site', 'rack', 'device_role', 'device_type', 'primary_ip')
- class DeviceSearchTable(SearchTable):
- name = tables.TemplateColumn(template_code=DEVICE_LINK)
- status = tables.TemplateColumn(template_code=DEVICE_STATUS, verbose_name='Status')
- tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')])
- site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')])
- rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')])
- device_role = tables.TemplateColumn(DEVICE_ROLE, verbose_name='Role')
- device_type = tables.LinkColumn(
- 'dcim:devicetype', args=[Accessor('device_type.pk')], verbose_name='Type',
- text=lambda record: record.device_type.full_name
- )
- class Meta(SearchTable.Meta):
- model = Device
- fields = ('name', 'status', 'tenant', 'site', 'rack', 'device_role', 'device_type')
- 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.LinkColumn('dcim:site', args=[Accessor('site.slug')], 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='Power 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')
|