blob: 129eaaf809b3d877abf37f4366dd8f592209bcb2 [file] [log] [blame]
Boyoung Jeong1cca5e82018-08-01 21:00:08 +09001/*
2 * Copyright 2016-present Open Networking Foundation
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17/*
18 ONOS GUI -- Openstack Telemetry View Module
19 */
20(function () {
21 'use strict';
22
23 // injected references
24 var $log, $scope, $location, ks, fs, cbs, ns;
25
26 var hasFlow;
27
28 var gFlowId;
29 var gPeriod;
30
31 var labels = new Array(1);
32 var data = new Array(2);
33 for (var i = 0; i < 2; i++) {
34 data[i] = new Array(1);
35 }
36
37 var max;
38
39 function ceil(num) {
40 if (isNaN(num)) {
41 return 0;
42 }
43 var pre = num.toString().length - 1
44 var pow = Math.pow(10, pre);
45 return (Math.ceil(num / pow)) * pow;
46 }
47
48 function maxInArray(array) {
49 var merged = [].concat.apply([], array);
50 return Math.max.apply(null, merged);
51 }
52
53 angular.module('ovOpenstacktelemetry', ["chart.js"])
54 .controller('OvOpenstacktelemetryCtrl',
55 ['$log', '$scope', '$location', 'FnService', 'ChartBuilderService', 'NavService',
56
57 function (_$log_, _$scope_, _$location_, _fs_, _cbs_, _ns_) {
58 var params;
59 $log = _$log_;
60 $scope = _$scope_;
61 $location = _$location_;
62 fs = _fs_;
63 cbs = _cbs_;
64 ns = _ns_;
65
66 params = $location.search();
67
68 if (params.hasOwnProperty('flowOpt')) {
69 $scope.flowOpt = params['flowOpt'];
70 hasFlow = true;
71 } else if (params.hasOwnProperty('periodOpt')) {
72 $scope.periodOpt = params['periodOpt'];
73 hasFlow = true;
74 } else {
75 hasFlow = false;
76 }
77
78 cbs.buildChart({
79 scope: $scope,
80 tag: 'openstacktelemetry',
81 query: params
82 });
83
84 $scope.$watch('chartData', function () {
85 if (!fs.isEmptyObject($scope.chartData)) {
86 $scope.showLoader = false;
87 var length = $scope.chartData.length;
88 labels = new Array(length);
89 for (var i = 0; i < 2; i++) {
90 data[i] = new Array(length);
91 }
92
93 $scope.chartData.forEach(function (cm, idx) {
94 data[0][idx] = (cm.curr_acc_packet - cm.prev_acc_packet);
95 data[1][idx] = (cm.curr_acc_byte - cm.prev_acc_byte);
96
97 labels[idx] = cm.label;
98 });
99 }
100
101 max = maxInArray(data)
102 $scope.labels = labels;
103 $scope.data = data;
104 $scope.options = {
105 scaleOverride : true,
106 scaleSteps : 10,
107 scaleStepWidth : ceil(max) / 10,
108 scaleStartValue : 0,
109 scaleFontSize : 16
110 };
111 $scope.onClick = function (points, evt) {
112 var label = labels[points[0]._index];
113 if (label) {
114 ns.navTo('openstacktelemetry', { flowOpt: label });
115 $log.log(label);
116 }
117 };
118
119 if (!fs.isEmptyObject($scope.annots)) {
120 $scope.flowIds = JSON.parse($scope.annots.flowIds);
121 $scope.periodOptions = JSON.parse($scope.annots.periodOptions);
122 }
123
124 $scope.onChange = function (flowId) {
125 gFlowId = flowId;
126 ns.navTo('openstacktelemetry', { periodOpt: gPeriod , flowOpt: flowId });
127 };
128
129 $scope.onPeriodChange = function (period) {
130 gPeriod = period;
131 ns.navTo('openstacktelemetry', { periodOpt: period , flowOpt: gFlowId });
132 };
133 });
134
135 $scope.series = ['Current Packet', 'Current Byte'];
136
137 $scope.labels = labels;
138 $scope.data = data;
139
140 $scope.chartColors = [
141 '#286090',
142 '#F7464A',
143 '#46BFBD',
144 '#FDB45C',
145 '#97BBCD',
146 '#4D5360',
147 '#8c4f9f'
148 ];
149 Chart.defaults.global.colours = $scope.chartColors;
150
151 $scope.showLoader = true;
152
153 $log.log('OvOpenstacktelemetryCtrl has been created');
154 }]);
155
156}());