2
0
Эх сурвалжийг харах

Fixes #5358: Fix user table configuration for VM interfaces

Jeremy Stretch 5 жил өмнө
parent
commit
11fa348575

+ 8 - 0
docs/release-notes/version-2.10.md

@@ -1,5 +1,13 @@
 # NetBox v2.10
 
+## v2.10-beta2 (FUTURE)
+
+### Bug Fixes
+
+* [#5358](https://github.com/netbox-community/netbox/issues/5358) - Fix user table configuration for VM interfaces
+
+---
+
 ## v2.10-beta1 (2020-11-17)
 
 **NOTE:** This release completely removes support for embedded graphs.

+ 1 - 1
netbox/netbox/settings.py

@@ -16,7 +16,7 @@ from django.core.validators import URLValidator
 # Environment setup
 #
 
-VERSION = '2.10-beta1'
+VERSION = '2.10-beta2'
 
 # Hostname
 HOSTNAME = platform.node()

+ 42 - 40
netbox/templates/virtualization/virtualmachine.html

@@ -266,54 +266,56 @@
 </div>
 <div class="row">
     <div class="col-md-12">
-        {% if perms.virtualization.change_vminterface or perms.virtualization.delete_vminterface %}
-            <form method="post">
+        <form method="post">
             {% csrf_token %}
             <input type="hidden" name="virtual_machine" value="{{ virtualmachine.pk }}" />
-        {% endif %}
-        <div class="panel panel-default">
-            <div class="panel-heading">
-                <strong>Interfaces</strong>
-                <div class="col-md-2 pull-right noprint">
-                    <input class="form-control interface-filter" type="text" placeholder="Filter" title="RegEx-enabled" style="height: 23px" />
+            <div class="panel panel-default">
+                <div class="panel-heading">
+                    <strong>Interfaces</strong>
+                    <div class="pull-right noprint">
+                        {% if request.user.is_authenticated %}
+                            <button type="button" class="btn btn-default btn-xs" data-toggle="modal" data-target="#VirtualMachineVMInterfaceTable_config" title="Configure table"><i class="mdi mdi-cog"></i> Configure</button>
+                        {% endif %}
+                    </div>
+                    <div class="pull-right col-md-2 noprint">
+                        <input class="form-control interface-filter" type="text" placeholder="Filter" title="Filter text (regular expressions supported)" style="height: 23px" />
+                    </div>
                 </div>
+                {% include 'responsive_table.html' with table=vminterface_table %}
+                {% if perms.virtualization.add_vminterface or perms.virtualization.delete_vminterface %}
+                    <div class="panel-footer noprint">
+                        {% 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">
+                                <span class="mdi mdi-pencil" aria-hidden="true"></span> Rename
+                            </button>
+                            <button type="submit" name="_edit" formaction="{% url 'virtualization:vminterface_bulk_edit' %}?return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-warning btn-xs">
+                                <span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
+                            </button>
+                        {% endif %}
+                        {% 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">
+                                <span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
+                            </button>
+                        {% endif %}
+                        {% if perms.virtualization.add_vminterface %}
+                            <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">
+                                    <span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add interfaces
+                                </a>
+                            </div>
+                            <div class="clearfix"></div>
+                        {% endif %}
+                     </div>
+                {% endif %}
             </div>
-            {% include 'responsive_table.html' with table=vminterface_table %}
-            {% if perms.virtualization.add_vminterface or perms.virtualization.delete_vminterface %}
-                <div class="panel-footer noprint">
-                    {% 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">
-                            <span class="mdi mdi-pencil" aria-hidden="true"></span> Rename
-                        </button>
-                        <button type="submit" name="_edit" formaction="{% url 'virtualization:vminterface_bulk_edit' %}?return_url={{ virtualmachine.get_absolute_url }}" class="btn btn-warning btn-xs">
-                            <span class="mdi mdi-pencil" aria-hidden="true"></span> Edit
-                        </button>
-                    {% endif %}
-                    {% 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">
-                            <span class="mdi mdi-trash-can-outline" aria-hidden="true"></span> Delete
-                        </button>
-                    {% endif %}
-                    {% if perms.virtualization.add_vminterface %}
-                        <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">
-                                <span class="mdi mdi-plus-thick" aria-hidden="true"></span> Add interfaces
-                            </a>
-                        </div>
-                        <div class="clearfix"></div>
-                    {% endif %}
-                 </div>
-            {% endif %}
-        </div>
-        {% if perms.virtualization.delete_vminterface %}
-            </form>
-        {% endif %}
+        </form>
+        {% table_config_form vminterface_table %}
 	</div>
 </div>
 {% include 'secrets/inc/private_key_modal.html' %}
 {% endblock %}
 
 {% block javascript %}
-<script src="{% static 'js/interface_filtering.js' %}?v{{ settings.VERSION }}"></script>
-<script src="{% static 'js/secrets.js' %}?v{{ settings.VERSION }}"></script>
+  <script src="{% static 'js/interface_filtering.js' %}?v{{ settings.VERSION }}"></script>
+  <script src="{% static 'js/tableconfig.js' %}?v{{ settings.VERSION }}"></script>
 {% endblock %}

+ 5 - 3
netbox/virtualization/tables.py

@@ -161,8 +161,8 @@ class VMInterfaceTable(BaseInterfaceTable):
     class Meta(BaseTable.Meta):
         model = VMInterface
         fields = (
-            'pk', 'virtual_machine', 'name', 'enabled', 'mac_address', 'mtu', 'description', 'tags', 'ip_addresses',
-            'untagged_vlan', 'tagged_vlans',
+            'pk', 'virtual_machine', 'name', 'enabled', 'mac_address', 'mtu', 'mode', 'description', 'tags',
+            'ip_addresses', 'untagged_vlan', 'tagged_vlans',
         )
         default_columns = ('pk', 'virtual_machine', 'name', 'enabled', 'description')
 
@@ -180,4 +180,6 @@ class VirtualMachineVMInterfaceTable(VMInterfaceTable):
             'pk', 'name', 'enabled', 'mac_address', 'mtu', 'mode', 'description', 'tags', 'ip_addresses',
             'untagged_vlan', 'tagged_vlans', 'actions',
         )
-        default_columns = ('pk', 'name', 'enabled', 'mac_address', 'mtu', 'mode', 'description', 'actions')
+        default_columns = (
+            'pk', 'name', 'enabled', 'mac_address', 'mtu', 'mode', 'description', 'ip_addresses', 'actions',
+        )

+ 1 - 1
netbox/virtualization/views.py

@@ -246,7 +246,7 @@ class VirtualMachineView(generic.ObjectView):
         ).prefetch_related(
             Prefetch('ip_addresses', queryset=IPAddress.objects.restrict(request.user))
         )
-        vminterface_table = tables.VirtualMachineVMInterfaceTable(vminterfaces, orderable=False)
+        vminterface_table = tables.VirtualMachineVMInterfaceTable(vminterfaces, user=request.user, orderable=False)
         if request.user.has_perm('virtualization.change_vminterface') or \
                 request.user.has_perm('virtualization.delete_vminterface'):
             vminterface_table.columns.show('pk')