tables.py 13 KB

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