|
@@ -9,10 +9,10 @@
|
|
|
<div class="row noprint">
|
|
<div class="row noprint">
|
|
|
<div class="col-sm-8 col-md-9">
|
|
<div class="col-sm-8 col-md-9">
|
|
|
<ol class="breadcrumb">
|
|
<ol class="breadcrumb">
|
|
|
- {% if virtualmachine.cluster %}
|
|
|
|
|
- <li><a href="{{ virtualmachine.cluster.get_absolute_url }}">{{ virtualmachine.cluster }}</a></li>
|
|
|
|
|
|
|
+ {% if object.cluster %}
|
|
|
|
|
+ <li><a href="{{ object.cluster.get_absolute_url }}">{{ object.cluster }}</a></li>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
- <li>{{ virtualmachine }}</li>
|
|
|
|
|
|
|
+ <li>{{ object }}</li>
|
|
|
</ol>
|
|
</ol>
|
|
|
</div>
|
|
</div>
|
|
|
<div class="col-sm-4 col-md-3">
|
|
<div class="col-sm-4 col-md-3">
|
|
@@ -30,38 +30,38 @@
|
|
|
</div>
|
|
</div>
|
|
|
<div class="pull-right noprint">
|
|
<div class="pull-right noprint">
|
|
|
{% if perms.virtualization.add_vminterface %}
|
|
{% if perms.virtualization.add_vminterface %}
|
|
|
- <a href="{% url 'virtualization:vminterface_add' %}?virtual_machine={{ virtualmachine.pk }}&return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-primary">
|
|
|
|
|
|
|
+ <a href="{% url 'virtualization:vminterface_add' %}?virtual_machine={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary">
|
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add Interfaces
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add Interfaces
|
|
|
</a>
|
|
</a>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
- {% plugin_buttons virtualmachine %}
|
|
|
|
|
|
|
+ {% plugin_buttons object %}
|
|
|
{% if perms.virtualization.add_virtualmachine %}
|
|
{% if perms.virtualization.add_virtualmachine %}
|
|
|
- {% clone_button virtualmachine %}
|
|
|
|
|
|
|
+ {% clone_button object %}
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if perms.virtualization.change_virtualmachine %}
|
|
{% if perms.virtualization.change_virtualmachine %}
|
|
|
- {% edit_button virtualmachine %}
|
|
|
|
|
|
|
+ {% edit_button object %}
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if perms.virtualization.delete_virtualmachine %}
|
|
{% if perms.virtualization.delete_virtualmachine %}
|
|
|
- {% delete_button virtualmachine %}
|
|
|
|
|
|
|
+ {% delete_button object %}
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
</div>
|
|
</div>
|
|
|
- <h1>{% block title %}{{ virtualmachine }}{% endblock %}</h1>
|
|
|
|
|
- {% include 'inc/created_updated.html' with obj=virtualmachine %}
|
|
|
|
|
|
|
+ <h1>{% block title %}{{ object }}{% endblock %}</h1>
|
|
|
|
|
+ {% include 'inc/created_updated.html' with obj=object %}
|
|
|
<div class="pull-right noprint">
|
|
<div class="pull-right noprint">
|
|
|
- {% custom_links virtualmachine %}
|
|
|
|
|
|
|
+ {% custom_links object %}
|
|
|
</div>
|
|
</div>
|
|
|
<ul class="nav nav-tabs">
|
|
<ul class="nav nav-tabs">
|
|
|
<li role="presentation"{% if not active_tab %} class="active"{% endif %}>
|
|
<li role="presentation"{% if not active_tab %} class="active"{% endif %}>
|
|
|
- <a href="{{ virtualmachine.get_absolute_url }}">Virtual Machine</a>
|
|
|
|
|
|
|
+ <a href="{{ object.get_absolute_url }}">Virtual Machine</a>
|
|
|
</li>
|
|
</li>
|
|
|
{% if perms.extras.view_configcontext %}
|
|
{% if perms.extras.view_configcontext %}
|
|
|
<li role="presentation"{% if active_tab == 'config-context' %} class="active"{% endif %}>
|
|
<li role="presentation"{% if active_tab == 'config-context' %} class="active"{% endif %}>
|
|
|
- <a href="{% url 'virtualization:virtualmachine_configcontext' pk=virtualmachine.pk %}">Config Context</a>
|
|
|
|
|
|
|
+ <a href="{% url 'virtualization:virtualmachine_configcontext' pk=object.pk %}">Config Context</a>
|
|
|
</li>
|
|
</li>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if perms.extras.view_objectchange %}
|
|
{% if perms.extras.view_objectchange %}
|
|
|
<li role="presentation"{% if active_tab == 'changelog' %} class="active"{% endif %}>
|
|
<li role="presentation"{% if active_tab == 'changelog' %} class="active"{% endif %}>
|
|
|
- <a href="{% url 'virtualization:virtualmachine_changelog' pk=virtualmachine.pk %}">Change Log</a>
|
|
|
|
|
|
|
+ <a href="{% url 'virtualization:virtualmachine_changelog' pk=object.pk %}">Change Log</a>
|
|
|
</li>
|
|
</li>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
</ul>
|
|
</ul>
|
|
@@ -77,19 +77,19 @@
|
|
|
<table class="table table-hover panel-body attr-table">
|
|
<table class="table table-hover panel-body attr-table">
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Name</td>
|
|
<td>Name</td>
|
|
|
- <td>{{ virtualmachine }}</td>
|
|
|
|
|
|
|
+ <td>{{ object }}</td>
|
|
|
</tr>
|
|
</tr>
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Status</td>
|
|
<td>Status</td>
|
|
|
<td>
|
|
<td>
|
|
|
- <span class="label label-{{ virtualmachine.get_status_class }}">{{ virtualmachine.get_status_display }}</span>
|
|
|
|
|
|
|
+ <span class="label label-{{ object.get_status_class }}">{{ object.get_status_display }}</span>
|
|
|
</td>
|
|
</td>
|
|
|
</tr>
|
|
</tr>
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Role</td>
|
|
<td>Role</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.role %}
|
|
|
|
|
- <a href="{% url 'virtualization:virtualmachine_list' %}?role={{ virtualmachine.role.slug }}">{{ virtualmachine.role }}</a>
|
|
|
|
|
|
|
+ {% if object.role %}
|
|
|
|
|
+ <a href="{% url 'virtualization:virtualmachine_list' %}?role={{ object.role.slug }}">{{ object.role }}</a>
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">None</span>
|
|
<span class="text-muted">None</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
@@ -98,8 +98,8 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Platform</td>
|
|
<td>Platform</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.platform %}
|
|
|
|
|
- <a href="{% url 'virtualization:virtualmachine_list' %}?platform={{ virtualmachine.platform.slug }}">{{ virtualmachine.platform }}</a>
|
|
|
|
|
|
|
+ {% if object.platform %}
|
|
|
|
|
+ <a href="{% url 'virtualization:virtualmachine_list' %}?platform={{ object.platform.slug }}">{{ object.platform }}</a>
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">None</span>
|
|
<span class="text-muted">None</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
@@ -108,11 +108,11 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Tenant</td>
|
|
<td>Tenant</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.tenant %}
|
|
|
|
|
- {% if virtualmachine.tenant.group %}
|
|
|
|
|
- <a href="{{ virtualmachine.tenant.group.get_absolute_url }}">{{ virtualmachine.tenant.group }}</a> /
|
|
|
|
|
|
|
+ {% if object.tenant %}
|
|
|
|
|
+ {% if object.tenant.group %}
|
|
|
|
|
+ <a href="{{ object.tenant.group.get_absolute_url }}">{{ object.tenant.group }}</a> /
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
- <a href="{{ virtualmachine.tenant.get_absolute_url }}">{{ virtualmachine.tenant }}</a>
|
|
|
|
|
|
|
+ <a href="{{ object.tenant.get_absolute_url }}">{{ object.tenant }}</a>
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">None</span>
|
|
<span class="text-muted">None</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
@@ -121,12 +121,12 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Primary IPv4</td>
|
|
<td>Primary IPv4</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.primary_ip4 %}
|
|
|
|
|
- <a href="{% url 'ipam:ipaddress' pk=virtualmachine.primary_ip4.pk %}">{{ virtualmachine.primary_ip4.address.ip }}</a>
|
|
|
|
|
- {% if virtualmachine.primary_ip4.nat_inside %}
|
|
|
|
|
- <span>(NAT for {{ virtualmachine.primary_ip4.nat_inside.address.ip }})</span>
|
|
|
|
|
- {% elif virtualmachine.primary_ip4.nat_outside %}
|
|
|
|
|
- <span>(NAT: {{ virtualmachine.primary_ip4.nat_outside.address.ip }})</span>
|
|
|
|
|
|
|
+ {% if object.primary_ip4 %}
|
|
|
|
|
+ <a href="{% url 'ipam:ipaddress' pk=object.primary_ip4.pk %}">{{ object.primary_ip4.address.ip }}</a>
|
|
|
|
|
+ {% if object.primary_ip4.nat_inside %}
|
|
|
|
|
+ <span>(NAT for {{ object.primary_ip4.nat_inside.address.ip }})</span>
|
|
|
|
|
+ {% elif object.primary_ip4.nat_outside %}
|
|
|
|
|
+ <span>(NAT: {{ object.primary_ip4.nat_outside.address.ip }})</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">—</span>
|
|
<span class="text-muted">—</span>
|
|
@@ -136,12 +136,12 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Primary IPv6</td>
|
|
<td>Primary IPv6</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.primary_ip6 %}
|
|
|
|
|
- <a href="{% url 'ipam:ipaddress' pk=virtualmachine.primary_ip6.pk %}">{{ virtualmachine.primary_ip6.address.ip }}</a>
|
|
|
|
|
- {% if virtualmachine.primary_ip6.nat_inside %}
|
|
|
|
|
- <span>(NAT for {{ virtualmachine.primary_ip6.nat_inside.address.ip }})</span>
|
|
|
|
|
- {% elif virtualmachine.primary_ip6.nat_outside %}
|
|
|
|
|
- <span>(NAT: {{ virtualmachine.primary_ip6.nat_outside.address.ip }})</span>
|
|
|
|
|
|
|
+ {% if object.primary_ip6 %}
|
|
|
|
|
+ <a href="{% url 'ipam:ipaddress' pk=object.primary_ip6.pk %}">{{ object.primary_ip6.address.ip }}</a>
|
|
|
|
|
+ {% if object.primary_ip6.nat_inside %}
|
|
|
|
|
+ <span>(NAT for {{ object.primary_ip6.nat_inside.address.ip }})</span>
|
|
|
|
|
+ {% elif object.primary_ip6.nat_outside %}
|
|
|
|
|
+ <span>(NAT: {{ object.primary_ip6.nat_outside.address.ip }})</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">—</span>
|
|
<span class="text-muted">—</span>
|
|
@@ -150,21 +150,21 @@
|
|
|
</tr>
|
|
</tr>
|
|
|
</table>
|
|
</table>
|
|
|
</div>
|
|
</div>
|
|
|
- {% include 'inc/custom_fields_panel.html' with obj=virtualmachine %}
|
|
|
|
|
- {% include 'extras/inc/tags_panel.html' with tags=virtualmachine.tags.all url='virtualization:virtualmachine_list' %}
|
|
|
|
|
|
|
+ {% include 'inc/custom_fields_panel.html' with obj=object %}
|
|
|
|
|
+ {% include 'extras/inc/tags_panel.html' with tags=object.tags.all url='virtualization:virtualmachine_list' %}
|
|
|
<div class="panel panel-default">
|
|
<div class="panel panel-default">
|
|
|
<div class="panel-heading">
|
|
<div class="panel-heading">
|
|
|
<strong>Comments</strong>
|
|
<strong>Comments</strong>
|
|
|
</div>
|
|
</div>
|
|
|
<div class="panel-body rendered-markdown">
|
|
<div class="panel-body rendered-markdown">
|
|
|
- {% if virtualmachine.comments %}
|
|
|
|
|
- {{ virtualmachine.comments|render_markdown }}
|
|
|
|
|
|
|
+ {% if object.comments %}
|
|
|
|
|
+ {{ object.comments|render_markdown }}
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">None</span>
|
|
<span class="text-muted">None</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
</div>
|
|
</div>
|
|
|
</div>
|
|
</div>
|
|
|
- {% plugin_left_page virtualmachine %}
|
|
|
|
|
|
|
+ {% plugin_left_page object %}
|
|
|
</div>
|
|
</div>
|
|
|
<div class="col-md-6">
|
|
<div class="col-md-6">
|
|
|
<div class="panel panel-default">
|
|
<div class="panel panel-default">
|
|
@@ -175,15 +175,15 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Cluster</td>
|
|
<td>Cluster</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.cluster.group %}
|
|
|
|
|
- <a href="{{ virtualmachine.cluster.group.get_absolute_url }}">{{ virtualmachine.cluster.group }}</a> /
|
|
|
|
|
|
|
+ {% if object.cluster.group %}
|
|
|
|
|
+ <a href="{{ object.cluster.group.get_absolute_url }}">{{ object.cluster.group }}</a> /
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
- <a href="{{ virtualmachine.cluster.get_absolute_url }}">{{ virtualmachine.cluster }}</a>
|
|
|
|
|
|
|
+ <a href="{{ object.cluster.get_absolute_url }}">{{ object.cluster }}</a>
|
|
|
</td>
|
|
</td>
|
|
|
</tr>
|
|
</tr>
|
|
|
<tr>
|
|
<tr>
|
|
|
<td>Cluster Type</td>
|
|
<td>Cluster Type</td>
|
|
|
- <td>{{ virtualmachine.cluster.type }}</td>
|
|
|
|
|
|
|
+ <td>{{ object.cluster.type }}</td>
|
|
|
</tr>
|
|
</tr>
|
|
|
</table>
|
|
</table>
|
|
|
</div>
|
|
</div>
|
|
@@ -194,13 +194,13 @@
|
|
|
<table class="table table-hover panel-body attr-table">
|
|
<table class="table table-hover panel-body attr-table">
|
|
|
<tr>
|
|
<tr>
|
|
|
<td><i class="mdi mdi-gauge"></i> Virtual CPUs</td>
|
|
<td><i class="mdi mdi-gauge"></i> Virtual CPUs</td>
|
|
|
- <td>{{ virtualmachine.vcpus|placeholder }}</td>
|
|
|
|
|
|
|
+ <td>{{ object.vcpus|placeholder }}</td>
|
|
|
</tr>
|
|
</tr>
|
|
|
<tr>
|
|
<tr>
|
|
|
<td><i class="mdi mdi-chip"></i> Memory</td>
|
|
<td><i class="mdi mdi-chip"></i> Memory</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.memory %}
|
|
|
|
|
- {{ virtualmachine.memory }} MB
|
|
|
|
|
|
|
+ {% if object.memory %}
|
|
|
|
|
+ {{ object.memory }} MB
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">—</span>
|
|
<span class="text-muted">—</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
@@ -209,8 +209,8 @@
|
|
|
<tr>
|
|
<tr>
|
|
|
<td><i class="mdi mdi-harddisk"></i> Disk Space</td>
|
|
<td><i class="mdi mdi-harddisk"></i> Disk Space</td>
|
|
|
<td>
|
|
<td>
|
|
|
- {% if virtualmachine.disk %}
|
|
|
|
|
- {{ virtualmachine.disk }} GB
|
|
|
|
|
|
|
+ {% if object.disk %}
|
|
|
|
|
+ {{ object.disk }} GB
|
|
|
{% else %}
|
|
{% else %}
|
|
|
<span class="text-muted">—</span>
|
|
<span class="text-muted">—</span>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
@@ -226,7 +226,7 @@
|
|
|
{% include 'secrets/inc/assigned_secrets.html' %}
|
|
{% include 'secrets/inc/assigned_secrets.html' %}
|
|
|
{% if perms.secrets.add_secret %}
|
|
{% if perms.secrets.add_secret %}
|
|
|
<div class="panel-footer text-right noprint">
|
|
<div class="panel-footer text-right noprint">
|
|
|
- <a href="{% url 'secrets:secret_add' %}?virtual_machine={{ virtualmachine.pk }}&return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-xs btn-primary">
|
|
|
|
|
|
|
+ <a href="{% url 'secrets:secret_add' %}?virtual_machine={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-xs btn-primary">
|
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add secret
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add secret
|
|
|
</a>
|
|
</a>
|
|
|
</div>
|
|
</div>
|
|
@@ -250,25 +250,25 @@
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if perms.ipam.add_service %}
|
|
{% if perms.ipam.add_service %}
|
|
|
<div class="panel-footer text-right noprint">
|
|
<div class="panel-footer text-right noprint">
|
|
|
- <a href="{% url 'virtualization:virtualmachine_service_assign' virtualmachine=virtualmachine.pk %}" class="btn btn-xs btn-primary">
|
|
|
|
|
|
|
+ <a href="{% url 'virtualization:virtualmachine_service_assign' object=object.pk %}" class="btn btn-xs btn-primary">
|
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Assign service
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Assign service
|
|
|
</a>
|
|
</a>
|
|
|
</div>
|
|
</div>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
</div>
|
|
</div>
|
|
|
- {% plugin_right_page virtualmachine %}
|
|
|
|
|
|
|
+ {% plugin_right_page object %}
|
|
|
</div>
|
|
</div>
|
|
|
</div>
|
|
</div>
|
|
|
<div class="row">
|
|
<div class="row">
|
|
|
<div class="col-md-12">
|
|
<div class="col-md-12">
|
|
|
- {% plugin_full_width_page virtualmachine %}
|
|
|
|
|
|
|
+ {% plugin_full_width_page object %}
|
|
|
</div>
|
|
</div>
|
|
|
</div>
|
|
</div>
|
|
|
<div class="row">
|
|
<div class="row">
|
|
|
<div class="col-md-12">
|
|
<div class="col-md-12">
|
|
|
<form method="post">
|
|
<form method="post">
|
|
|
{% csrf_token %}
|
|
{% csrf_token %}
|
|
|
- <input type="hidden" name="virtual_machine" value="{{ virtualmachine.pk }}" />
|
|
|
|
|
|
|
+ <input type="hidden" name="virtual_machine" value="{{ object.pk }}" />
|
|
|
<div class="panel panel-default">
|
|
<div class="panel panel-default">
|
|
|
<div class="panel-heading">
|
|
<div class="panel-heading">
|
|
|
<strong>Interfaces</strong>
|
|
<strong>Interfaces</strong>
|
|
@@ -285,21 +285,21 @@
|
|
|
{% if perms.virtualization.add_vminterface or perms.virtualization.delete_vminterface %}
|
|
{% if perms.virtualization.add_vminterface or perms.virtualization.delete_vminterface %}
|
|
|
<div class="panel-footer noprint">
|
|
<div class="panel-footer noprint">
|
|
|
{% if interfaces and perms.virtualization.change_vminterface %}
|
|
{% if interfaces and perms.virtualization.change_vminterface %}
|
|
|
- <button type="submit" name="_rename" formaction="{% url 'virtualization:vminterface_bulk_rename' %}?return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-warning btn-xs">
|
|
|
|
|
|
|
+ <button type="submit" name="_rename" formaction="{% url 'virtualization:vminterface_bulk_rename' %}?return_url={{ object.get_absolute_url }}" class="btn btn-warning btn-xs">
|
|
|
<span class="mdi mdi-pencil" aria-hidden="true"></span> Rename
|
|
<span class="mdi mdi-pencil" aria-hidden="true"></span> Rename
|
|
|
</button>
|
|
</button>
|
|
|
- <button type="submit" name="_edit" formaction="{% url 'virtualization:vminterface_bulk_edit' %}?return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-warning btn-xs">
|
|
|
|
|
|
|
+ <button type="submit" name="_edit" formaction="{% url 'virtualization:vminterface_bulk_edit' %}?return_url={{ object.get_absolute_url }}" class="btn btn-warning btn-xs">
|
|
|
<span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
|
|
<span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
|
|
|
</button>
|
|
</button>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if interfaces and perms.virtualization.delete_vminterface %}
|
|
{% if interfaces and perms.virtualization.delete_vminterface %}
|
|
|
- <button type="submit" name="_delete" formaction="{% url 'virtualization:vminterface_bulk_delete' %}?return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-danger btn-xs">
|
|
|
|
|
|
|
+ <button type="submit" name="_delete" formaction="{% url 'virtualization:vminterface_bulk_delete' %}?return_url={{ object.get_absolute_url }}" class="btn btn-danger btn-xs">
|
|
|
<span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
|
|
<span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
|
|
|
</button>
|
|
</button>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
{% if perms.virtualization.add_vminterface %}
|
|
{% if perms.virtualization.add_vminterface %}
|
|
|
<div class="pull-right">
|
|
<div class="pull-right">
|
|
|
- <a href="{% url 'virtualization:vminterface_add' %}?virtual_machine={{ virtualmachine.pk }}&return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-primary btn-xs">
|
|
|
|
|
|
|
+ <a href="{% url 'virtualization:vminterface_add' %}?virtual_machine={{ object.pk }}&return_url={{ object.get_absolute_url }}" class="btn btn-primary btn-xs">
|
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add interfaces
|
|
<span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add interfaces
|
|
|
</a>
|
|
</a>
|
|
|
</div>
|
|
</div>
|