tables.py 11 KB

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