diff --git a/ui/scripts/metrics.js b/ui/scripts/metrics.js index 02d436d3852..04d919cf146 100644 --- a/ui/scripts/metrics.js +++ b/ui/scripts/metrics.js @@ -26,13 +26,193 @@ }, refreshMetrics: function() { console.log("Refreshing metrics"); - }, - hideSearchBar: true + } } }; - // Cluster Metrics - cloudStack.sections.metrics.cluster = { + // Zones Metrics + cloudStack.sections.metrics.zones = { + title: 'label.metrics', + listView: { + id: 'metrics', + fields: { + name: { + label: 'label.name' + }, + state: { + label: 'label.state', + converter: function (str) { + // For localization + return str; + }, + indicator: { + 'Enabled': 'on', + 'Unmanaged': 'off', + 'Destroyed': 'off', + 'Disabled': 'off' + } + }, + clusters : { + label: 'label.clusters' + }, + cpuused: { + label: 'label.cpu.usage', + collapsible: true, + columns: { + cpuusedavg: { + label: 'label.cpu.used.avg', + }, + cpumaxdev: { + label: 'label.cpu.max.dev' + } + } + }, + cpuallocated: { + label: 'label.cpu.allocated', + collapsible: true, + columns: { + cpuallocated: { + label: 'label.allocated' + }, + cputotal: { + label: 'label.cpu.total.ghz' + } + } + }, + memused: { + label: 'label.memory.usage', + collapsible: true, + columns: { + memusedavg: { + label: 'label.memory.used.avg' + }, + memmaxdev: { + label: 'label.memory.max.dev' + } + } + }, + memallocated: { + label: 'label.memory.allocated', + collapsible: true, + columns: { + memallocated: { + label: 'label.allocated' + }, + memtotal: { + label: 'label.memory.total.gb' + } + } + } + }, + dataProvider: function(args) { + var data = {}; + listViewDataProvider(args, data); + $.ajax({ + url: createURL('listZones'), + data: data, + success: function(json) { + var items = json.listzonesresponse.zone; + $.each(items, function(idx, zone) { + items[idx].clusters = 0; + items[idx].cpuusedavg = 0.0; + items[idx].cpumaxdev = 0.0; + items[idx].cpuallocated = 0.0; + items[idx].maxCpuUsed = 0; + items[idx].memusedavg = 0.0; + items[idx].memmaxdev = 0.0; + items[idx].memallocated = 0.0; + items[idx].maxMemUsed = 0; + + $.ajax({ + url: createURL('listClusters'), + data: {zoneid: zone.id}, + success: function(json) { + items[idx].clusters += parseInt(json.listclustersresponse.count); + var maxCpuUsed = 0.0; + var maxMemUsed = 0; + $.each(json.listclustersresponse.cluster, function(i, cluster) { + if (cluster.hasOwnProperty('cpuused')) { + items[idx].cpuusedavg += cluster.cpuused; + if (cluster.cpuused > items[idx].maxCpuUsed) { + items[idx].maxCpuUsed = cluster.cpuused; + } + } + + if (cluster.hasOwnProperty('cpuallocated')) { + items[idx].cpuallocated += parseFloat(cluster.cpuallocated.replace('%', '')); + } + + if (cluster.hasOwnProperty('memused')) { + items[idx].memusedavg += parseFloat(cluster.memused); + if (cluster.memused > items[idx].maxMemUsed) { + items[idx].maxMemUsed = cluster.memused; + } + } + + if (cluster.hasOwnProperty('memoryallocated')) { + items[idx].memallocated += parseFloat(100.0 * parseFloat(cluster.memoryallocated)/parseFloat(cluster.memorytotal)); + } + + }); + + }, + async: false + }); + + $.ajax({ + url: createURL('listCapacity'), + data: {zoneid: zone.id}, + success: function(json) { + $.each(json.listcapacityresponse.capacity, function(i, capacity) { + // CPU + if (capacity.type == 1) { + items[idx].cputotal = (parseInt(capacity.capacitytotal)/(1000.0)).toFixed(2) + "Ghz"; + } + // Memory + if (capacity.type == 0) { + items[idx].memtotal = (parseInt(capacity.capacitytotal)/(1024.0*1024.0*1024.0)).toFixed(2) + "GB"; + } + }); + }, + async: false + }); + + items[idx].cpuusedavg = (100.0 * items[idx].cpuusedavg / items[idx].clusters); + items[idx].cpumaxdev = (items[idx].maxCpuUsed - items[idx].cpuusedavg); + items[idx].cpuallocated = (items[idx].cpuallocated / items[idx].clusters).toFixed(2) + "%"; + + items[idx].memusedavg = (100.0 * items[idx].memusedavg / items[idx].clusters); + items[idx].memmaxdev = (items[idx].maxMemUsed - items[idx].memusedavg); + items[idx].memallocated = (items[idx].memallocated / items[idx].clusters).toFixed(2) + "%"; + + items[idx].state = items[idx].allocationstate; + if (items[idx].managedstate == 'Unmanaged') { + items[idx].state = 'Unmanaged'; + } + + if (items[idx].managedstate == 'Managed' && items[idx].allocationstate == 'Enabled') { + items[idx].state = 'Enabled'; + } + + if (items[idx].managedstate == 'Managed' && items[idx].allocationstate == 'Disabled') { + items[idx].state = 'Disabled'; + } + }); + args.response.success({ + data: items + }); + } + }); + }, + refreshMetrics: function() { + console.log("Refreshing Cluster metrics"); + } + } + }; + + + // Clusters Metrics + cloudStack.sections.metrics.clusters = { title: 'label.metrics', listView: { id: 'metrics', @@ -207,12 +387,106 @@ }, refreshMetrics: function() { console.log("Refreshing Cluster metrics"); + } + } + }; + + // Hosts Metrics + cloudStack.sections.metrics.hosts = { + title: 'label.metrics', + listView: { + id: 'metrics', + fields: { + name: { + label: 'label.name' + }, + state: { + label: 'label.state', + converter: function (str) { + // For localization + return str; + }, + indicator: { + 'Enabled': 'on', + 'Unmanaged': 'off', + 'Destroyed': 'off', + 'Disabled': 'off' + } + }, + cpuused: { + label: 'label.cpu.usage', + collapsible: true, + columns: { + cores: { + label: 'label.num.cpu.cores', + }, + cputotal: { + label: 'label.cpu.total.ghz' + }, + cpuusedavg: { + label: 'label.cpu.used.avg', + }, + cpuallocated: { + label: 'label.allocated' + } + } + }, + memused: { + label: 'label.memory.usage', + collapsible: true, + columns: { + memtotal: { + label: 'label.memory.total.gb' + }, + memallocated: { + label: 'label.allocated' + }, + memusedavg: { + label: 'label.memory.used.avg' + } + } + }, + network: { + label: 'label.network', + collapsible: true, + columns: { + networkread: { + label: 'label.network.read' + }, + networkwrite: { + label: 'label.network.write' + } + } + } }, - hideSearchBar: true, - needsRefresh: true, - noSplit: true, - horizontalOverflow: true, - groupableColumns: true + dataProvider: function(args) { + var data = {}; + listViewDataProvider(args, data); + $.ajax({ + url: createURL('listHosts'), + data: data, + success: function(json) { + var items = json.listhostsresponse.host; + $.each(items, function(idx, host) { + items[idx].cores = 0; + items[idx].cputotal = 0; + items[idx].cpuusedavg = 0.0; + items[idx].cpuallocated = 0.0; + items[idx].memtotal = 0; + items[idx].memallocated = 0.0; + items[idx].memusedavg = 0.0; + items[idx].networkread = 0.0; + items[idx].networkwrite = 0.0; + }); + args.response.success({ + data: items + }); + } + }); + }, + refreshMetrics: function() { + console.log("Refreshing Cluster metrics"); + } } };