class ConsulService { constructor(ressourceURL, refresh) { this.ressourceURL = ressourceURL; this.fetchRessource(); this.serviceList = $("#service-list"); this.serviceFilter = $("#service-filter"); this.serviceFilter.keyup(this.filterService); this.instanceFilter = $("#instance-filter"); this.instanceFilter.keyup(this.filterInstances); this.refresh = parseInt(refresh); this.filterStatus = null; this.serviceFilterCounter = $("#service-counter"); this.serviceFilterCount = 0; this.showProxiesInList = false; var cs = this window.setTimeout(function(){ cs.showTags($('#showTagsInList:checked').length > 0); cs.showProxies($('#showProxiesInList:checked').length > 0); }, 100); } showTags(showTags) { var stylesheet = document.getElementById('css-states'); stylesheet.textContent = '.service-tags { display: ' + (showTags? 'block':'none') + ';}'; } showProxies(showProxies) { if (showProxies != this.showProxiesInList) { this.showProxiesInList = showProxies; console.log("showProxies:= "+this.showProxiesInList+", reloading list") this.reloadServiceList(); } } fetchRessource() { $.ajax({url: this.ressourceURL, cache: false, dataType: "json", sourceObject: this, success: function(result){ consulService.initRessource(result); }}); } initRessource(data) { this.data = data; this.reloadServiceList(); console.log('Data generated at: ' + data['generated_at']); var urlParam = new URL(location.href).searchParams.get('service'); if (urlParam === null) { var servicePrefix = '#service_' if (location.hash.startsWith(servicePrefix)) { urlParam = location.hash.substr(servicePrefix.length) } } if (urlParam) { var nodes = document.getElementById('service-list').childNodes; for(var i in nodes) { if($(nodes[i]).find(".service-name").html() == urlParam) { var selectedElement = $(nodes[i]) this.selectService(selectedElement); selectedElement.focus() break; } } } else { this.selectService(document.getElementById('service-list').firstElementChild); } if(this.refresh > 0) { setTimeout(this.fetchRessource, this.refresh * 1000); } } reloadServiceList() { if (!this.data || !this.data.services) { console.log("No data to display"); } this.serviceList.html(''); this.serviceFilterCount = 0; for (var serviceName in this.data.services) { var service = this.data.services[serviceName]; var serviceStatus = buildServiceStatus(service); var listItem = document.createElement('button'); listItem.setAttribute('type','button'); listItem.setAttribute('onfocus','consulService.onClickServiceName(this)'); listItem.setAttribute('onclick','consulService.onClickServiceName(this)'); listItem.setAttribute('value',serviceName); var listItemClass = 'list-group-item list-group-item-action'; var statuses = document.createElement('div'); statuses.setAttribute('class','statuses float-right'); if (!!serviceStatus['passing']) { statuses.appendChild(createBadge('badge-success passing', serviceStatus['passing'])); listItem.setAttribute('status', 'passing'); } if (!!serviceStatus['warning']) { statuses.appendChild(createBadge('badge-warning warning', serviceStatus['warning'])); listItem.setAttribute('status', 'warning'); } if (!!serviceStatus['critical']) { statuses.appendChild(createBadge('badge-danger critical', serviceStatus['critical'])); listItem.setAttribute('status', 'critical'); } statuses.appendChild(createBadge('badge-dark', (serviceStatus['total'] || 0))); listItem.appendChild(statuses); if (!!service['kind']) { var kind = document.createElement('div'); kind.setAttribute('class','kind float-right'); kind.appendChild(createBadge('badge-info kind', service['kind'])); listItem.appendChild(kind); listItemClass+= " kind-" + service['kind']; } listItem.setAttribute('class', listItemClass); var serviceNameItem = document.createElement('div'); serviceNameItem.setAttribute('class', 'service-name'); serviceNameItem.appendChild(document.createTextNode(serviceName)); listItem.appendChild(serviceNameItem); var serviceTagsItem = document.createElement('div'); serviceTagsItem.setAttribute('class', 'service-tags'); for (var i = 0; i < service.tags.length; i++) { serviceTagsItem.appendChild(createBadge('float-right badge-' + (i%2?'secondary':'info') , service.tags[i])); } listItem.appendChild(serviceTagsItem); this.serviceFilterCount += 1; this.serviceList.append(listItem); } this.serviceFilterCounter.html(this.serviceFilterCount); resizeWrapper('service-wrapper', 'service-list'); this.filterService(); } filterService() { var filter; var serviceVal = consulService.serviceFilter.val(); try { filter = new RegExp(serviceVal); } catch (e) { var safeReg = serviceVal.replace(/[-[\]{}()*+?.,\\^$|]/g, "\\$&") console.log("Failed to compile regexp for '" + serviceVal + "', using strict lookup due to: " + e); filter = new RegExp(safeReg); } consulService.serviceFilterCount = 0; var showProxiesInList = this.showProxiesInList; consulService.serviceList.children('button').each(function (){ var ui = $(this); if(serviceMatcher(this, filter, showProxiesInList)) { ui.removeClass('d-none'); ui.addClass('d-block'); consulService.serviceFilterCount += 1; consulService.serviceFilterCounter.html(consulService.serviceFilterCount); } else { ui.removeClass('d-block'); ui.addClass('d-none'); } }) } onClickServiceName(source) { this.selectService(source); this.updateURL($(source).find(".service-name").html()); } onClickFilter(source) { var status = $(source).attr('status'); this.filterStatus = (this.filterStatus == status) ? null : status; this.filterInstances(); } filterInstances() { updateFilterDisplay(consulService.filterStatus); var filter = new RegExp(consulService.instanceFilter.val()); $('#instances-list').children('div').each(function() { var status = $(this).attr('status'); if(instanceMatcher(this, filter)) { if (consulService.filterStatus == null) { $(this).removeClass('d-none'); $(this).addClass('d-block'); } else if (consulService.filterStatus == status) { $(this).removeClass('d-none'); $(this).addClass('d-block'); } else { $(this).removeClass('d-block'); $(this).addClass('d-none'); } } else { $(this).removeClass('d-block'); $(this).addClass('d-none'); } }) } updateURL(link) { var newUrl = window.location.protocol + "//" + window.location.host + window.location.pathname; if (link) { newUrl += '?service=' + link } window.history.pushState({},"",newUrl); } selectService(source) { if (this.selectedService) { $(this.selectedService).removeClass('active'); } var serviceName = $(source).find(".service-name").html() this.selectedService = source.closest( "button" ); $(this.selectedService).addClass('active'); this.displayService(this.data.services[serviceName]); } displayService(service) { $("#service-title").html(service['name']); $("#instances-list").html(""); var serviceStatus = buildServiceStatus(service); for (var key in service['instances']) { var instance = service['instances'][key]; var serviceHtml = document.createElement('div'); serviceHtml.setAttribute('class','list-group-item'); var state = nodeState(instance.checks); serviceHtml.appendChild(weightsGenerator(instance.weights, state)); serviceHtml.appendChild(serviceTitleGenerator(instance)); serviceHtml.appendChild(tagsGenerator(instance.tags)); serviceHtml.appendChild(serviceMetaGenerator(instance.sMeta)); serviceHtml.appendChild(connectGenerator(instance)) serviceHtml.appendChild(checksStatusGenerator(instance.checks)); serviceHtml.setAttribute('status', state); $("#instances-list").append(serviceHtml); } $('#service-progress-passing').css('width', (serviceStatus['passing'] || 0) / serviceStatus['total'] * 100 + '%') $('#service-progress-passing').html("passing (" + (serviceStatus['passing'] || 0) + ")") $('#service-progress-warning').css('width', (serviceStatus['warning'] || 0) / serviceStatus['total'] * 100 + '%') $('#service-progress-warning').html("warning (" + (serviceStatus['warning'] || 0) +")") $('#service-progress-critical').css('width', (serviceStatus['critical'] || 0) / serviceStatus['total'] * 100 + '%') $('#service-progress-critical').html("critical (" + (serviceStatus['critical'] || 0) + ")") resizeWrapper('instances-wrapper', 'instances-list'); $('#instances-list .list-group-item').resize(resizeAll); this.filterInstances(); $('pre code').each(function(i, block) { hljs.highlightBlock(block); }); } } $( window ).resize(resizeAll); resizeAll();