tables.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336
  1. import django_tables2 as tables
  2. from django_tables2.utils import Accessor
  3. from utilities.tables import BaseTable, ToggleColumn
  4. from .models import (
  5. ConsolePort, ConsolePortTemplate, ConsoleServerPortTemplate, Device, DeviceBayTemplate, DeviceRole, DeviceType,
  6. Interface, InterfaceTemplate, Manufacturer, Platform, PowerOutletTemplate, PowerPort, PowerPortTemplate, Rack,
  7. RackGroup, Site,
  8. )
  9. DEVICE_LINK = """
  10. <a href="{% url 'dcim:device' pk=record.pk %}">
  11. {{ record.name|default:'<span class="label label-info">Unnamed device</span>' }}
  12. </a>
  13. """
  14. RACKGROUP_ACTIONS = """
  15. {% if perms.dcim.change_rackgroup %}
  16. <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>
  17. {% endif %}
  18. """
  19. DEVICEROLE_ACTIONS = """
  20. {% if perms.dcim.change_devicerole %}
  21. <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>
  22. {% endif %}
  23. """
  24. MANUFACTURER_ACTIONS = """
  25. {% if perms.dcim.change_manufacturer %}
  26. <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>
  27. {% endif %}
  28. """
  29. PLATFORM_ACTIONS = """
  30. {% if perms.dcim.change_platform %}
  31. <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>
  32. {% endif %}
  33. """
  34. STATUS_ICON = """
  35. {% if record.status %}
  36. <span class="glyphicon glyphicon-ok-sign text-success" title="Active" aria-hidden="true"></span>
  37. {% else %}
  38. <span class="glyphicon glyphicon-minus-sign text-danger" title="Offline" aria-hidden="true"></span>
  39. {% endif %}
  40. """
  41. UTILIZATION_GRAPH = """
  42. {% load helpers %}
  43. {% utilization_graph record.get_utilization %}
  44. """
  45. #
  46. # Sites
  47. #
  48. class SiteTable(BaseTable):
  49. pk = ToggleColumn()
  50. name = tables.LinkColumn('dcim:site', args=[Accessor('slug')], verbose_name='Name')
  51. facility = tables.Column(verbose_name='Facility')
  52. tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant')
  53. asn = tables.Column(verbose_name='ASN')
  54. rack_count = tables.Column(accessor=Accessor('count_racks'), orderable=False, verbose_name='Racks')
  55. device_count = tables.Column(accessor=Accessor('count_devices'), orderable=False, verbose_name='Devices')
  56. prefix_count = tables.Column(accessor=Accessor('count_prefixes'), orderable=False, verbose_name='Prefixes')
  57. vlan_count = tables.Column(accessor=Accessor('count_vlans'), orderable=False, verbose_name='VLANs')
  58. circuit_count = tables.Column(accessor=Accessor('count_circuits'), orderable=False, verbose_name='Circuits')
  59. class Meta(BaseTable.Meta):
  60. model = Site
  61. fields = ('pk', 'name', 'facility', 'tenant', 'asn', 'rack_count', 'device_count', 'prefix_count',
  62. 'vlan_count', 'circuit_count')
  63. #
  64. # Rack groups
  65. #
  66. class RackGroupTable(BaseTable):
  67. pk = ToggleColumn()
  68. name = tables.LinkColumn(verbose_name='Name')
  69. site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site')
  70. rack_count = tables.Column(verbose_name='Racks')
  71. slug = tables.Column(verbose_name='Slug')
  72. actions = tables.TemplateColumn(template_code=RACKGROUP_ACTIONS, attrs={'td': {'class': 'text-right'}},
  73. verbose_name='')
  74. class Meta(BaseTable.Meta):
  75. model = RackGroup
  76. fields = ('pk', 'name', 'site', 'rack_count', 'slug', 'actions')
  77. #
  78. # Racks
  79. #
  80. class RackTable(BaseTable):
  81. pk = ToggleColumn()
  82. name = tables.LinkColumn('dcim:rack', args=[Accessor('pk')], verbose_name='Name')
  83. site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site')
  84. group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group')
  85. facility_id = tables.Column(verbose_name='Facility ID')
  86. tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant')
  87. u_height = tables.TemplateColumn("{{ record.u_height }}U", verbose_name='Height')
  88. devices = tables.Column(accessor=Accessor('device_count'), verbose_name='Devices')
  89. u_consumed = tables.TemplateColumn("{{ record.u_consumed|default:'0' }}U", verbose_name='Used')
  90. utilization = tables.TemplateColumn(UTILIZATION_GRAPH, orderable=False, verbose_name='Utilization')
  91. class Meta(BaseTable.Meta):
  92. model = Rack
  93. fields = ('pk', 'name', 'site', 'group', 'facility_id', 'tenant', 'u_height', 'devices', 'u_consumed',
  94. 'utilization')
  95. class RackImportTable(BaseTable):
  96. name = tables.LinkColumn('dcim:rack', args=[Accessor('pk')], verbose_name='Name')
  97. site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site')
  98. group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group')
  99. facility_id = tables.Column(verbose_name='Facility ID')
  100. tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant')
  101. u_height = tables.Column(verbose_name='Height (U)')
  102. class Meta(BaseTable.Meta):
  103. model = Rack
  104. fields = ('site', 'group', 'name', 'facility_id', 'tenant', 'u_height')
  105. #
  106. # Manufacturers
  107. #
  108. class ManufacturerTable(BaseTable):
  109. pk = ToggleColumn()
  110. name = tables.LinkColumn(verbose_name='Name')
  111. devicetype_count = tables.Column(verbose_name='Device Types')
  112. slug = tables.Column(verbose_name='Slug')
  113. actions = tables.TemplateColumn(template_code=MANUFACTURER_ACTIONS, attrs={'td': {'class': 'text-right'}},
  114. verbose_name='')
  115. class Meta(BaseTable.Meta):
  116. model = Manufacturer
  117. fields = ('pk', 'name', 'devicetype_count', 'slug', 'actions')
  118. #
  119. # Device types
  120. #
  121. class DeviceTypeTable(BaseTable):
  122. pk = ToggleColumn()
  123. manufacturer = tables.Column(verbose_name='Manufacturer')
  124. model = tables.LinkColumn('dcim:devicetype', args=[Accessor('pk')], verbose_name='Device Type')
  125. part_number = tables.Column(verbose_name='Part Number')
  126. class Meta(BaseTable.Meta):
  127. model = DeviceType
  128. fields = ('pk', 'model', 'manufacturer', 'part_number', 'u_height')
  129. #
  130. # Device type components
  131. #
  132. class ConsolePortTemplateTable(BaseTable):
  133. pk = ToggleColumn()
  134. class Meta(BaseTable.Meta):
  135. model = ConsolePortTemplate
  136. fields = ('pk', 'name')
  137. empty_text = "None"
  138. show_header = False
  139. class ConsoleServerPortTemplateTable(BaseTable):
  140. pk = ToggleColumn()
  141. class Meta(BaseTable.Meta):
  142. model = ConsoleServerPortTemplate
  143. fields = ('pk', 'name')
  144. empty_text = "None"
  145. show_header = False
  146. class PowerPortTemplateTable(BaseTable):
  147. pk = ToggleColumn()
  148. class Meta(BaseTable.Meta):
  149. model = PowerPortTemplate
  150. fields = ('pk', 'name')
  151. empty_text = "None"
  152. show_header = False
  153. class PowerOutletTemplateTable(BaseTable):
  154. pk = ToggleColumn()
  155. class Meta(BaseTable.Meta):
  156. model = PowerOutletTemplate
  157. fields = ('pk', 'name')
  158. empty_text = "None"
  159. show_header = False
  160. class InterfaceTemplateTable(BaseTable):
  161. pk = ToggleColumn()
  162. class Meta(BaseTable.Meta):
  163. model = InterfaceTemplate
  164. fields = ('pk', 'name', 'form_factor')
  165. empty_text = "None"
  166. show_header = False
  167. class DeviceBayTemplateTable(BaseTable):
  168. pk = ToggleColumn()
  169. class Meta(BaseTable.Meta):
  170. model = DeviceBayTemplate
  171. fields = ('pk', 'name')
  172. empty_text = "None"
  173. show_header = False
  174. #
  175. # Device roles
  176. #
  177. class DeviceRoleTable(BaseTable):
  178. pk = ToggleColumn()
  179. name = tables.LinkColumn(verbose_name='Name')
  180. device_count = tables.Column(verbose_name='Devices')
  181. slug = tables.Column(verbose_name='Slug')
  182. color = tables.Column(verbose_name='Color')
  183. actions = tables.TemplateColumn(template_code=DEVICEROLE_ACTIONS, attrs={'td': {'class': 'text-right'}},
  184. verbose_name='')
  185. class Meta(BaseTable.Meta):
  186. model = DeviceRole
  187. fields = ('pk', 'name', 'device_count', 'slug', 'color', 'actions')
  188. #
  189. # Platforms
  190. #
  191. class PlatformTable(BaseTable):
  192. pk = ToggleColumn()
  193. name = tables.LinkColumn(verbose_name='Name')
  194. device_count = tables.Column(verbose_name='Devices')
  195. slug = tables.Column(verbose_name='Slug')
  196. actions = tables.TemplateColumn(template_code=PLATFORM_ACTIONS, attrs={'td': {'class': 'text-right'}}, verbose_name='')
  197. class Meta(BaseTable.Meta):
  198. model = Platform
  199. fields = ('pk', 'name', 'device_count', 'slug', 'actions')
  200. #
  201. # Devices
  202. #
  203. class DeviceTable(BaseTable):
  204. pk = ToggleColumn()
  205. status = tables.TemplateColumn(template_code=STATUS_ICON, verbose_name='')
  206. name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name')
  207. tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant')
  208. site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site')
  209. rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack')
  210. device_role = tables.Column(verbose_name='Role')
  211. device_type = tables.Column(verbose_name='Type')
  212. primary_ip = tables.TemplateColumn(orderable=False, verbose_name='IP Address',
  213. template_code="{{ record.primary_ip.address.ip }}")
  214. class Meta(BaseTable.Meta):
  215. model = Device
  216. fields = ('pk', 'name', 'status', 'tenant', 'site', 'rack', 'device_role', 'device_type', 'primary_ip')
  217. class DeviceImportTable(BaseTable):
  218. name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name')
  219. tenant = tables.LinkColumn('tenancy:tenant', args=[Accessor('tenant.slug')], verbose_name='Tenant')
  220. site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site')
  221. rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack')
  222. position = tables.Column(verbose_name='Position')
  223. device_role = tables.Column(verbose_name='Role')
  224. device_type = tables.Column(verbose_name='Type')
  225. class Meta(BaseTable.Meta):
  226. model = Device
  227. fields = ('name', 'tenant', 'site', 'rack', 'position', 'device_role', 'device_type')
  228. empty_text = False
  229. #
  230. # Device connections
  231. #
  232. class ConsoleConnectionTable(BaseTable):
  233. console_server = tables.LinkColumn('dcim:device', accessor=Accessor('cs_port.device'),
  234. args=[Accessor('cs_port.device.pk')], verbose_name='Console server')
  235. cs_port = tables.Column(verbose_name='Port')
  236. device = tables.LinkColumn('dcim:device', args=[Accessor('device.pk')], verbose_name='Device')
  237. name = tables.Column(verbose_name='Console port')
  238. class Meta(BaseTable.Meta):
  239. model = ConsolePort
  240. fields = ('console_server', 'cs_port', 'device', 'name')
  241. class PowerConnectionTable(BaseTable):
  242. pdu = tables.LinkColumn('dcim:device', accessor=Accessor('power_outlet.device'),
  243. args=[Accessor('power_outlet.device.pk')], verbose_name='PDU')
  244. power_outlet = tables.Column(verbose_name='Outlet')
  245. device = tables.LinkColumn('dcim:device', args=[Accessor('device.pk')], verbose_name='Device')
  246. name = tables.Column(verbose_name='Console port')
  247. class Meta(BaseTable.Meta):
  248. model = PowerPort
  249. fields = ('pdu', 'power_outlet', 'device', 'name')
  250. class InterfaceConnectionTable(BaseTable):
  251. device_a = tables.LinkColumn('dcim:device', accessor=Accessor('interface_a.device'),
  252. args=[Accessor('interface_a.device.pk')], verbose_name='Device A')
  253. interface_a = tables.Column(verbose_name='Interface A')
  254. device_b = tables.LinkColumn('dcim:device', accessor=Accessor('interface_b.device'),
  255. args=[Accessor('interface_b.device.pk')], verbose_name='Device B')
  256. interface_b = tables.Column(verbose_name='Interface B')
  257. class Meta(BaseTable.Meta):
  258. model = Interface
  259. fields = ('device_a', 'interface_a', 'device_b', 'interface_b')