|
@@ -1,11 +1,23 @@
|
|
|
{% extends 'dcim/device/base.html' %}
|
|
{% extends 'dcim/device/base.html' %}
|
|
|
|
|
+{% load static %}
|
|
|
|
|
|
|
|
{% block title %}{{ object }} - LLDP Neighbors{% endblock %}
|
|
{% block title %}{{ object }} - LLDP Neighbors{% endblock %}
|
|
|
|
|
|
|
|
|
|
+{% block head %}
|
|
|
|
|
+<script type="text/javascript" src="{% static 'lldp.js' %}" onerror="window.location='{% url 'media_failure' %}?filename=lldp.js'"></script>
|
|
|
|
|
+{% endblock %}
|
|
|
|
|
+
|
|
|
{% block content %}
|
|
{% block content %}
|
|
|
- {% include 'inc/ajax_loader.html' %}
|
|
|
|
|
<div class="card">
|
|
<div class="card">
|
|
|
- <h5 class="card-header">LLDP Neighbors</h5>
|
|
|
|
|
|
|
+ <div class="card-overlay">
|
|
|
|
|
+ <div class="spinner-border" role="status">
|
|
|
|
|
+ <span class="visually-hidden">Loading...</span>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ <div class="card-header">
|
|
|
|
|
+ <h5 class="d-inline">LLDP Neighbors</h5>
|
|
|
|
|
+ {% comment %} <div id="spinner-container" class="float-end"></div> {% endcomment %}
|
|
|
|
|
+ </div>
|
|
|
<div class="card-body">
|
|
<div class="card-body">
|
|
|
<table class="table table-hover">
|
|
<table class="table table-hover">
|
|
|
<thead>
|
|
<thead>
|
|
@@ -20,7 +32,7 @@
|
|
|
<tbody>
|
|
<tbody>
|
|
|
{% for iface in interfaces %}
|
|
{% for iface in interfaces %}
|
|
|
<tr id="{{ iface.name }}">
|
|
<tr id="{{ iface.name }}">
|
|
|
- <td>{{ iface }}</td>
|
|
|
|
|
|
|
+ <td class="font-monospace">{{ iface }}</td>
|
|
|
{% if iface.connected_endpoint.device %}
|
|
{% if iface.connected_endpoint.device %}
|
|
|
<td class="configured_device" data="{{ iface.connected_endpoint.device }}" data-chassis="{{ iface.connected_endpoint.device.virtual_chassis.name }}">
|
|
<td class="configured_device" data="{{ iface.connected_endpoint.device }}" data-chassis="{{ iface.connected_endpoint.device.virtual_chassis.name }}">
|
|
|
<a href="{% url 'dcim:device' pk=iface.connected_endpoint.device.pk %}">{{ iface.connected_endpoint.device }}</a>
|
|
<a href="{% url 'dcim:device' pk=iface.connected_endpoint.device.pk %}">{{ iface.connected_endpoint.device }}</a>
|
|
@@ -36,7 +48,7 @@
|
|
|
</td>
|
|
</td>
|
|
|
{% endwith %}
|
|
{% endwith %}
|
|
|
{% else %}
|
|
{% else %}
|
|
|
- <td colspan="2">None</td>
|
|
|
|
|
|
|
+ <td class="text-muted" colspan="2">None</td>
|
|
|
{% endif %}
|
|
{% endif %}
|
|
|
<td class="device"></td>
|
|
<td class="device"></td>
|
|
|
<td class="interface"></td>
|
|
<td class="interface"></td>
|
|
@@ -48,53 +60,6 @@
|
|
|
</div>
|
|
</div>
|
|
|
{% endblock %}
|
|
{% endblock %}
|
|
|
|
|
|
|
|
-{% block javascript %}
|
|
|
|
|
-<script type="text/javascript">
|
|
|
|
|
-$(document).ready(function() {
|
|
|
|
|
- $.ajax({
|
|
|
|
|
- url: "{% url 'dcim-api:device-napalm' pk=object.pk %}?method=get_lldp_neighbors_detail",
|
|
|
|
|
- dataType: 'json',
|
|
|
|
|
- success: function(json) {
|
|
|
|
|
- $.each(json['get_lldp_neighbors_detail'], function(iface, neighbors) {
|
|
|
|
|
- var neighbor = neighbors[0];
|
|
|
|
|
- var row = $('#' + iface.split(".")[0].replace(/([\/:])/g, "\\$1"));
|
|
|
|
|
-
|
|
|
|
|
- // Glean configured hostnames/interfaces from the DOM
|
|
|
|
|
- var configured_device = row.children('td.configured_device').attr('data');
|
|
|
|
|
- var configured_chassis = row.children('td.configured_device').attr('data-chassis');
|
|
|
|
|
- var configured_interface = row.children('td.configured_interface').attr('data');
|
|
|
|
|
- var configured_interface_short = null;
|
|
|
|
|
- if (configured_interface) {
|
|
|
|
|
- // Match long-form IOS names against short ones (e.g. Gi0/1 == GigabitEthernet0/1).
|
|
|
|
|
- configured_interface_short = configured_interface.replace(/^([A-Z][a-z])[^0-9]*([0-9\/]+)$/, "$1$2");
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- // Clean up hostnames/interfaces learned via LLDP
|
|
|
|
|
- var neighbor_host = neighbor['remote_system_name'] || ""; // sanitize hostname if it's null to avoid breaking the split func
|
|
|
|
|
- var neighbor_port = neighbor['remote_port'] || ""; // sanitize port if it's null to avoid breaking the split func
|
|
|
|
|
- var lldp_device = neighbor_host.split(".")[0]; // Strip off any trailing domain name
|
|
|
|
|
- var lldp_interface = neighbor_port.split(".")[0]; // Strip off any trailing subinterface ID
|
|
|
|
|
-
|
|
|
|
|
- // Add LLDP neighbors to table
|
|
|
|
|
- row.children('td.device').html(lldp_device);
|
|
|
|
|
- row.children('td.interface').html(lldp_interface);
|
|
|
|
|
-
|
|
|
|
|
- // Apply colors to rows
|
|
|
|
|
- if (!configured_device && lldp_device) {
|
|
|
|
|
- row.addClass('info');
|
|
|
|
|
- } else if ((configured_device == lldp_device || configured_chassis == lldp_device) && configured_interface == lldp_interface) {
|
|
|
|
|
- row.addClass('success');
|
|
|
|
|
- } else if ((configured_device == lldp_device || configured_chassis == lldp_device) && configured_interface_short == lldp_interface) {
|
|
|
|
|
- row.addClass('success');
|
|
|
|
|
- } else {
|
|
|
|
|
- row.addClass('danger');
|
|
|
|
|
- }
|
|
|
|
|
- });
|
|
|
|
|
- },
|
|
|
|
|
- error: function(xhr) {
|
|
|
|
|
- alert(xhr.responseText);
|
|
|
|
|
- }
|
|
|
|
|
- });
|
|
|
|
|
-});
|
|
|
|
|
-</script>
|
|
|
|
|
|
|
+{% block data %}
|
|
|
|
|
+<span data-object-url="{% url 'dcim-api:device-napalm' pk=object.pk %}?method=get_lldp_neighbors_detail"></span>
|
|
|
{% endblock %}
|
|
{% endblock %}
|