tables.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323
  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. #
  42. # Sites
  43. #
  44. class SiteTable(BaseTable):
  45. name = tables.LinkColumn('dcim:site', args=[Accessor('slug')], verbose_name='Name')
  46. facility = tables.Column(verbose_name='Facility')
  47. asn = tables.Column(verbose_name='ASN')
  48. rack_count = tables.Column(accessor=Accessor('count_racks'), orderable=False, verbose_name='Racks')
  49. device_count = tables.Column(accessor=Accessor('count_devices'), orderable=False, verbose_name='Devices')
  50. prefix_count = tables.Column(accessor=Accessor('count_prefixes'), orderable=False, verbose_name='Prefixes')
  51. vlan_count = tables.Column(accessor=Accessor('count_vlans'), orderable=False, verbose_name='VLANs')
  52. circuit_count = tables.Column(accessor=Accessor('count_circuits'), orderable=False, verbose_name='Circuits')
  53. class Meta(BaseTable.Meta):
  54. model = Site
  55. fields = ('name', 'facility', 'asn', 'rack_count', 'device_count', 'prefix_count', 'vlan_count',
  56. 'circuit_count')
  57. #
  58. # Rack groups
  59. #
  60. class RackGroupTable(BaseTable):
  61. pk = ToggleColumn()
  62. name = tables.LinkColumn(verbose_name='Name')
  63. site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site')
  64. rack_count = tables.Column(verbose_name='Racks')
  65. slug = tables.Column(verbose_name='Slug')
  66. edit = tables.TemplateColumn(template_code=RACKGROUP_EDIT_LINK, verbose_name='')
  67. class Meta(BaseTable.Meta):
  68. model = RackGroup
  69. fields = ('pk', 'name', 'site', 'rack_count', 'slug', 'edit')
  70. #
  71. # Racks
  72. #
  73. class RackTable(BaseTable):
  74. pk = ToggleColumn()
  75. name = tables.LinkColumn('dcim:rack', args=[Accessor('pk')], verbose_name='Name')
  76. site = tables.LinkColumn('dcim:site', args=[Accessor('site.slug')], verbose_name='Site')
  77. group = tables.Column(accessor=Accessor('group.name'), verbose_name='Group')
  78. facility_id = tables.Column(verbose_name='Facility ID')
  79. u_height = tables.Column(verbose_name='Height (U)')
  80. devices = tables.Column(accessor=Accessor('device_count'), verbose_name='Devices')
  81. class Meta(BaseTable.Meta):
  82. model = Rack
  83. fields = ('pk', 'name', 'site', 'group', 'facility_id', 'u_height', 'devices')
  84. #
  85. # Manufacturers
  86. #
  87. class ManufacturerTable(BaseTable):
  88. pk = ToggleColumn()
  89. name = tables.LinkColumn(verbose_name='Name')
  90. devicetype_count = tables.Column(verbose_name='Device Types')
  91. slug = tables.Column(verbose_name='Slug')
  92. edit = tables.TemplateColumn(template_code=MANUFACTURER_EDIT_LINK, verbose_name='')
  93. class Meta(BaseTable.Meta):
  94. model = Manufacturer
  95. fields = ('pk', 'name', 'devicetype_count', 'slug', 'edit')
  96. #
  97. # Device types
  98. #
  99. class DeviceTypeTable(BaseTable):
  100. pk = ToggleColumn()
  101. model = tables.LinkColumn('dcim:devicetype', args=[Accessor('pk')], verbose_name='Device Type')
  102. class Meta(BaseTable.Meta):
  103. model = DeviceType
  104. fields = ('pk', 'model', 'manufacturer', 'u_height')
  105. #
  106. # Device type components
  107. #
  108. class ConsolePortTemplateTable(tables.Table):
  109. pk = ToggleColumn()
  110. class Meta:
  111. model = ConsolePortTemplate
  112. fields = ('pk', 'name')
  113. empty_text = "None"
  114. show_header = False
  115. attrs = {
  116. 'class': 'table table-hover',
  117. }
  118. class ConsoleServerPortTemplateTable(tables.Table):
  119. pk = ToggleColumn()
  120. class Meta:
  121. model = ConsoleServerPortTemplate
  122. fields = ('pk', 'name')
  123. empty_text = "None"
  124. show_header = False
  125. attrs = {
  126. 'class': 'table table-hover',
  127. }
  128. class PowerPortTemplateTable(tables.Table):
  129. pk = ToggleColumn()
  130. class Meta:
  131. model = PowerPortTemplate
  132. fields = ('pk', 'name')
  133. empty_text = "None"
  134. show_header = False
  135. attrs = {
  136. 'class': 'table table-hover',
  137. }
  138. class PowerOutletTemplateTable(tables.Table):
  139. pk = ToggleColumn()
  140. class Meta:
  141. model = PowerOutletTemplate
  142. fields = ('pk', 'name')
  143. empty_text = "None"
  144. show_header = False
  145. attrs = {
  146. 'class': 'table table-hover',
  147. }
  148. class InterfaceTemplateTable(tables.Table):
  149. pk = ToggleColumn()
  150. class Meta:
  151. model = InterfaceTemplate
  152. fields = ('pk', 'name')
  153. empty_text = "None"
  154. show_header = False
  155. attrs = {
  156. 'class': 'table table-hover panel-body',
  157. }
  158. class DeviceBayTemplateTable(tables.Table):
  159. pk = ToggleColumn()
  160. class Meta:
  161. model = DeviceBayTemplate
  162. fields = ('pk', 'name')
  163. empty_text = "None"
  164. show_header = False
  165. attrs = {
  166. 'class': 'table table-hover panel-body',
  167. }
  168. #
  169. # Device roles
  170. #
  171. class DeviceRoleTable(BaseTable):
  172. pk = ToggleColumn()
  173. name = tables.LinkColumn(verbose_name='Name')
  174. device_count = tables.Column(verbose_name='Devices')
  175. slug = tables.Column(verbose_name='Slug')
  176. color = tables.Column(verbose_name='Color')
  177. edit = tables.TemplateColumn(template_code=DEVICEROLE_EDIT_LINK, verbose_name='')
  178. class Meta(BaseTable.Meta):
  179. model = DeviceRole
  180. fields = ('pk', 'name', 'device_count', 'slug', 'color')
  181. #
  182. # Platforms
  183. #
  184. class PlatformTable(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. edit = tables.TemplateColumn(template_code=PLATFORM_EDIT_LINK, verbose_name='')
  190. class Meta(BaseTable.Meta):
  191. model = Platform
  192. fields = ('pk', 'name', 'device_count', 'slug', 'edit')
  193. #
  194. # Devices
  195. #
  196. class DeviceTable(BaseTable):
  197. pk = ToggleColumn()
  198. status = tables.TemplateColumn(template_code=STATUS_ICON, verbose_name='')
  199. name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name')
  200. site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site')
  201. rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack')
  202. device_role = tables.Column(verbose_name='Role')
  203. device_type = tables.Column(verbose_name='Type')
  204. primary_ip = tables.TemplateColumn(orderable=False, verbose_name='IP Address',
  205. template_code="{{ record.primary_ip.address.ip }}")
  206. class Meta(BaseTable.Meta):
  207. model = Device
  208. fields = ('pk', 'name', 'status', 'site', 'rack', 'device_role', 'device_type', 'primary_ip')
  209. class DeviceImportTable(BaseTable):
  210. name = tables.TemplateColumn(template_code=DEVICE_LINK, verbose_name='Name')
  211. site = tables.Column(accessor=Accessor('rack.site'), verbose_name='Site')
  212. rack = tables.LinkColumn('dcim:rack', args=[Accessor('rack.pk')], verbose_name='Rack')
  213. position = tables.Column(verbose_name='Position')
  214. device_role = tables.Column(verbose_name='Role')
  215. device_type = tables.Column(verbose_name='Type')
  216. class Meta(BaseTable.Meta):
  217. model = Device
  218. fields = ('name', 'site', 'rack', 'position', 'device_role', 'device_type')
  219. empty_text = False
  220. #
  221. # Device connections
  222. #
  223. class ConsoleConnectionTable(BaseTable):
  224. console_server = tables.LinkColumn('dcim:device', accessor=Accessor('cs_port.device'),
  225. args=[Accessor('cs_port.device.pk')], verbose_name='Console server')
  226. cs_port = tables.Column(verbose_name='Port')
  227. device = tables.LinkColumn('dcim:device', args=[Accessor('device.pk')], verbose_name='Device')
  228. name = tables.Column(verbose_name='Console port')
  229. class Meta(BaseTable.Meta):
  230. model = ConsolePort
  231. fields = ('console_server', 'cs_port', 'device', 'name')
  232. class PowerConnectionTable(BaseTable):
  233. pdu = tables.LinkColumn('dcim:device', accessor=Accessor('power_outlet.device'),
  234. args=[Accessor('power_outlet.device.pk')], verbose_name='PDU')
  235. power_outlet = tables.Column(verbose_name='Outlet')
  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 = PowerPort
  240. fields = ('pdu', 'power_outlet', 'device', 'name')
  241. class InterfaceConnectionTable(BaseTable):
  242. device_a = tables.LinkColumn('dcim:device', accessor=Accessor('interface_a.device'),
  243. args=[Accessor('interface_a.device.pk')], verbose_name='Device A')
  244. interface_a = tables.Column(verbose_name='Interface A')
  245. device_b = tables.LinkColumn('dcim:device', accessor=Accessor('interface_b.device'),
  246. args=[Accessor('interface_b.device.pk')], verbose_name='Device B')
  247. interface_b = tables.Column(verbose_name='Interface B')
  248. class Meta(BaseTable.Meta):
  249. model = Interface
  250. fields = ('device_a', 'interface_a', 'device_b', 'interface_b')