| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261 |
- {% load helpers %}
- <tr class="interface{% if not iface.enabled %} danger{% elif iface.cable.status %} success{% elif iface.cable %} info{% elif iface.is_virtual %} warning{% endif %}" id="interface_{{ iface.name }}">
- {# Checkbox #}
- {% if perms.dcim.change_interface or perms.dcim.delete_interface %}
- <td class="pk">
- <input name="pk" type="checkbox" value="{{ iface.pk }}" />
- </td>
- {% endif %}
- {# Icon and name #}
- <td class="text-nowrap">
- <span title="{{ iface.get_type_display }}">
- <i class="fa fa-fw fa-{% if iface.mgmt_only %}wrench{% elif iface.is_lag %}align-justify{% elif iface.is_virtual %}circle{% elif iface.is_wireless %}wifi{% else %}exchange{% endif %}"></i>
- <a href="{{ iface.get_absolute_url }}">{{ iface }}</a>
- </span>
- {% if iface.mac_address %}
- <br/><small class="text-muted">{{ iface.mac_address }}</small>
- {% endif %}
- </td>
- {# LAG #}
- <td>
- {% if iface.lag %}
- <a href="#interface_{{ iface.lag }}" class="label label-primary" title="{{ iface.lag.description }}">{{ iface.lag }}</a>
- {% endif %}
- </td>
- {# Description/tags #}
- <td>
- {% if iface.description %}
- {{ iface.description }}<br/>
- {% endif %}
- {% for tag in iface.tags.all %}
- {% tag tag %}
- {% empty %}
- {% if not iface.description %}—{% endif %}
- {% endfor %}
- </td>
- {# MTU #}
- <td>{{ iface.mtu|default:"—" }}</td>
- {# 802.1Q mode #}
- <td>{{ iface.get_mode_display|default:"—" }}</td>
- {# Cable #}
- <td class="text-nowrap">
- {% if iface.cable %}
- <a href="{{ iface.cable.get_absolute_url }}">{{ iface.cable }}</a>
- <a href="{% url 'dcim:interface_trace' pk=iface.pk %}" class="btn btn-primary btn-xs" title="Trace">
- <i class="fa fa-share-alt" aria-hidden="true"></i>
- </a>
- {% else %}
- <span class="text-muted">—</span>
- {% endif %}
- </td>
- {# Connection or type #}
- {% if iface.is_lag %}
- <td colspan="2" class="text-muted">
- LAG interface<br />
- <small class="text-muted">
- {% for member in iface.member_interfaces.all %}
- <a href="#interface_{{ member.name }}">{{ member }}</a>{% if not forloop.last %}, {% endif %}
- {% empty %}
- No members
- {% endfor %}
- </small>
- </td>
- {% elif iface.is_virtual %}
- <td colspan="2" class="text-muted">Virtual interface</td>
- {% elif iface.is_wireless %}
- <td colspan="2" class="text-muted">Wireless interface</td>
- {% elif iface.connected_endpoint.name %}
- {# Connected to an Interface #}
- <td>
- <a href="{% url 'dcim:device' pk=iface.connected_endpoint.device.pk %}">
- {{ iface.connected_endpoint.device }}
- </a>
- </td>
- <td>
- <a href="{% url 'dcim:interface' pk=iface.connected_endpoint.pk %}">
- <span title="{{ iface.connected_endpoint.get_type_display }}">
- {{ iface.connected_endpoint }}
- </span>
- </a>
- </td>
- {% elif iface.connected_endpoint.term_side %}
- {# Connected to a CircuitTermination #}
- {% with iface.connected_endpoint.get_peer_termination as peer_termination %}
- {% if peer_termination %}
- {% if peer_termination.connected_endpoint %}
- <td>
- <a href="{% url 'dcim:device' pk=peer_termination.connected_endpoint.device.pk %}">
- {{ peer_termination.connected_endpoint.device }}
- </a><br/>
- <small>via <i class="fa fa-fw fa-globe" title="Circuit"></i>
- <a href="{{ iface.connected_endpoint.circuit.get_absolute_url }}">
- {{ iface.connected_endpoint.circuit.provider }}
- {{ iface.connected_endpoint.circuit }}
- </a>
- </small>
- </td>
- <td>
- {{ peer_termination.connected_endpoint }}
- </td>
- {% else %}
- <td colspan="2">
- <a href="{% url 'dcim:site' slug=peer_termination.site.slug %}">
- {{ peer_termination.site }}
- </a>
- via <i class="fa fa-fw fa-globe" title="Circuit"></i>
- <a href="{{ iface.connected_endpoint.circuit.get_absolute_url }}">
- {{ iface.connected_endpoint.circuit.provider }}
- {{ iface.connected_endpoint.circuit }}
- </a>
- </td>
- {% endif %}
- {% else %}
- <td colspan="2">
- <i class="fa fa-fw fa-globe" title="Circuit"></i>
- <a href="{{ iface.connected_endpoint.circuit.get_absolute_url }}">
- {{ iface.connected_endpoint.circuit.provider }}
- {{ iface.connected_endpoint.circuit }}
- </a>
- </td>
- {% endif %}
- {% endwith %}
- {% else %}
- <td colspan="2">
- <span class="text-muted">Not connected</span>
- </td>
- {% endif %}
- {# Buttons #}
- <td class="text-right text-nowrap noprint">
- {% if show_interface_graphs %}
- {% if iface.connected_endpoint %}
- <button type="button" class="btn btn-primary btn-xs" data-toggle="modal" data-target="#graphs_modal" data-obj="{{ device.name }} - {{ iface.name }}" data-url="{% url 'dcim-api:interface-graphs' pk=iface.pk %}" title="Show graphs">
- <i class="glyphicon glyphicon-signal" aria-hidden="true"></i>
- </button>
- {% endif %}
- {% endif %}
- {% if perms.ipam.add_ipaddress %}
- <a href="{% url 'ipam:ipaddress_add' %}?interface={{ iface.pk }}&return_url={{ device.get_absolute_url }}" class="btn btn-xs btn-success" title="Add IP address">
- <i class="glyphicon glyphicon-plus" aria-hidden="true"></i>
- </a>
- {% endif %}
- {% if perms.dcim.change_interface %}
- {% if iface.cable %}
- {% include 'dcim/inc/cable_toggle_buttons.html' with cable=iface.cable %}
- {% elif iface.is_connectable and perms.dcim.add_cable %}
- <span class="dropdown">
- <button type="button" class="btn btn-success btn-xs dropdown-toggle" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
- <span class="glyphicon glyphicon-resize-small" aria-hidden="true"></span>
- </button>
- <ul class="dropdown-menu dropdown-menu-right">
- <li><a href="{% url 'dcim:interface_connect' termination_a_id=iface.pk termination_b_type='interface' %}?return_url={{ device.get_absolute_url }}">Interface</a></li>
- <li><a href="{% url 'dcim:interface_connect' termination_a_id=iface.pk termination_b_type='front-port' %}?return_url={{ device.get_absolute_url }}">Front Port</a></li>
- <li><a href="{% url 'dcim:interface_connect' termination_a_id=iface.pk termination_b_type='rear-port' %}?return_url={{ device.get_absolute_url }}">Rear Port</a></li>
- <li><a href="{% url 'dcim:interface_connect' termination_a_id=iface.pk termination_b_type='circuit-termination' %}?return_url={{ device.get_absolute_url }}">Circuit Termination</a></li>
- </ul>
- </span>
- {% endif %}
- <a href="{% if iface.device_id %}{% url 'dcim:interface_edit' pk=iface.pk %}{% else %}{% url 'virtualization:interface_edit' pk=iface.pk %}{% endif %}?return_url={{ device.get_absolute_url }}" class="btn btn-info btn-xs" title="Edit interface">
- <i class="glyphicon glyphicon-pencil" aria-hidden="true"></i>
- </a>
- {% endif %}
- {% if perms.dcim.delete_interface %}
- {% if iface.connection or iface.circuit_termination %}
- <button class="btn btn-danger btn-xs" disabled="disabled">
- <i class="glyphicon glyphicon-trash" aria-hidden="true"></i>
- </button>
- {% else %}
- <a href="{% if iface.device_id %}{% url 'dcim:interface_delete' pk=iface.pk %}{% else %}{% url 'virtualization:interface_delete' pk=iface.pk %}{% endif %}?return_url={{ device.get_absolute_url }}" class="btn btn-danger btn-xs" title="Delete interface">
- <i class="glyphicon glyphicon-trash" aria-hidden="true"></i>
- </a>
- {% endif %}
- {% endif %}
- </td>
- </tr>
- {% with ipaddresses=iface.ip_addresses.all %}
- {% if ipaddresses %}
- <tr class="ipaddresses">
- {# Placeholder #}
- {% if perms.dcim.change_interface or perms.dcim.delete_interface %}
- <td></td>
- {% endif %}
- {# IP addresses table #}
- <td colspan="9" style="padding: 0">
- <table class="table table-condensed interface-ips">
- <thead>
- <tr class="text-muted">
- <th class="col-md-3">IP Address</th>
- <th class="col-md-2">Status/Role</th>
- <th class="col-md-3">VRF</th>
- <th class="col-md-3">Description</th>
- <th class="col-md-1"></th>
- </tr>
- </thead>
- {% for ip in iface.ip_addresses.all %}
- <tr>
- {# IP address #}
- <td>
- <a href="{% url 'ipam:ipaddress' pk=ip.pk %}">{{ ip }}</a>
- </td>
- {# Primary/status/role #}
- <td>
- {% if device.primary_ip4 == ip or device.primary_ip6 == ip %}
- <span class="label label-success">Primary</span>
- {% endif %}
- <span class="label label-{{ ip.get_status_class }}">{{ ip.get_status_display }}</span>
- {% if ip.role %}
- <span class="label label-{{ ip.get_role_class }}">{{ ip.get_role_display }}</span>
- {% endif %}
- </td>
- {# VRF #}
- <td>
- {% if ip.vrf %}
- <a href="{% url 'ipam:vrf' pk=ip.vrf.pk %}" title="{{ ip.vrf.rd }}">{{ ip.vrf.name }}</a>
- {% else %}
- <span class="text-muted">Global</span>
- {% endif %}
- </td>
- {# Description #}
- <td>
- {% if ip.description %}
- {{ ip.description }}
- {% else %}
- <span class="text-muted">—</span>
- {% endif %}
- </td>
- {# Buttons #}
- <td class="text-right text-nowrap noprint">
- {% if perms.ipam.change_ipaddress %}
- <a href="{% url 'ipam:ipaddress_edit' pk=ip.pk %}?return_url={{ device.get_absolute_url }}" class="btn btn-info btn-xs">
- <i class="glyphicon glyphicon-pencil" aria-hidden="true" title="Edit IP address"></i>
- </a>
- {% endif %}
- {% if perms.ipam.delete_ipaddress %}
- <a href="{% url 'ipam:ipaddress_delete' pk=ip.pk %}?return_url={{ device.get_absolute_url }}" class="btn btn-danger btn-xs">
- <i class="glyphicon glyphicon-trash" aria-hidden="true" title="Delete IP address"></i>
- </a>
- {% endif %}
- </td>
- </tr>
- {% endfor %}
- </table>
- </td>
- </tr>
- {% endif %}
- {% endwith %}
|