update minidashboard immediately after DOM is ready
[plstackapi.git] / planetstack / core / static / page_analytics.js
1 function getPageKind() {
2     var parentNodeTxt = $('#selectedMainNav').text();
3     parentNodeTxt = parentNodeTxt.replace("/\n","");
4     parentNodeTxt = parentNodeTxt.replace("ยป","");
5     parentNodeTxt = parentNodeTxt.trim();
6     if (parentNodeTxt.length > 0 && parentNodeTxt.charAt(parentNodeTxt.length-1)=='s') {
7             parentNodeTxt = parentNodeTxt.substring(0, parentNodeTxt.length-1);
8     }
9     return parentNodeTxt;
10 }
11
12 function getObjectQuery() {
13     var selectedNodeTxt = $('#currentOriginalNode').text();
14     selectedNodeTxt = selectedNodeTxt.trim();
15     selectedNodeTxt = selectedNodeTxt.split(' ').join('');//selectedNodeTxt.replace(" ", "")
16     parentNodeTxt = getPageKind();
17
18     if (parentNodeTxt == "Slice") {
19         return "&slice=" + selectedNodeTxt;
20     } else if (parentNodeTxt == "Site") {
21         return "&site=" + selectedNodeTxt;
22     } else if (parentNodeTxt == "Node") {
23         return "&node=" + selectedNodeTxt;
24     } else {
25         return "";
26     }
27 }
28
29
30 function setPageStatInt(labelName, valueName, legend, units, value) {
31     $(labelName).text(legend).show();
32     $(valueName).text(Math.round(value)+units).show();
33 }
34
35 function setPageStatFloat(labelName, valueName, legend, units, value, dp) {
36     $(labelName).text(legend).show();
37     $(valueName).text(Number(value).toFixed(dp)+units).show();
38 }
39
40 // ----------------------------------------------------------------------------
41 // node count and average cpu utilization
42
43 function updatePageAnalyticsData(summaryData) {
44     window.pageAnalyticsUrl = summaryData["dataSourceUrl"];
45     lastRow = summaryData.rows.length-1;
46
47     setPageStatInt(".nodesLabel", ".nodesValue", "Node Count", "", summaryData.rows[lastRow]["count_hostname"]);
48     setPageStatInt(".cpuLabel", ".cpuValue", "Avg Load", "%", summaryData.rows[lastRow]["avg_cpu"]);
49
50     //New miniDashboard
51     setPageStatInt("#miniDashNodeCountLabel", "#miniDashNodeCount", "Node Count", "", summaryData.rows[lastRow]["count_hostname"]);
52     setPageStatInt("#miniDashAvgLoadLabel", "#miniDashAvgLoad", "Avg Load", "%", summaryData.rows[lastRow]["avg_cpu"]);
53 }
54
55 function updatePageAnalytics() {
56     var url= '/analytics/bigquery/?avg=%cpu&count=%hostname&cached=default' + getObjectQuery();
57     console.log(url);
58     $.ajax({
59     url: url,
60     dataType : 'json',
61     type : 'GET',
62     success: function(newData)
63     {
64         updatePageAnalyticsData(newData);
65     }
66 });
67     setTimeout(updatePageAnalytics, 30000);
68 }
69
70 // ----------------------------------------------------------------------------
71 // bandwidth
72
73 function updatePageBandwidthData(summaryData) {
74     window.pageBandwidthUrl = summaryData["dataSourceUrl"];
75     lastRow = summaryData.rows.length-1;
76     setPageStatFloat(".bandwidthLabel", ".bandwidthValue", "Bandwidth", " Gbps", summaryData.rows[lastRow]["sum_computed_bytes_sent_div_elapsed"]*8.0/1024/1024/1024,2);
77     setPageStatFloat("#miniDashBandwidthLabel", "#miniDashBandwidth", "Bandwidth", " Gbps", summaryData.rows[lastRow]["sum_computed_bytes_sent_div_elapsed"]*8.0/1024/1024/1024,2);
78 }
79
80 function updatePageBandwidth() {
81     var url='/analytics/bigquery/?computed=%bytes_sent/%elapsed&cached=default' + getObjectQuery();
82
83     if (getPageKind()!="Slice") {
84         url = url + "&event=node_heartbeat";
85     }
86
87     $.ajax({
88     url : url,
89     dataType : 'json',
90     type : 'GET',
91     success: function(newData)
92     {
93         updatePageBandwidthData(newData);
94     }
95 });
96     setTimeout(updatePageBandwidth, 30000);
97 }
98
99 $( document ).ready(function() {
100     updatePageAnalytics();
101     updatePageBandwidth();
102 });\r
103