virtualmachine.html 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. {% extends 'virtualization/virtualmachine/base.html' %}
  2. {% load buttons %}
  3. {% load static %}
  4. {% load helpers %}
  5. {% load plugins %}
  6. {% load i18n %}
  7. {% block content %}
  8. <div class="row my-3">
  9. <div class="col col-12 col-md-6">
  10. <div class="card">
  11. <h2 class="card-header">{% trans "Virtual Machine" %}</h2>
  12. <table class="table table-hover attr-table">
  13. <tr>
  14. <th scope="row">{% trans "Name" %}</th>
  15. <td>{{ object }}</td>
  16. </tr>
  17. <tr>
  18. <th scope="row">{% trans "Status" %}</th>
  19. <td>{% badge object.get_status_display bg_color=object.get_status_color %}</td>
  20. </tr>
  21. <tr>
  22. <th scope="row">{% trans "Role" %}</th>
  23. <td>{{ object.role|linkify|placeholder }}</td>
  24. </tr>
  25. <tr>
  26. <th scope="row">{% trans "Platform" %}</th>
  27. <td>{{ object.platform|linkify|placeholder }}</td>
  28. </tr>
  29. <tr>
  30. <th scope="row">{% trans "Description" %}</th>
  31. <td>{{ object.description|placeholder }}</td>
  32. </tr>
  33. <tr>
  34. <th scope="row">{% trans "Serial Number" %}</th>
  35. <td>{{ object.serial|placeholder }}</td>
  36. </tr>
  37. <tr>
  38. <th scope="row">{% trans "Tenant" %}</th>
  39. <td>
  40. {% if object.tenant.group %}
  41. {{ object.tenant.group|linkify }} /
  42. {% endif %}
  43. {{ object.tenant|linkify|placeholder }}
  44. </td>
  45. </tr>
  46. <tr>
  47. <th scope="row">{% trans "Config Template" %}</th>
  48. <td>{{ object.config_template|linkify|placeholder }}</td>
  49. </tr>
  50. <tr>
  51. <th scope="row">{% trans "Primary IPv4" %}</th>
  52. <td>
  53. {% if object.primary_ip4 %}
  54. <a href="{% url 'ipam:ipaddress' pk=object.primary_ip4.pk %}" id="primary_ip4">{{ object.primary_ip4.address.ip }}</a>
  55. {% if object.primary_ip4.nat_inside %}
  56. ({% trans "NAT for" %} <a href="{{ object.primary_ip4.nat_inside.get_absolute_url }}">{{ object.primary_ip4.nat_inside.address.ip }}</a>)
  57. {% elif object.primary_ip4.nat_outside.exists %}
  58. ({% trans "NAT" %}: {% for nat in object.primary_ip4.nat_outside.all %}<a href="{{ nat.get_absolute_url }}">{{ nat.address.ip }}</a>{% if not forloop.last %}, {% endif %}{% endfor %})
  59. {% endif %}
  60. {% copy_content "primary_ip4" %}
  61. {% else %}
  62. {{ ''|placeholder }}
  63. {% endif %}
  64. </td>
  65. </tr>
  66. <tr>
  67. <th scope="row">{% trans "Primary IPv6" %}</th>
  68. <td>
  69. {% if object.primary_ip6 %}
  70. <a href="{% url 'ipam:ipaddress' pk=object.primary_ip6.pk %}" id="primary_ip6">{{ object.primary_ip6.address.ip }}</a>
  71. {% if object.primary_ip6.nat_inside %}
  72. ({% trans "NAT for" %} <a href="{{ object.primary_ip6.nat_inside.get_absolute_url }}">{{ object.primary_ip6.nat_inside.address.ip }}</a>)
  73. {% elif object.primary_ip6.nat_outside.exists %}
  74. ({% trans "NAT" %}: {% for nat in object.primary_ip6.nat_outside.all %}<a href="{{ nat.get_absolute_url }}">{{ nat.address.ip }}</a>{% if not forloop.last %}, {% endif %}{% endfor %})
  75. {% endif %}
  76. {% copy_content "primary_ip6" %}
  77. {% else %}
  78. {{ ''|placeholder }}
  79. {% endif %}
  80. </td>
  81. </tr>
  82. </table>
  83. </div>
  84. {% include 'inc/panels/custom_fields.html' %}
  85. {% include 'inc/panels/tags.html' %}
  86. {% include 'inc/panels/comments.html' %}
  87. {% plugin_left_page object %}
  88. </div>
  89. <div class="col col-12 col-md-6">
  90. <div class="card">
  91. <h2 class="card-header">{% trans "Cluster" %}</h2>
  92. <table class="table table-hover attr-table">
  93. <tr>
  94. <th scope="row">{% trans "Site" %}</th>
  95. <td>
  96. {{ object.site|linkify|placeholder }}
  97. </td>
  98. </tr>
  99. <tr>
  100. <th scope="row">{% trans "Cluster" %}</th>
  101. <td>
  102. {% if object.cluster.group %}
  103. {{ object.cluster.group|linkify }} /
  104. {% endif %}
  105. {{ object.cluster|linkify|placeholder }}
  106. </td>
  107. </tr>
  108. <tr>
  109. <th scope="row">{% trans "Cluster Type" %}</th>
  110. <td>{{ object.cluster.type }}</td>
  111. </tr>
  112. <tr>
  113. <th scope="row">{% trans "Device" %}</th>
  114. <td>
  115. {{ object.device|linkify|placeholder }}
  116. </td>
  117. </tr>
  118. </table>
  119. </div>
  120. <div class="card">
  121. <h2 class="card-header">{% trans "Resources" %}</h2>
  122. <table class="table table-hover attr-table">
  123. <tr>
  124. <th scope="row"><i class="mdi mdi-gauge"></i> {% trans "Virtual CPUs" %}</th>
  125. <td>{{ object.vcpus|placeholder }}</td>
  126. </tr>
  127. <tr>
  128. <th scope="row"><i class="mdi mdi-chip"></i> {% trans "Memory" %}</th>
  129. <td>
  130. {% if object.memory %}
  131. <span title={{ object.memory }}>{{ object.memory|humanize_ram_megabytes }}</span>
  132. {% else %}
  133. {{ ''|placeholder }}
  134. {% endif %}
  135. </td>
  136. </tr>
  137. <tr>
  138. <th scope="row">
  139. <i class="mdi mdi-harddisk"></i> {% trans "Disk Space" %}
  140. </th>
  141. <td>
  142. {% if object.disk %}
  143. {{ object.disk|humanize_disk_megabytes }}
  144. {% else %}
  145. {{ ''|placeholder }}
  146. {% endif %}
  147. </td>
  148. </tr>
  149. </table>
  150. </div>
  151. <div class="card">
  152. <h2 class="card-header">
  153. {% trans "Services" %}
  154. {% if perms.ipam.add_service %}
  155. <div class="card-actions">
  156. <a href="{% url 'ipam:service_add' %}?parent_object_type={{ object|content_type_id }}&parent={{ object.pk }}" class="btn btn-ghost-primary btn-sm">
  157. <span class="mdi mdi-plus-thick" aria-hidden="true"></span> {% trans "Add a service" %}
  158. </a>
  159. </div>
  160. {% endif %}
  161. </h2>
  162. {% htmx_table 'ipam:service_list' virtual_machine_id=object.pk %}
  163. </div>
  164. {% include 'inc/panels/image_attachments.html' %}
  165. {% plugin_right_page object %}
  166. </div>
  167. </div>
  168. <div class="row">
  169. <div class="col col-md-12">
  170. <div class="card">
  171. <h2 class="card-header">
  172. {% trans "Virtual Disks" %}
  173. {% if perms.virtualization.add_virtualdisk %}
  174. <div class="card-actions">
  175. <a href="{% url 'virtualization:virtualdisk_add' %}?device={{ object.device.pk }}&virtual_machine={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-ghost-primary btn-sm">
  176. <span class="mdi mdi-plus-thick" aria-hidden="true"></span> {% trans "Add Virtual Disk" %}
  177. </a>
  178. </div>
  179. {% endif %}
  180. </h2>
  181. {% htmx_table 'virtualization:virtualdisk_list' virtual_machine_id=object.pk %}
  182. </div>
  183. </div>
  184. </div>
  185. <div class="row">
  186. <div class="col col-md-12">
  187. {% plugin_full_width_page object %}
  188. </div>
  189. </div>
  190. {% endblock %}