diff --git a/src/ServicePulse.Host/ServicePulse.Host.csproj b/src/ServicePulse.Host/ServicePulse.Host.csproj index ae898d458..1cb99e9d6 100644 --- a/src/ServicePulse.Host/ServicePulse.Host.csproj +++ b/src/ServicePulse.Host/ServicePulse.Host.csproj @@ -85,7 +85,10 @@ + + + @@ -111,6 +114,7 @@ + diff --git a/src/ServicePulse.Host/app/css/particular.css b/src/ServicePulse.Host/app/css/particular.css index 30a7c4890..62a5b27b8 100644 --- a/src/ServicePulse.Host/app/css/particular.css +++ b/src/ServicePulse.Host/app/css/particular.css @@ -452,12 +452,12 @@ h3 { text-align: center; } - .summary-item .badge, .summary-item .label { - font-size: 18px; - margin-left: 12px; - position: absolute; - top: 2px; - } +.summary-item .badge, .summary-item .label { + font-size: 18px; + margin-left: 12px; + position: absolute; + top: 2px; +} .summary-info, .summary-info > .fa, a.summary-info:hover { color: #777f7f; @@ -567,6 +567,10 @@ h1 { margin: 0 0 32px; } +h1 .warning { + font-size: 26px; +} + p.metadata { margin-bottom: 6px; } @@ -1734,12 +1738,26 @@ hr.top-separator { } .monitoring-no-data { - margin: 60px 0 120px; + margin: 60px auto 120px; + max-width: 520px; + line-height: 26px; +} + +.monitoring-no-data h1 { + font-size: 30px; } .monitoring-no-data p { font-size: 16px; margin-bottom: 20px; + margin-top: -18px; +} + +.monitoring-no-data ul { + padding-left: 0; + text-align: left; + font-size: 16px; + margin-bottom: 30px; } .monitoring-no-data .btn { @@ -1776,7 +1794,7 @@ hr.top-separator { font-size: 12px; text-transform: uppercase; color: #181919; - display: inline-block; + text-transform: initial; } .table-head-row span.table-header-unit { @@ -1796,10 +1814,9 @@ p.col-sort-active { margin-top: 15px; } - .endpoint-name a:hover { - text-decoration: none !important; - margin-top: 20px; - } +.endpoint-name a:hover { + text-decoration: none !important; +} .tooltip-inner { width: 200px; @@ -1808,6 +1825,7 @@ p.col-sort-active { .endpoint-status { display: inline-block; position: absolute; + top: 1px; margin-left: 7px; } @@ -1821,7 +1839,6 @@ h1 .endpoint-status i.fa-envelope, .endpoint-status i.fa-exclamation-triangle { } .endpoint-status i.fa-envelope { - position: relative; color: #777f7f; } @@ -1829,15 +1846,9 @@ h1 .endpoint-status i.fa-envelope, .endpoint-status i.fa-exclamation-triangle { color: #23527c; } -.endpoint-status i.fa-exclamation-triangle { - position: relative; - top: 1px; - margin-right: 6px; -} - .endpoint-status .badge { position: relative; - top: 6px; + top: 8px; font-size: 10px; margin-right: 0; left: -10px; @@ -1845,10 +1856,41 @@ h1 .endpoint-status i.fa-envelope, .endpoint-status i.fa-exclamation-triangle { .endpoint-status i.fa-envelope, .endpoint-name i.fa-exclamation-triangle { font-size: 20px; - color: #CE4844; margin-left: 6px; } +.endpoint-status a { + position: relative; + top: -8px; + padding-left: 0; +} + +.endpoint-status a:hover { + text-decoration: none; +} + +.monitoring-head .endpoint-status { + top: 0; +} + +.monitoring-head .endpoint-status a { + top: 0; +} + +.monitoring-head i.fa.fa-envelope { + font-size: 26px; + position: relative; + top: -4px; + left: 1px; +} + +.monitoring-head .endpoint-status .badge { + position: relative; + top: 4px; + left: -12px; + font-size: 10px; +} + .endpoint-status .badge { position: relative; top: 2px; @@ -1933,6 +1975,10 @@ h1 .endpoint-status i.fa-envelope, .endpoint-status i.fa-exclamation-triangle { font-size: 22px; } +.metric-digest-value div { + display: inline-block; +} + .metric-digest-value-suffix { font-weight: normal; font-size: 14px; @@ -1948,7 +1994,7 @@ h1 .endpoint-status i.fa-envelope, .endpoint-status i.fa-exclamation-triangle { margin-right: 24px; color: #8C8C8C; font-weight: normal; - font-size: 14px; + font-size: 12px; float: left; } @@ -2006,16 +2052,71 @@ i.fa-exclamation-triangle { display: inline-block; } -.back-nav -{ - position: absolute; - top: 80px; +.back-nav { text-transform: uppercase; margin-bottom: 6px; font-size: 13px; } -.monitoring-head .back-nav { - position: absolute; - top: 80px; +.pa-endpoint-lost.endpoints-overview { + background-image: url('../../img/endpoint-lost.svg'); + background-position: center; + background-repeat: no-repeat; +} + +.pa-monitoring-lost.endpoints-overview { + background-image: url('../../img/monitoring-lost.svg'); + background-position: center; + background-repeat: no-repeat; +} + +.pa-endpoint-lost.endpoint-details { + background-image: url('../../../img/endpoint-lost.svg'); + background-position: center; + background-repeat: no-repeat; +} + +.pa-monitoring-lost.endpoint-details { + background-image: url('../../../img/monitoring-lost.svg'); + background-position: center; + background-repeat: no-repeat; +} + +.monitoring-head .endpoint-status .pa-endpoint-lost.endpoint-details, .monitoring-head .endpoint-status .pa-monitoring-lost.endpoint-details { + width: 23px; + height: 23px; +} + +.endpoint-status .pa-endpoint-lost.endpoint-details, .endpoint-status .pa-monitoring-lost.endpoint-details, .endpoint-status .pa-endpoint-lost.endpoints-overview, .endpoint-status .pa-monitoring-lost.endpoints-overview { + width: 20px; + height: 20px; + left: 6px; + position: relative; +} + +.endpoint-message-types .endpoint-status { + margin-top: -1px; +} + +i.fa.pa-endpoint-lost.endpoints-overview, i.fa.pa-monitoring-lost.endpoints-overview { + position: relative; + top: 8px; + margin-right: 4px; +} + +.endpoint-name .lead { + text-overflow: ellipsis; + overflow: hidden; + white-space: nowrap; +} + +@media (min-width: 1200px) { + .col-lg-max-8 { + max-width: 66%; + float: left; + } + .col-lg-max-9 { + max-width: 76%; + float: left; + } } \ No newline at end of file diff --git a/src/ServicePulse.Host/app/img/endpoint-lost.svg b/src/ServicePulse.Host/app/img/endpoint-lost.svg new file mode 100644 index 000000000..56f07a296 --- /dev/null +++ b/src/ServicePulse.Host/app/img/endpoint-lost.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/ServicePulse.Host/app/img/monitoring-lost.svg b/src/ServicePulse.Host/app/img/monitoring-lost.svg new file mode 100644 index 000000000..1e8181b0c --- /dev/null +++ b/src/ServicePulse.Host/app/img/monitoring-lost.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/src/ServicePulse.Host/app/js/services/service.toast.js b/src/ServicePulse.Host/app/js/services/service.toast.js index 15b194487..469606bc0 100644 --- a/src/ServicePulse.Host/app/js/services/service.toast.js +++ b/src/ServicePulse.Host/app/js/services/service.toast.js @@ -18,12 +18,18 @@ this.showToast(text, 'info', title || 'Info', sticky); } - this.showError = function (text) { - this.showToast(text, 'error', 'Error', true); + this.showError = function (text, sticky) { + if (sticky === undefined) { + sticky = true; + } + this.showToast(text, 'error', 'Error', sticky); } - this.showWarning = function (text) { - this.showToast(text, 'warning', 'Warning', true); + this.showWarning = function (text, sticky) { + if (sticky === undefined) { + sticky = true; + } + this.showToast(text, 'warning', 'Warning', sticky); } } diff --git a/src/ServicePulse.Host/app/js/services/services.module.js b/src/ServicePulse.Host/app/js/services/services.module.js index 1a2527fea..3740b8e92 100644 --- a/src/ServicePulse.Host/app/js/services/services.module.js +++ b/src/ServicePulse.Host/app/js/services/services.module.js @@ -5,6 +5,7 @@ 'services.streamService', 'services.serviceControlService', 'services.monitoringService', + 'services.connectivityNotifier', 'services.platformUpdateService', 'services.semverService', 'services.notifications', diff --git a/src/ServicePulse.Host/app/js/views/failed_messages/view.html b/src/ServicePulse.Host/app/js/views/failed_messages/view.html index 7077dbfcd..d4b842ed3 100644 --- a/src/ServicePulse.Host/app/js/views/failed_messages/view.html +++ b/src/ServicePulse.Host/app/js/views/failed_messages/view.html @@ -13,10 +13,10 @@ Failed message groups list
All failed messages ({{vm.failedMessages.length}} / {{vm.selectedExceptionGroup.count}} | number)
-

+

{{vm.selectedExceptionGroup.parentTitle}} - {{vm.selectedExceptionGroup.title}} -

+

{{vm.selectedExceptionGroup.count | number}} messages in group

diff --git a/src/ServicePulse.Host/app/modules/monitoring/dist/monitoring.dist.js b/src/ServicePulse.Host/app/modules/monitoring/dist/monitoring.dist.js index 72277f600..789222d70 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/dist/monitoring.dist.js +++ b/src/ServicePulse.Host/app/modules/monitoring/dist/monitoring.dist.js @@ -60,118 +60,151 @@ /******/ __webpack_require__.p = ""; /******/ /******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 4); +/******/ return __webpack_require__(__webpack_require__.s = 54); /******/ }) /************************************************************************/ -/******/ ([ -/* 0 */ +/******/ ({ + +/***/ 5: +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\n;(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('monitored_endpoints').constant('largeGraphsMinimumYAxis', {\n 'queueLength': 10,\n 'throughputRetries': 10,\n 'processingCritical': 10\n }).constant('smallGraphsMinimumYAxis', {\n 'queueLength': 10,\n 'throughput': 10,\n 'retries': 10,\n 'processingTime': 10,\n 'criticalTime': 10\n });\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2NvbnN0YW50LmRpYWdyYW1zLmpzPzhjMjkiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsImNvbnN0YW50Il0sIm1hcHBpbmdzIjoiOztBQUFBLENBQUcsV0FBVUEsTUFBVixFQUFrQkMsT0FBbEIsRUFBMkJDLFNBQTNCLEVBQXNDO0FBQ3JDOztBQUVBRCxZQUFRRSxNQUFSLENBQWUscUJBQWYsRUFDS0MsUUFETCxDQUNjLHlCQURkLEVBQ3lDO0FBQzdCLHVCQUFlLEVBRGM7QUFFN0IsNkJBQXFCLEVBRlE7QUFHN0IsOEJBQXNCO0FBSE8sS0FEekMsRUFNS0EsUUFOTCxDQU1jLHlCQU5kLEVBTXlDO0FBQ2pDLHVCQUFlLEVBRGtCO0FBRWpDLHNCQUFjLEVBRm1CO0FBR2pDLG1CQUFXLEVBSHNCO0FBSWpDLDBCQUFrQixFQUplO0FBS2pDLHdCQUFnQjtBQUxpQixLQU56QztBQWNILENBakJFLEVBaUJESixNQWpCQyxFQWlCT0EsT0FBT0MsT0FqQmQsQ0FBRCIsImZpbGUiOiI1LmpzIiwic291cmNlc0NvbnRlbnQiOlsiOyAoZnVuY3Rpb24gKHdpbmRvdywgYW5ndWxhciwgdW5kZWZpbmVkKSB7XHJcbiAgICAndXNlIHN0cmljdCc7XHJcblxyXG4gICAgYW5ndWxhci5tb2R1bGUoJ21vbml0b3JlZF9lbmRwb2ludHMnKVxyXG4gICAgICAgIC5jb25zdGFudCgnbGFyZ2VHcmFwaHNNaW5pbXVtWUF4aXMnLCB7XHJcbiAgICAgICAgICAgICAgICAncXVldWVMZW5ndGgnOiAxMCxcclxuICAgICAgICAgICAgICAgICd0aHJvdWdocHV0UmV0cmllcyc6IDEwLFxyXG4gICAgICAgICAgICAgICAgJ3Byb2Nlc3NpbmdDcml0aWNhbCc6IDEwLFxyXG4gICAgICAgICAgICB9KVxyXG4gICAgICAgIC5jb25zdGFudCgnc21hbGxHcmFwaHNNaW5pbXVtWUF4aXMnLCB7XHJcbiAgICAgICAgICAgICdxdWV1ZUxlbmd0aCc6IDEwLFxyXG4gICAgICAgICAgICAndGhyb3VnaHB1dCc6IDEwLFxyXG4gICAgICAgICAgICAncmV0cmllcyc6IDEwLFxyXG4gICAgICAgICAgICAncHJvY2Vzc2luZ1RpbWUnOiAxMCxcclxuICAgICAgICAgICAgJ2NyaXRpY2FsVGltZSc6IDEwLFxyXG4gICAgICAgIH0pO1xyXG5cclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XHJcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvY29uc3RhbnQuZGlhZ3JhbXMuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5\n"); + +/***/ }), + +/***/ 54: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graph', []).directive('graph', function () {\n return {\n restrict: 'E',\n scope: {\n plotData: '&',\n formatter: '&'\n },\n template: '',\n link: function link(scope, element, attrs) {\n scope.plotData = scope.plotData() || { points: [], average: 0 };\n\n var svg = element.find('svg')[0];\n\n var width = svg.clientWidth;\n var height = svg.clientHeight;\n\n //HINT: This is workaround for Firefox\n if (width === 0) {\n var box = svg.getBoundingClientRect();\n\n width = box.right - box.left;\n height = box.bottom - box.top;\n }\n\n var verticalMargin = 6;\n var horizontalMargin = 2;\n\n var points = scope.plotData.points;\n var average = scope.plotData.average || 0;\n var max = points && points.length ? Math.max(average * 1.5, d3.max(points)) : 1;\n var numberOfPoints = points && points.length ? points.length : 2;\n\n var scaleY = d3.scaleLinear().domain([0, max]).range([height - verticalMargin, verticalMargin]);\n\n var scaleX = d3.scaleLinear().domain([0, numberOfPoints - 1]).range([horizontalMargin, width - horizontalMargin]);\n\n var area = d3.area().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).y1(function (d) {\n return scaleY(0);\n }).curve(d3.curveLinear);\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var chart = d3.select(svg).attr('width', width).attr('height', height);\n\n chart.append('rect').attr('width', width - 2 * horizontalMargin).attr('height', height - 2 * verticalMargin).attr('transform', 'translate(' + horizontalMargin + ',' + verticalMargin + ')').attr('fill', '#F2F6F7');\n\n if (points) {\n chart.append('path').datum(points).attr('d', area).attr('class', 'graph-data-fill');\n\n chart.append('path').datum(points).attr('d', line).attr('class', 'graph-data-line');\n }\n\n chart.append('path').datum(Array(numberOfPoints).fill(average)).attr('d', line).attr('class', 'graph-avg-line');\n }\n };\n });\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/directives/ui.particular.graph.js?c1b8"],"names":["window","angular","undefined","module","directive","restrict","scope","plotData","formatter","template","link","element","attrs","points","average","svg","find","width","clientWidth","height","clientHeight","box","getBoundingClientRect","right","left","bottom","top","verticalMargin","horizontalMargin","max","length","Math","d3","numberOfPoints","scaleY","scaleLinear","domain","range","scaleX","area","x","d","i","y","y1","curve","curveLinear","line","chart","select","attr","append","datum","Array","fill"],"mappings":"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","file":"0.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    angular.module('ui.particular.graph', [])\r\n        .directive('graph',\r\n            function() {\r\n                return {\r\n                    restrict: 'E',\r\n                    scope: {\r\n                        plotData: '&',\r\n                        formatter: '&'\r\n                    },\r\n                    template: '<svg></svg>',\r\n                    link: function link(scope, element, attrs) {\r\n                        scope.plotData = scope.plotData() || { points: [], average: 0 };\r\n\r\n                        var svg = element.find('svg')[0];\r\n\r\n                        var width = svg.clientWidth;\r\n                        var height = svg.clientHeight;\r\n\r\n                        //HINT: This is workaround for Firefox\r\n                        if (width === 0) {\r\n                            var box = svg.getBoundingClientRect();\r\n\r\n                            width = box.right - box.left;\r\n                            height = box.bottom - box.top;\r\n                        }\r\n\r\n                        var verticalMargin = 6;\r\n                        var horizontalMargin = 2;\r\n\r\n                        var points = scope.plotData.points;\r\n                        var average = scope.plotData.average || 0;\r\n                        var max = points && points.length ? Math.max(average * 1.5, d3.max(points)) : 1;\r\n                        var numberOfPoints = points && points.length ? points.length : 2;\r\n\r\n                        var scaleY = d3.scaleLinear()\r\n                            .domain([0, max])\r\n                            .range([height - verticalMargin, verticalMargin]);\r\n\r\n                        var scaleX = d3.scaleLinear()\r\n                            .domain([0, numberOfPoints - 1])\r\n                            .range([horizontalMargin, width - horizontalMargin]);\r\n\r\n                        var area = d3.area()\r\n                            .x(function (d, i) {\r\n                                return scaleX(i);\r\n                            })\r\n                            .y(function (d, i) { return scaleY(d); })\r\n                            .y1(function (d) { return scaleY(0); }) \r\n                            .curve(d3.curveLinear);\r\n\r\n                        var line = d3.line()\r\n                            .x(function (d, i) {\r\n                                return scaleX(i);\r\n                            })\r\n                            .y(function(d, i) {\r\n                                return scaleY(d);\r\n                            })\r\n                            .curve(d3.curveLinear);\r\n\r\n                        var chart = d3.select(svg)\r\n                            .attr('width', width)\r\n                            .attr('height', height);\r\n\r\n                        chart.append('rect')\r\n                            .attr('width', width - 2 * horizontalMargin)\r\n                            .attr('height', height - 2 * verticalMargin)\r\n                            .attr('transform', 'translate(' + horizontalMargin + ',' + verticalMargin + ')')\r\n                            .attr('fill', '#F2F6F7');\r\n\r\n                        if (points) {\r\n                            chart.append('path')\r\n                                .datum(points)\r\n                                .attr('d', area)\r\n                                .attr('class', 'graph-data-fill');\r\n\r\n\r\n                            chart.append('path')\r\n                                .datum(points)\r\n                                .attr('d', line)\r\n                                .attr('class', 'graph-data-line');\r\n                        }\r\n\r\n                        chart.append('path')\r\n                            .datum(Array(numberOfPoints).fill(average))\r\n                            .attr('d', line)\r\n                            .attr('class', 'graph-avg-line');\r\n                    }\r\n                };\r\n            });\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/directives/ui.particular.graph.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///0\n"); +eval("\n\n__webpack_require__(55);\n__webpack_require__(60);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL21vbml0b3JpbmcuanM/ZTJhZCJdLCJuYW1lcyI6WyJyZXF1aXJlIl0sIm1hcHBpbmdzIjoiOztBQUFBLG1CQUFBQSxDQUFRLEVBQVI7QUFDQSxtQkFBQUEsQ0FBUSxFQUFSIiwiZmlsZSI6IjU0LmpzIiwic291cmNlc0NvbnRlbnQiOlsicmVxdWlyZSgnLi9qcy9tb25pdG9yZWRfZW5kcG9pbnRzLm1vZHVsZScpO1xyXG5yZXF1aXJlKCcuL2pzL2VuZHBvaW50X2RldGFpbHMubW9kdWxlJyk7XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vYXBwL21vZHVsZXMvbW9uaXRvcmluZy9tb25pdG9yaW5nLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///54\n"); /***/ }), -/* 1 */ + +/***/ 55: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graphdecimal', []).filter('graphdecimal', ['$filter', function ($filter) {\n return function (input, decimals) {\n if (input) {\n var lastValue = input.points.length > 0 ? input.points[input.points.length - 1] : 0;\n input.displayValue = $filter(\"metricslargenumber\")(lastValue, decimals);\n } else {\n input = {\n points: [],\n average: 0,\n displayValue: 0\n };\n }\n\n return input;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGRlY2ltYWwuanM/NTFkMyJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwibW9kdWxlIiwiZmlsdGVyIiwiJGZpbHRlciIsImlucHV0IiwiZGVjaW1hbHMiLCJsYXN0VmFsdWUiLCJwb2ludHMiLCJsZW5ndGgiLCJkaXNwbGF5VmFsdWUiLCJhdmVyYWdlIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQUQsWUFBUUUsTUFBUixDQUFlLDRCQUFmLEVBQTZDLEVBQTdDLEVBQ0tDLE1BREwsQ0FDWSxjQURaLEVBQzRCLENBQUMsU0FBRCxFQUFZLFVBQVVDLE9BQVYsRUFBbUI7QUFDbkQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCQyxRQUFqQixFQUEyQjtBQUM5QixnQkFBSUQsS0FBSixFQUFXO0FBQ1Asb0JBQUlFLFlBQVlGLE1BQU1HLE1BQU4sQ0FBYUMsTUFBYixHQUFzQixDQUF0QixHQUEwQkosTUFBTUcsTUFBTixDQUFhSCxNQUFNRyxNQUFOLENBQWFDLE1BQWIsR0FBc0IsQ0FBbkMsQ0FBMUIsR0FBa0UsQ0FBbEY7QUFDQUosc0JBQU1LLFlBQU4sR0FBcUJOLFFBQVEsb0JBQVIsRUFBOEJHLFNBQTlCLEVBQXlDRCxRQUF6QyxDQUFyQjtBQUNILGFBSEQsTUFHTztBQUNIRCx3QkFBUTtBQUNKRyw0QkFBUSxFQURKO0FBRUpHLDZCQUFTLENBRkw7QUFHSkQsa0NBQWM7QUFIVixpQkFBUjtBQUtIOztBQUVELG1CQUFPTCxLQUFQO0FBQ0gsU0FiRDtBQWNILEtBZnVCLENBRDVCO0FBaUJILENBcEJBLEVBb0JDTixNQXBCRCxFQW9CU0EsT0FBT0MsT0FwQmhCLENBQUQiLCJmaWxlIjoiMS5qcyIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbiAod2luZG93LCBhbmd1bGFyLCB1bmRlZmluZWQpIHtcclxuICAgICd1c2Ugc3RyaWN0JztcclxuXHJcbiAgICBhbmd1bGFyLm1vZHVsZSgndWkucGFydGljdWxhci5ncmFwaGRlY2ltYWwnLCBbXSlcclxuICAgICAgICAuZmlsdGVyKCdncmFwaGRlY2ltYWwnLCBbJyRmaWx0ZXInLCBmdW5jdGlvbiAoJGZpbHRlcikge1xyXG4gICAgICAgICAgICByZXR1cm4gZnVuY3Rpb24gKGlucHV0LCBkZWNpbWFscykge1xyXG4gICAgICAgICAgICAgICAgaWYgKGlucHV0KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdmFyIGxhc3RWYWx1ZSA9IGlucHV0LnBvaW50cy5sZW5ndGggPiAwID8gaW5wdXQucG9pbnRzW2lucHV0LnBvaW50cy5sZW5ndGggLSAxXSA6IDA7XHJcbiAgICAgICAgICAgICAgICAgICAgaW5wdXQuZGlzcGxheVZhbHVlID0gJGZpbHRlcihcIm1ldHJpY3NsYXJnZW51bWJlclwiKShsYXN0VmFsdWUsIGRlY2ltYWxzKTtcclxuICAgICAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgaW5wdXQgPSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBvaW50czogW10sXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGF2ZXJhZ2U6IDAsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXlWYWx1ZTogMFxyXG4gICAgICAgICAgICAgICAgICAgIH07XHJcbiAgICAgICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGlucHV0O1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1dKTtcclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XHJcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZGVjaW1hbC5qcyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///1\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('monitored_endpoints', []);\n\n __webpack_require__(56);\n __webpack_require__(78);\n __webpack_require__(57);\n __webpack_require__(58);\n __webpack_require__(5);\n\n __webpack_require__(6);\n __webpack_require__(7);\n __webpack_require__(8);\n __webpack_require__(9);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL21vbml0b3JlZF9lbmRwb2ludHMubW9kdWxlLmpzPzA3YmQiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsInJlcXVpcmUiXSwibWFwcGluZ3MiOiI7O0FBQUMsV0FBVUEsTUFBVixFQUFrQkMsT0FBbEIsRUFBMkJDLFNBQTNCLEVBQXNDO0FBQ25DOztBQUNBRCxZQUFRRSxNQUFSLENBQWUscUJBQWYsRUFBc0MsRUFBdEM7O0FBRUFDLElBQUEsbUJBQUFBLENBQVEsRUFBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLEVBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxFQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsRUFBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7O0FBRUFBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNILENBZEEsRUFjQ0osTUFkRCxFQWNTQSxPQUFPQyxPQWRoQixDQUFEIiwiZmlsZSI6IjU1LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG4gICAgYW5ndWxhci5tb2R1bGUoJ21vbml0b3JlZF9lbmRwb2ludHMnLCBbXSk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9zZXJ2aWNlcy9zZXJ2aWNlcy5tb25pdG9yaW5nJyk7XHJcbiAgICByZXF1aXJlKCcuL3NlcnZpY2VzL3NlcnZpY2VzLmNvbm5lY3Rpdml0eU5vdGlmaWVyJyk7XHJcbiAgICByZXF1aXJlKCcuL21vbml0b3JlZF9lbmRwb2ludHMuY29udHJvbGxlcicpO1xyXG4gICAgcmVxdWlyZSgnLi9tb25pdG9yZWRfZW5kcG9pbnRzLnJvdXRlLmpzJyk7XHJcbiAgICByZXF1aXJlKCcuL2NvbnN0YW50LmRpYWdyYW1zLmpzJyk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZ3JhcGguanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZGVjaW1hbC5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZ3JhcGhkdXJhdGlvbi5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIubWV0cmljc2xhcmdlbnVtYmVyLmpzJyk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhcikpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvbW9uaXRvcmVkX2VuZHBvaW50cy5tb2R1bGUuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///55\n"); /***/ }), -/* 2 */ + +/***/ 56: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graphduration', []).filter('graphduration', ['formatter', function (formatter) {\n return function (input) {\n if (input) {\n var lastValue = input.points.length > 0 ? input.points[input.points.length - 1] : 0;\n input.displayValue = formatter.formatTime(lastValue);\n }\n\n return input;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGR1cmF0aW9uLmpzP2Y3NWIiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsImZpbHRlciIsImZvcm1hdHRlciIsImlucHV0IiwibGFzdFZhbHVlIiwicG9pbnRzIiwibGVuZ3RoIiwiZGlzcGxheVZhbHVlIiwiZm9ybWF0VGltZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQyxXQUFVQSxNQUFWLEVBQWtCQyxPQUFsQixFQUEyQkMsU0FBM0IsRUFBc0M7QUFDbkM7O0FBRUFELFlBQVFFLE1BQVIsQ0FBZSw2QkFBZixFQUE4QyxFQUE5QyxFQUNLQyxNQURMLENBQ1ksZUFEWixFQUM2QixDQUFDLFdBQUQsRUFBYyxVQUFVQyxTQUFWLEVBQXFCO0FBQ3hELGVBQU8sVUFBVUMsS0FBVixFQUFpQjtBQUNwQixnQkFBSUEsS0FBSixFQUFXO0FBQ1Asb0JBQUlDLFlBQVlELE1BQU1FLE1BQU4sQ0FBYUMsTUFBYixHQUFzQixDQUF0QixHQUEwQkgsTUFBTUUsTUFBTixDQUFhRixNQUFNRSxNQUFOLENBQWFDLE1BQWIsR0FBc0IsQ0FBbkMsQ0FBMUIsR0FBa0UsQ0FBbEY7QUFDQUgsc0JBQU1JLFlBQU4sR0FBcUJMLFVBQVVNLFVBQVYsQ0FBcUJKLFNBQXJCLENBQXJCO0FBQ0g7O0FBRUQsbUJBQU9ELEtBQVA7QUFDSCxTQVBEO0FBUUgsS0FUd0IsQ0FEN0I7QUFXSCxDQWRBLEVBY0NOLE1BZEQsRUFjU0EsT0FBT0MsT0FkaEIsQ0FBRCIsImZpbGUiOiIyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCd1aS5wYXJ0aWN1bGFyLmdyYXBoZHVyYXRpb24nLCBbXSlcclxuICAgICAgICAuZmlsdGVyKCdncmFwaGR1cmF0aW9uJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHZhciBsYXN0VmFsdWUgPSBpbnB1dC5wb2ludHMubGVuZ3RoID4gMCA/IGlucHV0LnBvaW50c1tpbnB1dC5wb2ludHMubGVuZ3RoIC0gMV0gOiAwO1xyXG4gICAgICAgICAgICAgICAgICAgIGlucHV0LmRpc3BsYXlWYWx1ZSA9IGZvcm1hdHRlci5mb3JtYXRUaW1lKGxhc3RWYWx1ZSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGlucHV0O1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1dKTtcclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XHJcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZHVyYXRpb24uanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///2\n"); +eval("\n\n;\n(function (window, angular, $, undefined) {\n 'use strict';\n\n function Service($http, rx, scConfig, uri, $q) {\n\n function createEndpointsSource(historyPeriod, refreshInterval) {\n return Rx.Observable.interval(refreshInterval).startWith(0).flatMap(function (i) {\n return Rx.Observable.fromArray(loadEndpointDataFromMonitoringService(historyPeriod)).flatMap(function (p) {\n var o = Rx.Observable.fromPromise(p);\n o = o.catch(Rx.Observable.empty());\n return o;\n });\n }).selectMany(function (endpoints) {\n return endpoints;\n });\n }\n\n function loadEndpointDataFromMonitoringService(historyPeriod) {\n return scConfig.monitoring_urls.map(function (url) {\n return $http.get(uri.join(url, 'monitored-endpoints') + '?history=' + historyPeriod).then(function (result) {\n var sourceIndex = scConfig.monitoring_urls.indexOf(url);\n\n result.data.forEach(function (endpoint) {\n endpoint.sourceIndex = sourceIndex;\n });\n\n return result.data;\n }, function (error) {\n var sourceIndex = scConfig.monitoring_urls.indexOf(url);\n return [{ error: error, sourceIndex: sourceIndex }];\n });\n });\n }\n\n function loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod) {\n return $http.get(uri.join(scConfig.monitoring_urls[sourceIndex], 'monitored-endpoints', endpointName) + \"?history=\" + historyPeriod).then(function (result) {\n return result.data;\n }, function (error) {\n return { error: error };\n });\n }\n\n function createEndpointDetailsSource(endpointName, sourceIndex, historyPeriod, refreshInterval) {\n return Rx.Observable.interval(refreshInterval).startWith(0).flatMap(function (i) {\n return Rx.Observable.fromPromise(loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod));\n });\n }\n\n var service = {\n createEndpointsSource: createEndpointsSource,\n createEndpointDetailsSource: createEndpointDetailsSource\n };\n\n return service;\n }\n\n Service.$inject = ['$http', 'rx', 'scConfig', 'uri', '$q', 'toastService'];\n\n angular.module('services.monitoringService', ['sc']).service('monitoringService', Service);\n})(window, window.angular, window.jQuery);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/services/services.monitoring.js?fa65"],"names":["window","angular","$","undefined","Service","$http","rx","scConfig","uri","$q","createEndpointsSource","historyPeriod","refreshInterval","Rx","Observable","interval","startWith","flatMap","i","fromArray","loadEndpointDataFromMonitoringService","p","o","fromPromise","catch","empty","selectMany","endpoints","monitoring_urls","map","url","get","join","then","result","sourceIndex","indexOf","data","forEach","endpoint","error","loadEndpointDetailsFromMonitoringService","endpointName","createEndpointDetailsSource","service","$inject","module","jQuery"],"mappings":"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","file":"56.js","sourcesContent":[";\r\n(function (window, angular, $, undefined) {\r\n    'use strict';\r\n\r\n    function Service($http, rx, scConfig, uri, $q) {\r\n\r\n        function createEndpointsSource(historyPeriod, refreshInterval) {\r\n            return Rx.Observable.interval(refreshInterval).startWith(0)\r\n                .flatMap(function (i) {\r\n                    return Rx.Observable.fromArray(loadEndpointDataFromMonitoringService(historyPeriod))\r\n                        .flatMap(function (p) {\r\n                            var o = Rx.Observable.fromPromise(p);\r\n                            o = o.catch(Rx.Observable.empty());\r\n                            return o;\r\n                        });\r\n                }).selectMany(function (endpoints) {\r\n                    return endpoints;\r\n                });\r\n        }\r\n\r\n        function loadEndpointDataFromMonitoringService(historyPeriod) {\r\n            return scConfig.monitoring_urls.map(function (url) {\r\n                return $http.get(uri.join(url, 'monitored-endpoints') + '?history=' + historyPeriod)\r\n                    .then(function (result) {\r\n                        var sourceIndex = scConfig.monitoring_urls.indexOf(url);\r\n\r\n                        result.data.forEach(function (endpoint) {\r\n                            endpoint.sourceIndex = sourceIndex;\r\n                        });\r\n\r\n                        return result.data;\r\n                    },\r\n                    (error) => {\r\n                        var sourceIndex = scConfig.monitoring_urls.indexOf(url);\r\n                        return [{ error: error, sourceIndex: sourceIndex }];\r\n                        }\r\n                    );\r\n            });\r\n        }\r\n\r\n        function loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod) {\r\n            return $http.get(uri.join(scConfig.monitoring_urls[sourceIndex], 'monitored-endpoints', endpointName) + \"?history=\" + historyPeriod)\r\n                .then(function (result) {\r\n                    return result.data;\r\n                }, function (error) {\r\n                    return { error: error };\r\n                });\r\n        }\r\n\r\n        function createEndpointDetailsSource(endpointName, sourceIndex, historyPeriod, refreshInterval) {\r\n            return Rx.Observable.interval(refreshInterval).startWith(0)\r\n                .flatMap(function (i) {\r\n                    return Rx.Observable.fromPromise(loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod));\r\n                });\r\n        }\r\n\r\n        var service = {\r\n            createEndpointsSource: createEndpointsSource,\r\n            createEndpointDetailsSource: createEndpointDetailsSource\r\n        };\r\n\r\n        return service;\r\n    }\r\n\r\n    Service.$inject = ['$http', 'rx', 'scConfig', 'uri', '$q', 'toastService'];\r\n\r\n    angular.module('services.monitoringService', ['sc'])\r\n        .service('monitoringService', Service);\r\n}(window, window.angular, window.jQuery));\r\n\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/services/services.monitoring.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///56\n"); /***/ }), -/* 3 */ + +/***/ 57: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular) {\n 'use strict';\n\n angular.module('ui.particular.metricslargenumber', []).filter('metricslargenumber', ['formatter', function (formatter) {\n return function (input, dec) {\n var decimals = 0;\n if (input < 10 || input > 1000000) {\n decimals = 2;\n }\n return formatter.formatLargeNumber(input, dec || decimals);\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5tZXRyaWNzbGFyZ2VudW1iZXIuanM/ZWQ2MSJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwibW9kdWxlIiwiZmlsdGVyIiwiZm9ybWF0dGVyIiwiaW5wdXQiLCJkZWMiLCJkZWNpbWFscyIsImZvcm1hdExhcmdlTnVtYmVyIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVNBLE1BQVQsRUFBaUJDLE9BQWpCLEVBQTBCO0FBQzFCOztBQUVHQSxZQUFRQyxNQUFSLENBQWUsa0NBQWYsRUFBbUQsRUFBbkQsRUFDS0MsTUFETCxDQUNZLG9CQURaLEVBQ2tDLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDN0QsZUFBTyxVQUFVQyxLQUFWLEVBQWlCQyxHQUFqQixFQUFzQjtBQUN6QixnQkFBSUMsV0FBVyxDQUFmO0FBQ0EsZ0JBQUlGLFFBQVEsRUFBUixJQUFjQSxRQUFRLE9BQTFCLEVBQW1DO0FBQy9CRSwyQkFBVyxDQUFYO0FBQ0g7QUFDRCxtQkFBT0gsVUFBVUksaUJBQVYsQ0FBNEJILEtBQTVCLEVBQW1DQyxPQUFPQyxRQUExQyxDQUFQO0FBQ0gsU0FORDtBQU9ILEtBUjZCLENBRGxDO0FBVUgsQ0FiQSxFQWFDUCxNQWJELEVBYVNBLE9BQU9DLE9BYmhCLENBQUQiLCJmaWxlIjoiMy5qcyIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbih3aW5kb3csIGFuZ3VsYXIpIHtcclxuXHQndXNlIHN0cmljdCc7XHJcblxyXG4gICAgYW5ndWxhci5tb2R1bGUoJ3VpLnBhcnRpY3VsYXIubWV0cmljc2xhcmdlbnVtYmVyJywgW10pXHJcbiAgICAgICAgLmZpbHRlcignbWV0cmljc2xhcmdlbnVtYmVyJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQsIGRlYykge1xyXG4gICAgICAgICAgICAgICAgdmFyIGRlY2ltYWxzID0gMDtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dCA8IDEwIHx8IGlucHV0ID4gMTAwMDAwMCkge1xyXG4gICAgICAgICAgICAgICAgICAgIGRlY2ltYWxzID0gMjtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0TGFyZ2VOdW1iZXIoaW5wdXQsIGRlYyB8fCBkZWNpbWFscyk7XHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgfV0pO1xyXG59KHdpbmRvdywgd2luZG93LmFuZ3VsYXIpKTtcblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5tZXRyaWNzbGFyZ2VudW1iZXIuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///3\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function controller($scope, $location, monitoringService, serviceControlService, toastService, historyPeriods, rx, $filter, smallGraphsMinimumYAxis, connectivityNotifier) {\n\n var subscription, endpointsFromScSubscription;\n\n $scope.periods = historyPeriods;\n $scope.selectedPeriod = $scope.periods[0];\n $scope.smallGraphsMinimumYAxis = smallGraphsMinimumYAxis;\n\n if ($location.$$search.historyPeriod) {\n $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\n return period.value == $location.$$search.historyPeriod;\n })];\n }\n\n $scope.endpoints = [];\n\n $scope.selectPeriod = function (period) {\n $scope.selectedPeriod = period;\n\n updateUI();\n };\n\n $scope.getDetailsUrl = function (endpoint) {\n if (!endpoint.isServiceControlOnly) {\n return '#/endpoint_details/' + endpoint.name + '/' + endpoint.sourceIndex + '?historyPeriod=' + $scope.selectedPeriod.value;\n }\n\n return '#/failed-messages/groups/' + endpoint.serviceControlId;\n };\n\n function fillDisplayValuesForEndpoint(endpoint) {\n\n $filter('graphduration')(endpoint.metrics.processingTime);\n $filter('graphduration')(endpoint.metrics.criticalTime);\n $filter('graphdecimal')(endpoint.metrics.queueLength, 0);\n $filter('graphdecimal')(endpoint.metrics.throughput, 2);\n $filter('graphdecimal')(endpoint.metrics.retries, 2);\n }\n\n function updateUI() {\n if (subscription) {\n subscription.dispose();\n }\n\n if (endpointsFromScSubscription) {\n endpointsFromScSubscription.dispose();\n }\n\n var selectedPeriod = $scope.selectedPeriod;\n\n subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\n if (endpoint.error) {\n connectivityNotifier.reportFailedConnection(endpoint.sourceIndex);\n if ($scope.endpoints) {\n $scope.endpoints.filter(function (item) {\n return item.sourceIndex === endpoint.sourceIndex;\n }).forEach(function (item) {\n return item.isScMonitoringDisconnected = true;\n });\n }\n } else {\n connectivityNotifier.reportSuccessfulConnection(endpoint.sourceIndex);\n var index = $scope.endpoints.findIndex(function (item) {\n return item.name === endpoint.name;\n });\n\n endpoint.isConnected = true;\n endpoint.isScMonitoringDisconnected = false;\n fillDisplayValuesForEndpoint(endpoint);\n if (index >= 0) {\n var previousServiceControlId = $scope.endpoints[index].serviceControlId;\n var previousErrorCount = $scope.endpoints[index].errorCount;\n\n $scope.endpoints[index] = endpoint;\n $scope.endpoints[index].serviceControlId = previousServiceControlId;\n $scope.endpoints[index].errorCount = previousErrorCount;\n } else {\n $scope.endpoints.push(endpoint);\n\n $scope.endpoints.sort(function (first, second) {\n if (first.name < second.name) {\n return -1;\n }\n\n if (first.name > second.name) {\n return 1;\n }\n\n return 0;\n });\n }\n }\n\n $scope.$apply();\n });\n\n endpointsFromScSubscription = Rx.Observable.interval(5000).startWith(0).flatMap(function (i) {\n return Rx.Observable.fromPromise(serviceControlService.getExceptionGroups('Endpoint Name', ''));\n }).selectMany(function (endpoints) {\n return endpoints.data;\n }).subscribe(function (endpoint) {\n var index = $scope.endpoints.findIndex(function (item) {\n return item.name === endpoint.title;\n });\n if (index >= 0) {\n $scope.endpoints[index].serviceControlId = endpoint.id;\n $scope.endpoints[index].errorCount = endpoint.count;\n } else {\n $scope.endpoints.push({ name: endpoint.title, errorCount: endpoint.count, isConnected: false, isServiceControlOnly: true, serviceControlId: endpoint.id });\n }\n });\n }\n\n updateUI();\n\n $scope.$on(\"$destroy\", function handler() {\n subscription.dispose();\n endpointsFromScSubscription.dispose();\n });\n };\n\n controller.$inject = ['$scope', '$location', 'monitoringService', 'serviceControlService', 'toastService', 'historyPeriods', 'rx', '$filter', 'smallGraphsMinimumYAxis', 'connectivityNotifier'];\n\n angular.module('monitored_endpoints').controller('monitoredEndpointsCtrl', controller);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/monitored_endpoints.controller.js?06ce"],"names":["window","angular","undefined","controller","$scope","$location","monitoringService","serviceControlService","toastService","historyPeriods","rx","$filter","smallGraphsMinimumYAxis","connectivityNotifier","subscription","endpointsFromScSubscription","periods","selectedPeriod","$$search","historyPeriod","findIndex","period","value","endpoints","selectPeriod","updateUI","getDetailsUrl","endpoint","isServiceControlOnly","name","sourceIndex","serviceControlId","fillDisplayValuesForEndpoint","metrics","processingTime","criticalTime","queueLength","throughput","retries","dispose","createEndpointsSource","refreshInterval","subscribe","error","reportFailedConnection","filter","item","forEach","isScMonitoringDisconnected","reportSuccessfulConnection","index","isConnected","previousServiceControlId","previousErrorCount","errorCount","push","sort","first","second","$apply","Rx","Observable","interval","startWith","flatMap","i","fromPromise","getExceptionGroups","selectMany","data","title","id","count","$on","handler","$inject","module"],"mappings":"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","file":"57.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    function controller(\r\n        $scope,\r\n        $location,\r\n        monitoringService,\r\n        serviceControlService,\r\n        toastService,\r\n        historyPeriods,\r\n        rx,\r\n        $filter,\r\n        smallGraphsMinimumYAxis,\r\n        connectivityNotifier) {\r\n\r\n        var subscription, endpointsFromScSubscription;\r\n\r\n        $scope.periods = historyPeriods;\r\n        $scope.selectedPeriod = $scope.periods[0];\r\n        $scope.smallGraphsMinimumYAxis = smallGraphsMinimumYAxis;\r\n\r\n        if ($location.$$search.historyPeriod) {\r\n            $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\r\n                return period.value == $location.$$search.historyPeriod;\r\n            })];\r\n        }\r\n\r\n        $scope.endpoints = [];\r\n\r\n        $scope.selectPeriod = function (period) {\r\n            $scope.selectedPeriod = period;\r\n\r\n            updateUI();\r\n        };\r\n\r\n        $scope.getDetailsUrl = endpoint => {\r\n            if (!endpoint.isServiceControlOnly) {\r\n                return '#/endpoint_details/' + endpoint.name + '/' + endpoint.sourceIndex + '?historyPeriod=' + $scope.selectedPeriod.value;\r\n            }\r\n\r\n            return '#/failed-messages/groups/' + endpoint.serviceControlId;\r\n        };\r\n\r\n        function fillDisplayValuesForEndpoint(endpoint) {\r\n\r\n            $filter('graphduration')(endpoint.metrics.processingTime);\r\n            $filter('graphduration')(endpoint.metrics.criticalTime);\r\n            $filter('graphdecimal')(endpoint.metrics.queueLength, 0);\r\n            $filter('graphdecimal')(endpoint.metrics.throughput, 2);\r\n            $filter('graphdecimal')(endpoint.metrics.retries, 2);\r\n        }\r\n\r\n        function updateUI() {\r\n            if (subscription) {\r\n                subscription.dispose();\r\n            }\r\n\r\n            if (endpointsFromScSubscription) {\r\n                endpointsFromScSubscription.dispose();\r\n            }\r\n\r\n            var selectedPeriod = $scope.selectedPeriod;\r\n\r\n            subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval)\r\n                .subscribe(function(endpoint) {\r\n                    if (endpoint.error) {\r\n                        connectivityNotifier.reportFailedConnection(endpoint.sourceIndex);\r\n                        if ($scope.endpoints) {\r\n                            $scope.endpoints.filter((item) => item.sourceIndex === endpoint.sourceIndex)\r\n                                .forEach((item) => item.isScMonitoringDisconnected = true);\r\n                        }\r\n                    } else {\r\n                        connectivityNotifier.reportSuccessfulConnection(endpoint.sourceIndex);\r\n                        var index = $scope.endpoints.findIndex(function(item) { return item.name === endpoint.name });\r\n\r\n                        endpoint.isConnected = true;\r\n                        endpoint.isScMonitoringDisconnected = false;\r\n                        fillDisplayValuesForEndpoint(endpoint);\r\n                        if (index >= 0) {\r\n                            var previousServiceControlId = $scope.endpoints[index].serviceControlId;\r\n                            var previousErrorCount = $scope.endpoints[index].errorCount;\r\n\r\n                            $scope.endpoints[index] = endpoint;\r\n                            $scope.endpoints[index].serviceControlId = previousServiceControlId;\r\n                            $scope.endpoints[index].errorCount = previousErrorCount;\r\n                        } else {\r\n                            $scope.endpoints.push(endpoint);\r\n\r\n                            $scope.endpoints.sort(function(first, second) {\r\n                                if (first.name < second.name) {\r\n                                    return -1;\r\n                                }\r\n\r\n                                if (first.name > second.name) {\r\n                                    return 1;\r\n                                }\r\n\r\n                                return 0;\r\n                            });\r\n                        }\r\n                    }\r\n\r\n                    $scope.$apply();\r\n                });\r\n\r\n            endpointsFromScSubscription =\r\n                Rx.Observable.interval(5000).startWith(0)\r\n                .flatMap(function(i) {\r\n                    return Rx.Observable.fromPromise(serviceControlService.getExceptionGroups('Endpoint Name', ''));\r\n                }).selectMany(function(endpoints) {\r\n                    return endpoints.data;\r\n                }).subscribe(function (endpoint) {\r\n                    var index = $scope.endpoints.findIndex(function(item) { return item.name === endpoint.title });\r\n                    if (index >= 0) {\r\n                        $scope.endpoints[index].serviceControlId = endpoint.id;\r\n                        $scope.endpoints[index].errorCount = endpoint.count;\r\n                    } else {\r\n                        $scope.endpoints.push({ name: endpoint.title, errorCount: endpoint.count, isConnected: false, isServiceControlOnly: true, serviceControlId: endpoint.id });\r\n                    }\r\n                });\r\n        }\r\n\r\n        updateUI();\r\n\r\n        $scope.$on(\"$destroy\", function handler() {\r\n            subscription.dispose();\r\n            endpointsFromScSubscription.dispose();\r\n        });\r\n    };\r\n\r\n    controller.$inject = [\r\n        '$scope',\r\n        '$location',\r\n        'monitoringService',\r\n        'serviceControlService',\r\n        'toastService',\r\n        'historyPeriods',\r\n        'rx',\r\n        '$filter',\r\n        'smallGraphsMinimumYAxis',\r\n        'connectivityNotifier'\r\n    ];\r\n\r\n    angular.module('monitored_endpoints')\r\n        .controller('monitoredEndpointsCtrl', controller);\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/monitored_endpoints.controller.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///57\n"); /***/ }), -/* 4 */ + +/***/ 58: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n__webpack_require__(5);\n__webpack_require__(10);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL21vbml0b3JpbmcuanM/ZTJhZCJdLCJuYW1lcyI6WyJyZXF1aXJlIl0sIm1hcHBpbmdzIjoiOztBQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDQSxtQkFBQUEsQ0FBUSxFQUFSIiwiZmlsZSI6IjQuanMiLCJzb3VyY2VzQ29udGVudCI6WyJyZXF1aXJlKCcuL2pzL21vbml0b3JlZF9lbmRwb2ludHMubW9kdWxlJyk7XHJcbnJlcXVpcmUoJy4vanMvZW5kcG9pbnRfZGV0YWlscy5tb2R1bGUnKTtcblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL21vbml0b3JpbmcuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///4\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function routeProvider($routeProvider) {\n var template = __webpack_require__(59);\n\n $routeProvider.when('/monitored_endpoints', {\n data: {\n pageTitle: 'Monitored Endpoints'\n },\n template: template,\n controller: 'monitoredEndpointsCtrl',\n controllerAs: 'vm',\n reloadOnSearch: false\n });\n };\n\n routeProvider.$inject = ['$routeProvider'];\n\n angular.module('monitored_endpoints').config(routeProvider);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL21vbml0b3JlZF9lbmRwb2ludHMucm91dGUuanM/MjcwNiJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwicm91dGVQcm92aWRlciIsIiRyb3V0ZVByb3ZpZGVyIiwidGVtcGxhdGUiLCJyZXF1aXJlIiwid2hlbiIsImRhdGEiLCJwYWdlVGl0bGUiLCJjb250cm9sbGVyIiwiY29udHJvbGxlckFzIiwicmVsb2FkT25TZWFyY2giLCIkaW5qZWN0IiwibW9kdWxlIiwiY29uZmlnIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQSxhQUFTQyxhQUFULENBQXVCQyxjQUF2QixFQUF1QztBQUNuQyxZQUFJQyxXQUFXLG1CQUFBQyxDQUFRLEVBQVIsQ0FBZjs7QUFFQUYsdUJBQWVHLElBQWYsQ0FBb0Isc0JBQXBCLEVBQTRDO0FBQ3hDQyxrQkFBTTtBQUNGQywyQkFBVztBQURULGFBRGtDO0FBSXhDSixzQkFBVUEsUUFKOEI7QUFLeENLLHdCQUFZLHdCQUw0QjtBQU14Q0MsMEJBQWMsSUFOMEI7QUFPeENDLDRCQUFnQjtBQVB3QixTQUE1QztBQVNIOztBQUVEVCxrQkFBY1UsT0FBZCxHQUF3QixDQUNwQixnQkFEb0IsQ0FBeEI7O0FBSUFaLFlBQVFhLE1BQVIsQ0FBZSxxQkFBZixFQUNLQyxNQURMLENBQ1laLGFBRFo7QUFFSCxDQXZCQSxFQXVCRUgsTUF2QkYsRUF1QlVBLE9BQU9DLE9BdkJqQixDQUFEIiwiZmlsZSI6IjU4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGZ1bmN0aW9uIHJvdXRlUHJvdmlkZXIoJHJvdXRlUHJvdmlkZXIpIHtcclxuICAgICAgICBsZXQgdGVtcGxhdGUgPSByZXF1aXJlKCcuLy4uL3ZpZXdzL21vbml0b3JlZF9lbmRwb2ludHMuaHRtbCcpO1xyXG5cclxuICAgICAgICAkcm91dGVQcm92aWRlci53aGVuKCcvbW9uaXRvcmVkX2VuZHBvaW50cycsIHtcclxuICAgICAgICAgICAgZGF0YToge1xyXG4gICAgICAgICAgICAgICAgcGFnZVRpdGxlOiAnTW9uaXRvcmVkIEVuZHBvaW50cydcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgdGVtcGxhdGU6IHRlbXBsYXRlLFxyXG4gICAgICAgICAgICBjb250cm9sbGVyOiAnbW9uaXRvcmVkRW5kcG9pbnRzQ3RybCcsXHJcbiAgICAgICAgICAgIGNvbnRyb2xsZXJBczogJ3ZtJyxcclxuICAgICAgICAgICAgcmVsb2FkT25TZWFyY2g6IGZhbHNlXHJcbiAgICAgICAgfSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJvdXRlUHJvdmlkZXIuJGluamVjdCA9IFtcclxuICAgICAgICAnJHJvdXRlUHJvdmlkZXInXHJcbiAgICBdO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCdtb25pdG9yZWRfZW5kcG9pbnRzJylcclxuICAgICAgICAuY29uZmlnKHJvdXRlUHJvdmlkZXIpO1xyXG59ICh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vYXBwL21vZHVsZXMvbW9uaXRvcmluZy9qcy9tb25pdG9yZWRfZW5kcG9pbnRzLnJvdXRlLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///58\n"); + +/***/ }), + +/***/ 59: +/***/ (function(module, exports) { + +eval("module.exports = \"

Endpoints overview

Endpoint monitoring not available

Monitoring is not available due to one or more of these reasons:

  • the monitoring server is not configured or is unavailable
  • the monitoring plugin is not installed on the endpoints to be monitored
  • endpoints without the monitoring plugin do not have auditing enabled
Endpoint name
Queue Length (msgs)

Queue length: The estimated number of messages in an endpoint's queue.

WARNING: This is an experimental feature. Learn more

Throughput (msgs/s)
Scheduled retry rate (msgs/s)
Processing Time (t)
Critical Time (t)
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.queueLength.displayValue}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.throughput.displayValue}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.retries.displayValue}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.processingTime.displayValue.value}} ? {{endpoint.metrics.processingTime.displayValue.unit}}
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.criticalTime.displayValue.value}} ? {{endpoint.metrics.criticalTime.displayValue.unit}}
No plug-ins installed.
\";//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/views/monitored_endpoints.html?3a87"],"names":[],"mappings":"AAAA,kdAAkd,qBAAqB,iLAAiL,cAAc,KAAK,aAAa,ypGAAypG,yBAAyB,mJAAmJ,eAAe,uhBAAuhB,2BAA2B,sFAAsF,0CAA0C,gPAAgP,qCAAqC,0GAA0G,8HAA8H,gTAAgT,oCAAoC,wGAAwG,6HAA6H,6SAA6S,iCAAiC,qGAAqG,0HAA0H,oTAAoT,wCAAwC,6GAA6G,uIAAuI,mLAAmL,mDAAmD,oOAAoO,sCAAsC,2GAA2G,qIAAqI,mLAAmL,iDAAiD","file":"59.js","sourcesContent":["module.exports = \"<div class=container ng-show=endpoints.length> <div class=\\\"row monitoring-head\\\"> <div class=\\\"col-sm-10 no-side-padding list-section\\\"> <h1>Endpoints overview</h1> </div> <div class=\\\"col-sm-2 no-side-padding toolbar-menus\\\"> <div class=\\\"msg-group-menu dropdown\\\"> <label class=control-label>Period:</label> <button type=button class=\\\"btn btn-default dropdown-toggle sp-btn-menu\\\" data-toggle=dropdown aria-haspopup=true aria-expanded=false> {{selectedPeriod.text}} <span class=caret></span> </button> <ul class=dropdown-menu> <li ng-repeat=\\\"period in periods\\\"> <a ng-click=selectPeriod(period) href=\\\"#/monitored_endpoints?historyPeriod={{period.value}}\\\">{{period.text}}</a> </li> </ul> </div> </div> </div> </div> <div class=container> <section ng-show=true> <div class=\\\"text-center monitoring-no-data\\\" ng-show=!endpoints.length> <h1>Endpoint monitoring not available</h1> <p>Monitoring is not available due to one or more of these reasons:</p> <ul> <li>the <strong>monitoring server</strong> is not configured or is unavailable</li> <li>the <strong>monitoring plugin</strong> is not installed on the endpoints to be monitored</li> <li>endpoints without the monitoring plugin do not have <strong>auditing</strong> enabled</li> </ul> <div class=action-toolbar> <a class=\\\"btn btn-default btn-primary\\\" href=\\\"https://docs.particular.net/search?q=metrics\\\">Learn more</a> </div> </div> <div ng-show=endpoints.length class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-7\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> Endpoint name </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=tooltip-trigger> Queue Length <span class=table-header-unit>(msgs)</span> <i class=\\\"fa fa-flask fake-link\\\"></i> <div class=interactive-tooltip> <div class=tooltip-contents> <p>Queue length: The estimated number of messages in an endpoint's queue.</p> <p>WARNING: This is an experimental feature. <a href=\\\"https://docs.particular.net/search?q=nservicebus+queue+length+metric+%2bexperimental\\\" target=_blank>Learn more</a> <i class=\\\"fa fa-external-link fake-link\\\"></i></p> </div> </div> </div> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Throughput: The number of messages per second successfully processed by a receiving endpoint.\\\"> Throughput <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate: The number of messages per second scheduled for retries (immediate or delayed).\\\"> Scheduled retry rate <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Processing time: The time taken for a receiving endpoint to successfully process a message.\\\"> Processing Time <span class=table-header-unit>(t)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Critical time: The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> Critical Time <span class=table-header-unit>(t)</span> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row box-group\\\" ng-repeat=\\\"endpoint in endpoints\\\" ng-mouseenter=\\\"endpoint.hover1=true\\\" ng-mouseleave=\\\"endpoint.hover1=false\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <a class=hard-wrap ng-click=\\\"endpoint.isExpanded = !endpoint.isExpanded\\\" ng-href={{getDetailsUrl(endpoint)}}> <div class=\\\"col-sm-2 col-xl-7 endpoint-name name-overview\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-lg-max-8 no-side-padding lead\\\"> {{endpoint.name}} </div> <div class=\\\"col-lg-5 no-side-padding endpoint-status\\\"> <span class=warning ng-if=endpoint.isScMonitoringDisconnected> <i class=\\\"fa pa-monitoring-lost endpoints-overview\\\" uib-tooltip=\\\"Unable to connect to monitoring server\\\"></i> </span> <span class=warning ng-if=endpoint.isStale> <i class=\\\"fa pa-endpoint-lost endpoints-overview\\\" uib-tooltip=\\\"Unable to connect to instance\\\"></i> </span> <span class=warning ng-if=endpoint.errorCount> <a ng-if=endpoint.errorCount class=\\\"warning btn\\\" href=#/failed-messages/groups/{{endpoint.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{endpoint.errorCount | metricslargenumber}}</span> </a> </span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.queueLength minimum-yaxis={{smallGraphsMinimumYAxis.queueLength}} class=\\\"graph queue-length pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.queueLength.displayValue}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.throughput minimum-yaxis={{smallGraphsMinimumYAxis.throughput}} class=\\\"graph throughput pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.throughput.displayValue}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.retries minimum-yaxis={{smallGraphsMinimumYAxis.retries}} class=\\\"graph retries pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.retries.displayValue}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.processingTime minimum-yaxis={{smallGraphsMinimumYAxis.processingTime}} class=\\\"graph processing-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.processingTime.displayValue.value}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.metrics.processingTime.displayValue.unit}}</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.criticalTime minimum-yaxis={{smallGraphsMinimumYAxis.criticalTime}} class=\\\"graph critical-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : endpoint.metrics.criticalTime.displayValue.value}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.metrics.criticalTime.displayValue.unit}}</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=!endpoint.isConnected> <div class=\\\"row box-header\\\"> No plug-ins installed. </div> </div> </a> </div> </div> </div> </div> </div> </section> </div> \";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./app/modules/monitoring/views/monitored_endpoints.html\n// module id = 59\n// module chunks = 1"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///59\n"); /***/ }), -/* 5 */ + +/***/ 6: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('monitored_endpoints', []);\n\n __webpack_require__(6);\n __webpack_require__(7);\n __webpack_require__(8);\n\n __webpack_require__(0);\n __webpack_require__(1);\n __webpack_require__(2);\n __webpack_require__(3);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL21vbml0b3JlZF9lbmRwb2ludHMubW9kdWxlLmpzPzA3YmQiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsInJlcXVpcmUiXSwibWFwcGluZ3MiOiI7O0FBQUMsV0FBVUEsTUFBVixFQUFrQkMsT0FBbEIsRUFBMkJDLFNBQTNCLEVBQXNDO0FBQ25DOztBQUNBRCxZQUFRRSxNQUFSLENBQWUscUJBQWYsRUFBc0MsRUFBdEM7O0FBRUFDLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSOztBQUVBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDSCxDQVpBLEVBWUNKLE1BWkQsRUFZU0EsT0FBT0MsT0FaaEIsQ0FBRCIsImZpbGUiOiI1LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG4gICAgYW5ndWxhci5tb2R1bGUoJ21vbml0b3JlZF9lbmRwb2ludHMnLCBbXSk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9zZXJ2aWNlcy9zZXJ2aWNlcy5tb25pdG9yaW5nJyk7XHJcbiAgICByZXF1aXJlKCcuL21vbml0b3JlZF9lbmRwb2ludHMuY29udHJvbGxlcicpO1xyXG4gICAgcmVxdWlyZSgnLi9tb25pdG9yZWRfZW5kcG9pbnRzLnJvdXRlLmpzJyk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZ3JhcGguanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZGVjaW1hbC5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZ3JhcGhkdXJhdGlvbi5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIubWV0cmljc2xhcmdlbnVtYmVyLmpzJyk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhcikpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvbW9uaXRvcmVkX2VuZHBvaW50cy5tb2R1bGUuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///5\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graph', []).directive('graph', function () {\n return {\n restrict: 'E',\n scope: {\n plotData: '&',\n formatter: '&',\n minimumYaxis: '@'\n },\n template: '',\n link: function link(scope, element, attrs) {\n scope.plotData = scope.plotData() || { points: [], average: 0 };\n\n var svg = element.find('svg')[0];\n\n var width = svg.clientWidth;\n var height = svg.clientHeight;\n\n //HINT: This is workaround for Firefox\n if (width === 0) {\n var box = svg.getBoundingClientRect();\n\n width = box.right - box.left;\n height = box.bottom - box.top;\n }\n\n var verticalMargin = 6;\n var horizontalMargin = 2;\n\n var points = scope.plotData.points;\n var average = scope.plotData.average || 0;\n var minimumYaxis = !isNaN(scope.minimumYaxis) ? Number(scope.minimumYaxis) : 10;\n var max = points && points.length ? Math.max(average * 1.5, d3.max(points), minimumYaxis) : 1;\n var numberOfPoints = points && points.length ? points.length : 2;\n\n var scaleY = d3.scaleLinear().domain([0, max]).range([height - verticalMargin, verticalMargin]);\n\n var scaleX = d3.scaleLinear().domain([0, numberOfPoints - 1]).range([horizontalMargin, width - horizontalMargin]);\n\n var area = d3.area().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).y1(function (d) {\n return scaleY(0);\n }).curve(d3.curveLinear);\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var chart = d3.select(svg).attr('width', width).attr('height', height);\n\n chart.append('rect').attr('width', width - 2 * horizontalMargin).attr('height', height - 2 * verticalMargin).attr('transform', 'translate(' + horizontalMargin + ',' + verticalMargin + ')').attr('fill', '#F2F6F7');\n\n if (points) {\n chart.append('path').datum(points).attr('d', area).attr('class', 'graph-data-fill');\n\n chart.append('path').datum(points).attr('d', line).attr('class', 'graph-data-line');\n }\n\n chart.append('path').datum(Array(numberOfPoints).fill(average)).attr('d', line).attr('class', 'graph-avg-line');\n }\n };\n });\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/directives/ui.particular.graph.js?c1b8"],"names":["window","angular","undefined","module","directive","restrict","scope","plotData","formatter","minimumYaxis","template","link","element","attrs","points","average","svg","find","width","clientWidth","height","clientHeight","box","getBoundingClientRect","right","left","bottom","top","verticalMargin","horizontalMargin","isNaN","Number","max","length","Math","d3","numberOfPoints","scaleY","scaleLinear","domain","range","scaleX","area","x","d","i","y","y1","curve","curveLinear","line","chart","select","attr","append","datum","Array","fill"],"mappings":"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","file":"6.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    angular.module('ui.particular.graph', [])\r\n        .directive('graph',\r\n            function() {\r\n                return {\r\n                    restrict: 'E',\r\n                    scope: {\r\n                        plotData: '&',\r\n                        formatter: '&',\r\n                        minimumYaxis: '@'\r\n                    },\r\n                    template: '<svg></svg>',\r\n                    link: function link(scope, element, attrs) {\r\n                        scope.plotData = scope.plotData() || { points: [], average: 0 };\r\n\r\n                        var svg = element.find('svg')[0];\r\n\r\n                        var width = svg.clientWidth;\r\n                        var height = svg.clientHeight;\r\n\r\n                        //HINT: This is workaround for Firefox\r\n                        if (width === 0) {\r\n                            var box = svg.getBoundingClientRect();\r\n\r\n                            width = box.right - box.left;\r\n                            height = box.bottom - box.top;\r\n                        }\r\n\r\n                        var verticalMargin = 6;\r\n                        var horizontalMargin = 2;\r\n\r\n                        var points = scope.plotData.points;\r\n                        var average = scope.plotData.average || 0;\r\n                        var minimumYaxis = !isNaN(scope.minimumYaxis) ? Number(scope.minimumYaxis) : 10;\r\n                        var max = points && points.length ? Math.max(average * 1.5, d3.max(points), minimumYaxis) : 1;\r\n                        var numberOfPoints = points && points.length ? points.length : 2;\r\n\r\n                        var scaleY = d3.scaleLinear()\r\n                            .domain([0, max])\r\n                            .range([height - verticalMargin, verticalMargin]);\r\n\r\n                        var scaleX = d3.scaleLinear()\r\n                            .domain([0, numberOfPoints - 1])\r\n                            .range([horizontalMargin, width - horizontalMargin]);\r\n\r\n                        var area = d3.area()\r\n                            .x(function (d, i) {\r\n                                return scaleX(i);\r\n                            })\r\n                            .y(function (d, i) { return scaleY(d); })\r\n                            .y1(function (d) { return scaleY(0); }) \r\n                            .curve(d3.curveLinear);\r\n\r\n                        var line = d3.line()\r\n                            .x(function (d, i) {\r\n                                return scaleX(i);\r\n                            })\r\n                            .y(function(d, i) {\r\n                                return scaleY(d);\r\n                            })\r\n                            .curve(d3.curveLinear);\r\n\r\n                        var chart = d3.select(svg)\r\n                            .attr('width', width)\r\n                            .attr('height', height);\r\n\r\n                        chart.append('rect')\r\n                            .attr('width', width - 2 * horizontalMargin)\r\n                            .attr('height', height - 2 * verticalMargin)\r\n                            .attr('transform', 'translate(' + horizontalMargin + ',' + verticalMargin + ')')\r\n                            .attr('fill', '#F2F6F7');\r\n\r\n                        if (points) {\r\n                            chart.append('path')\r\n                                .datum(points)\r\n                                .attr('d', area)\r\n                                .attr('class', 'graph-data-fill');\r\n\r\n\r\n                            chart.append('path')\r\n                                .datum(points)\r\n                                .attr('d', line)\r\n                                .attr('class', 'graph-data-line');\r\n                        }\r\n\r\n                        chart.append('path')\r\n                            .datum(Array(numberOfPoints).fill(average))\r\n                            .attr('d', line)\r\n                            .attr('class', 'graph-avg-line');\r\n                    }\r\n                };\r\n            });\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/directives/ui.particular.graph.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///6\n"); /***/ }), -/* 6 */ + +/***/ 60: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n;\n(function (window, angular, $, undefined) {\n 'use strict';\n\n function Service($http, rx, scConfig, uri, $q) {\n\n function createEndpointsSource(historyPeriod, refreshInterval) {\n return Rx.Observable.interval(refreshInterval).startWith(0).flatMap(function (i) {\n return Rx.Observable.fromArray(loadEndpointDataFromMonitoringService(historyPeriod)).flatMap(function (p) {\n var o = Rx.Observable.fromPromise(p);\n o = o.catch(Rx.Observable.empty());\n return o;\n });\n }).selectMany(function (endpoints) {\n return endpoints;\n });\n }\n\n function loadEndpointDataFromMonitoringService(historyPeriod) {\n return scConfig.monitoring_urls.map(function (url) {\n return $http.get(uri.join(url, 'monitored-endpoints') + '?history=' + historyPeriod).then(function (result) {\n var sourceIndex = scConfig.monitoring_urls.indexOf(url);\n\n result.data.forEach(function (endpoint) {\n endpoint.sourceIndex = sourceIndex;\n });\n\n return result.data;\n });\n });\n }\n\n function loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod) {\n return $http.get(uri.join(scConfig.monitoring_urls[sourceIndex], 'monitored-endpoints', endpointName) + \"?history=\" + historyPeriod).then(function (result) {\n return result.data;\n }, function (error) {\n return { error: error };\n });\n }\n\n function createEndpointDetailsSource(endpointName, sourceIndex, historyPeriod, refreshInterval) {\n return Rx.Observable.interval(refreshInterval).startWith(0).flatMap(function (i) {\n return Rx.Observable.fromPromise(loadEndpointDetailsFromMonitoringService(endpointName, sourceIndex, historyPeriod));\n });\n }\n\n var service = {\n createEndpointsSource: createEndpointsSource,\n createEndpointDetailsSource: createEndpointDetailsSource\n };\n\n return service;\n }\n\n Service.$inject = ['$http', 'rx', 'scConfig', 'uri', '$q'];\n\n angular.module('services.monitoringService', ['sc']).service('monitoringService', Service);\n})(window, window.angular, window.jQuery);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL3NlcnZpY2VzL3NlcnZpY2VzLm1vbml0b3JpbmcuanM/ZmE2NSJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwiJCIsInVuZGVmaW5lZCIsIlNlcnZpY2UiLCIkaHR0cCIsInJ4Iiwic2NDb25maWciLCJ1cmkiLCIkcSIsImNyZWF0ZUVuZHBvaW50c1NvdXJjZSIsImhpc3RvcnlQZXJpb2QiLCJyZWZyZXNoSW50ZXJ2YWwiLCJSeCIsIk9ic2VydmFibGUiLCJpbnRlcnZhbCIsInN0YXJ0V2l0aCIsImZsYXRNYXAiLCJpIiwiZnJvbUFycmF5IiwibG9hZEVuZHBvaW50RGF0YUZyb21Nb25pdG9yaW5nU2VydmljZSIsInAiLCJvIiwiZnJvbVByb21pc2UiLCJjYXRjaCIsImVtcHR5Iiwic2VsZWN0TWFueSIsImVuZHBvaW50cyIsIm1vbml0b3JpbmdfdXJscyIsIm1hcCIsInVybCIsImdldCIsImpvaW4iLCJ0aGVuIiwicmVzdWx0Iiwic291cmNlSW5kZXgiLCJpbmRleE9mIiwiZGF0YSIsImZvckVhY2giLCJlbmRwb2ludCIsImxvYWRFbmRwb2ludERldGFpbHNGcm9tTW9uaXRvcmluZ1NlcnZpY2UiLCJlbmRwb2ludE5hbWUiLCJlcnJvciIsImNyZWF0ZUVuZHBvaW50RGV0YWlsc1NvdXJjZSIsInNlcnZpY2UiLCIkaW5qZWN0IiwibW9kdWxlIiwialF1ZXJ5Il0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0MsV0FBVUEsTUFBVixFQUFrQkMsT0FBbEIsRUFBMkJDLENBQTNCLEVBQThCQyxTQUE5QixFQUF5QztBQUN0Qzs7QUFFQSxhQUFTQyxPQUFULENBQWlCQyxLQUFqQixFQUF3QkMsRUFBeEIsRUFBNEJDLFFBQTVCLEVBQXNDQyxHQUF0QyxFQUEyQ0MsRUFBM0MsRUFBK0M7O0FBRTNDLGlCQUFTQyxxQkFBVCxDQUErQkMsYUFBL0IsRUFBOENDLGVBQTlDLEVBQStEO0FBQzNELG1C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QThEU0EsT0FBT0MsT0E5RGhCLEVBOER5QkQsT0FBTytDLE1BOURoQyxDQUFEIiwiZmlsZSI6IjYuanMiLCJzb3VyY2VzQ29udGVudCI6WyI7XHJcbihmdW5jdGlvbiAod2luZG93LCBhbmd1bGFyLCAkLCB1bmRlZmluZWQpIHtcclxuICAgICd1c2Ugc3RyaWN0JztcclxuXHJcbiAgICBmdW5jdGlvbiBTZXJ2aWNlKCRodHRwLCByeCwgc2NDb25maWcsIHVyaSwgJHEpIHtcclxuXHJcbiAgICAgICAgZnVuY3Rpb24gY3JlYXRlRW5kcG9pbnRzU291cmNlKGhpc3RvcnlQZXJpb2QsIHJlZnJlc2hJbnRlcnZhbCkge1xyXG4gICAgICAgICAgICByZXR1cm4gUnguT2JzZXJ2YWJsZS5pbnRlcnZhbChyZWZyZXNoSW50ZXJ2YWwpLnN0YXJ0V2l0aCgwKVxyXG4gICAgICAgICAgICAgICAgLmZsYXRNYXAoZnVuY3Rpb24gKGkpIHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gUnguT2JzZXJ2YWJsZS5mcm9tQXJyYXkobG9hZEVuZHBvaW50RGF0YUZyb21Nb25pdG9yaW5nU2VydmljZShoaXN0b3J5UGVyaW9kKSlcclxuICAgICAgICAgICAgICAgICAgICAgICAgLmZsYXRNYXAoZnVuY3Rpb24gKHApIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIHZhciBvID0gUnguT2JzZXJ2YWJsZS5mcm9tUHJvbWlzZShwKTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIG8gPSBvLmNhdGNoKFJ4Lk9ic2VydmFibGUuZW1wdHkoKSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICByZXR1cm4gbztcclxuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgICAgICB9KS5zZWxlY3RNYW55KGZ1bmN0aW9uIChlbmRwb2ludHMpIHtcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gZW5kcG9pbnRzO1xyXG4gICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBmdW5jdGlvbiBsb2FkRW5kcG9pbnREYXRhRnJvbU1vbml0b3JpbmdTZXJ2aWNlKGhpc3RvcnlQZXJpb2QpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHNjQ29uZmlnLm1vbml0b3JpbmdfdXJscy5tYXAoZnVuY3Rpb24gKHVybCkge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuICRodHRwLmdldCh1cmkuam9pbih1cmwsICdtb25pdG9yZWQtZW5kcG9pbnRzJykgKyAnP2hpc3Rvcnk9JyArIGhpc3RvcnlQZXJpb2QpXHJcbiAgICAgICAgICAgICAgICAgICAgLnRoZW4oZnVuY3Rpb24gKHJlc3VsdCkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB2YXIgc291cmNlSW5kZXggPSBzY0NvbmZpZy5tb25pdG9yaW5nX3VybHMuaW5kZXhPZih1cmwpO1xyXG5cclxuICAgICAgICAgICAgICAgICAgICAgICAgcmVzdWx0LmRhdGEuZm9yRWFjaChmdW5jdGlvbiAoZW5kcG9pbnQpIHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZHBvaW50LnNvdXJjZUluZGV4ID0gc291cmNlSW5kZXg7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xyXG5cclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHJlc3VsdC5kYXRhO1xyXG4gICAgICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGZ1bmN0aW9uIGxvYWRFbmRwb2ludERldGFpbHNGcm9tTW9uaXRvcmluZ1NlcnZpY2UoZW5kcG9pbnROYW1lLCBzb3VyY2VJbmRleCwgaGlzdG9yeVBlcmlvZCkge1xyXG4gICAgICAgICAgICByZXR1cm4gJGh0dHAuZ2V0KHVyaS5qb2luKHNjQ29uZmlnLm1vbml0b3JpbmdfdXJsc1tzb3VyY2VJbmRleF0sICdtb25pdG9yZWQtZW5kcG9pbnRzJywgZW5kcG9pbnROYW1lKSArIFwiP2hpc3Rvcnk9XCIgKyBoaXN0b3J5UGVyaW9kKVxyXG4gICAgICAgICAgICAgICAgLnRoZW4oZnVuY3Rpb24gKHJlc3VsdCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiByZXN1bHQuZGF0YTtcclxuICAgICAgICAgICAgICAgIH0sIGZ1bmN0aW9uIChlcnJvcikge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiB7IGVycm9yOiBlcnJvciB9O1xyXG4gICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICBmdW5jdGlvbiBjcmVhdGVFbmRwb2ludERldGFpbHNTb3VyY2UoZW5kcG9pbnROYW1lLCBzb3VyY2VJbmRleCwgaGlzdG9yeVBlcmlvZCwgcmVmcmVzaEludGVydmFsKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBSeC5PYnNlcnZhYmxlLmludGVydmFsKHJlZnJlc2hJbnRlcnZhbCkuc3RhcnRXaXRoKDApXHJcbiAgICAgICAgICAgICAgICAuZmxhdE1hcChmdW5jdGlvbiAoaSkge1xyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBSeC5PYnNlcnZhYmxlLmZyb21Qcm9taXNlKGxvYWRFbmRwb2ludERldGFpbHNGcm9tTW9uaXRvcmluZ1NlcnZpY2UoZW5kcG9pbnROYW1lLCBzb3VyY2VJbmRleCwgaGlzdG9yeVBlcmlvZCkpO1xyXG4gICAgICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB2YXIgc2VydmljZSA9IHtcclxuICAgICAgICAgICAgY3JlYXRlRW5kcG9pbnRzU291cmNlOiBjcmVhdGVFbmRwb2ludHNTb3VyY2UsXHJcbiAgICAgICAgICAgIGNyZWF0ZUVuZHBvaW50RGV0YWlsc1NvdXJjZTogY3JlYXRlRW5kcG9pbnREZXRhaWxzU291cmNlXHJcbiAgICAgICAgfTtcclxuXHJcbiAgICAgICAgcmV0dXJuIHNlcnZpY2U7XHJcbiAgICB9XHJcblxyXG4gICAgU2VydmljZS4kaW5qZWN0ID0gWyckaHR0cCcsICdyeCcsICdzY0NvbmZpZycsICd1cmknLCAnJHEnXTtcclxuXHJcbiAgICBhbmd1bGFyLm1vZHVsZSgnc2VydmljZXMubW9uaXRvcmluZ1NlcnZpY2UnLCBbJ3NjJ10pXHJcbiAgICAgICAgLnNlcnZpY2UoJ21vbml0b3JpbmdTZXJ2aWNlJywgU2VydmljZSk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhciwgd2luZG93LmpRdWVyeSkpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvc2VydmljZXMvc2VydmljZXMubW9uaXRvcmluZy5qcyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///6\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('endpoint_details', []);\n\n __webpack_require__(78);\n __webpack_require__(61);\n __webpack_require__(62);\n __webpack_require__(5);\n\n __webpack_require__(6);\n __webpack_require__(7);\n __webpack_require__(64);\n __webpack_require__(8);\n __webpack_require__(65);\n __webpack_require__(9);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2VuZHBvaW50X2RldGFpbHMubW9kdWxlLmpzPzRmMGIiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsInJlcXVpcmUiXSwibWFwcGluZ3MiOiI7O0FBQUMsV0FBU0EsTUFBVCxFQUFpQkMsT0FBakIsRUFBMEJDLFNBQTFCLEVBQXFDO0FBQ2xDOztBQUVBRCxZQUFRRSxNQUFSLENBQWUsa0JBQWYsRUFBbUMsRUFBbkM7O0FBRUFDLElBQUEsbUJBQUFBLENBQVEsRUFBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLEVBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxFQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjs7QUFFQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLEVBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsRUFBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDSCxDQWhCQSxFQWdCQ0osTUFoQkQsRUFnQlNBLE9BQU9DLE9BaEJoQixDQUFEIiwiZmlsZSI6IjYwLmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uKHdpbmRvdywgYW5ndWxhciwgdW5kZWZpbmVkKSB7XHJcbiAgICAndXNlIHN0cmljdCc7XHJcblxyXG4gICAgYW5ndWxhci5tb2R1bGUoJ2VuZHBvaW50X2RldGFpbHMnLCBbXSk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9zZXJ2aWNlcy9zZXJ2aWNlcy5jb25uZWN0aXZpdHlOb3RpZmllcicpO1xyXG4gICAgcmVxdWlyZSgnLi9lbmRwb2ludF9kZXRhaWxzLmNvbnRyb2xsZXInKTtcclxuICAgIHJlcXVpcmUoJy4vZW5kcG9pbnRfZGV0YWlscy5yb3V0ZS5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9jb25zdGFudC5kaWFncmFtcy5qcycpO1xyXG5cclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoLmpzJyk7XHJcbiAgICByZXF1aXJlKCcuL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGRlY2ltYWwuanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmR1cmF0aW9uLmpzJyk7XHJcbiAgICByZXF1aXJlKCcuL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGR1cmF0aW9uLmpzJyk7XHJcbiAgICByZXF1aXJlKCcuL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5sYXJnZUdyYXBoLmpzJyk7XHJcbiAgICByZXF1aXJlKCcuL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5tZXRyaWNzbGFyZ2VudW1iZXIuanMnKTtcclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vYXBwL21vZHVsZXMvbW9uaXRvcmluZy9qcy9lbmRwb2ludF9kZXRhaWxzLm1vZHVsZS5qcyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///60\n"); /***/ }), -/* 7 */ + +/***/ 61: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function controller($scope, $location, monitoringService, serviceControlService, toastService, historyPeriods, rx, $filter) {\n\n var subscription, endpointsFromScSubscription;\n\n $scope.periods = historyPeriods;\n $scope.selectedPeriod = $scope.periods[0];\n\n if ($location.$$search.historyPeriod) {\n $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\n return period.value == $location.$$search.historyPeriod;\n })];\n }\n\n $scope.endpoints = [];\n\n $scope.selectPeriod = function (period) {\n $scope.selectedPeriod = period;\n\n updateUI();\n };\n\n $scope.getDetailsUrl = function (endpoint) {\n if (!endpoint.isServiceControlOnly) {\n return '#/endpoint_details/' + endpoint.name + '/' + endpoint.sourceIndex + '?historyPeriod=' + $scope.selectedPeriod.value;\n }\n\n return '#/failed-messages/groups/' + endpoint.serviceControlId;\n };\n\n function fillDisplayValuesForEndpoint(endpoint) {\n\n $filter('graphduration')(endpoint.metrics.processingTime);\n $filter('graphduration')(endpoint.metrics.criticalTime);\n $filter('graphdecimal')(endpoint.metrics.queueLength, 0);\n $filter('graphdecimal')(endpoint.metrics.throughput, 2);\n $filter('graphdecimal')(endpoint.metrics.retries, 2);\n }\n\n function updateUI() {\n if (subscription) {\n subscription.dispose();\n }\n\n if (endpointsFromScSubscription) {\n endpointsFromScSubscription.dispose();\n }\n\n var selectedPeriod = $scope.selectedPeriod;\n\n subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\n var index = $scope.endpoints.findIndex(function (item) {\n return item.name === endpoint.name;\n });\n\n endpoint.isConnected = true;\n fillDisplayValuesForEndpoint(endpoint);\n if (index >= 0) {\n $scope.endpoints[index] = endpoint;\n } else {\n $scope.endpoints.push(endpoint);\n\n $scope.endpoints.sort(function (first, second) {\n if (first.name < second.name) {\n return -1;\n }\n\n if (first.name > second.name) {\n return 1;\n }\n\n return 0;\n });\n }\n\n $scope.$apply();\n });\n\n endpointsFromScSubscription = Rx.Observable.interval(5000).flatMap(function (i) {\n return Rx.Observable.fromPromise(serviceControlService.getExceptionGroups('Endpoint Name', null));\n }).selectMany(function (endpoints) {\n return endpoints.data;\n }).subscribe(function (endpoint) {\n var index = $scope.endpoints.findIndex(function (item) {\n return item.name === endpoint.title;\n });\n if (index >= 0) {\n $scope.endpoints[index].errorCount = endpoint.count;\n } else {\n $scope.endpoints.push({ name: endpoint.title, errorCount: endpoint.count, isConnected: false, isServiceControlOnly: true, serviceControlId: endpoint.id });\n }\n });\n }\n\n updateUI();\n\n $scope.$on(\"$destroy\", function handler() {\n subscription.dispose();\n endpointsFromScSubscription.dispose();\n });\n };\n\n controller.$inject = ['$scope', '$location', 'monitoringService', 'serviceControlService', 'toastService', 'historyPeriods', 'rx', '$filter'];\n\n angular.module('monitored_endpoints').controller('monitoredEndpointsCtrl', controller);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/monitored_endpoints.controller.js?06ce"],"names":["window","angular","undefined","controller","$scope","$location","monitoringService","serviceControlService","toastService","historyPeriods","rx","$filter","subscription","endpointsFromScSubscription","periods","selectedPeriod","$$search","historyPeriod","findIndex","period","value","endpoints","selectPeriod","updateUI","getDetailsUrl","endpoint","isServiceControlOnly","name","sourceIndex","serviceControlId","fillDisplayValuesForEndpoint","metrics","processingTime","criticalTime","queueLength","throughput","retries","dispose","createEndpointsSource","refreshInterval","subscribe","index","item","isConnected","push","sort","first","second","$apply","Rx","Observable","interval","flatMap","i","fromPromise","getExceptionGroups","selectMany","data","title","errorCount","count","id","$on","handler","$inject","module"],"mappings":"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","file":"7.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    function controller(\r\n        $scope,\r\n        $location,\r\n        monitoringService,\r\n        serviceControlService,\r\n        toastService,\r\n        historyPeriods,\r\n        rx,\r\n        $filter) {\r\n\r\n        var subscription, endpointsFromScSubscription;\r\n\r\n        $scope.periods = historyPeriods;\r\n        $scope.selectedPeriod = $scope.periods[0];\r\n\r\n        if ($location.$$search.historyPeriod) {\r\n            $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\r\n                return period.value == $location.$$search.historyPeriod;\r\n            })];\r\n        }\r\n\r\n        $scope.endpoints = [];\r\n\r\n        $scope.selectPeriod = function (period) {\r\n            $scope.selectedPeriod = period;\r\n\r\n            updateUI();\r\n        };\r\n\r\n        $scope.getDetailsUrl = endpoint => {\r\n            if (!endpoint.isServiceControlOnly) {\r\n                return '#/endpoint_details/' + endpoint.name + '/' + endpoint.sourceIndex + '?historyPeriod=' + $scope.selectedPeriod.value;\r\n            }\r\n\r\n            return '#/failed-messages/groups/' + endpoint.serviceControlId;\r\n        };\r\n\r\n        function fillDisplayValuesForEndpoint(endpoint) {\r\n\r\n            $filter('graphduration')(endpoint.metrics.processingTime);\r\n            $filter('graphduration')(endpoint.metrics.criticalTime);\r\n            $filter('graphdecimal')(endpoint.metrics.queueLength, 0);\r\n            $filter('graphdecimal')(endpoint.metrics.throughput, 2);\r\n            $filter('graphdecimal')(endpoint.metrics.retries, 2);\r\n        }\r\n\r\n        function updateUI() {\r\n            if (subscription) {\r\n                subscription.dispose();\r\n            }\r\n\r\n            if (endpointsFromScSubscription) {\r\n                endpointsFromScSubscription.dispose();\r\n            }\r\n\r\n            var selectedPeriod = $scope.selectedPeriod;\r\n\r\n            subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\r\n                var index = $scope.endpoints.findIndex(function (item) { return item.name === endpoint.name });\r\n\r\n                endpoint.isConnected = true;\r\n                fillDisplayValuesForEndpoint(endpoint);\r\n                if (index >= 0) {\r\n                    $scope.endpoints[index] = endpoint;\r\n                } else {\r\n                    $scope.endpoints.push(endpoint);\r\n\r\n                    $scope.endpoints.sort(function (first, second) {\r\n                        if (first.name < second.name) {\r\n                            return -1;\r\n                        }\r\n\r\n                        if (first.name > second.name) {\r\n                            return 1;\r\n                        }\r\n\r\n                        return 0;\r\n                    });\r\n                }\r\n\r\n                $scope.$apply();\r\n            });\r\n\r\n            endpointsFromScSubscription =\r\n                Rx.Observable.interval(5000)\r\n                .flatMap(function(i) {\r\n                    return Rx.Observable.fromPromise(serviceControlService.getExceptionGroups('Endpoint Name', null));\r\n                }).selectMany(function(endpoints) {\r\n                    return endpoints.data;\r\n                }).subscribe(function (endpoint) {\r\n                    var index = $scope.endpoints.findIndex(function(item) { return item.name === endpoint.title });\r\n                    if (index >= 0) {\r\n                        $scope.endpoints[index].errorCount = endpoint.count;\r\n                    } else {\r\n                        $scope.endpoints.push({ name: endpoint.title, errorCount: endpoint.count, isConnected: false, isServiceControlOnly: true, serviceControlId: endpoint.id });\r\n                    }\r\n                });\r\n        }\r\n\r\n        updateUI();\r\n\r\n        $scope.$on(\"$destroy\", function handler() {\r\n            subscription.dispose();\r\n            endpointsFromScSubscription.dispose();\r\n        });\r\n    };\r\n\r\n    controller.$inject = [\r\n        '$scope',\r\n        '$location',\r\n        'monitoringService',\r\n        'serviceControlService',\r\n        'toastService',\r\n        'historyPeriods',\r\n        'rx',\r\n        '$filter'\r\n    ];\r\n\r\n    angular.module('monitored_endpoints')\r\n        .controller('monitoredEndpointsCtrl', controller);\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/monitored_endpoints.controller.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///7\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function controller($scope, $routeParams, $location, toastService, serviceControlService, monitoringService, historyPeriods, $filter, smallGraphsMinimumYAxis, largeGraphsMinimumYAxis, connectivityNotifier) {\n\n $scope.endpointName = $routeParams.endpointName;\n $scope.sourceIndex = $routeParams.sourceIndex;\n $scope.loading = true;\n $scope.showInstancesBreakdown = false;\n $scope.largeGraphsMinimumYAxis = largeGraphsMinimumYAxis;\n $scope.smallGraphsMinimumYAxis = smallGraphsMinimumYAxis;\n\n var subscription;\n\n $scope.periods = historyPeriods;\n $scope.selectedPeriod = $scope.periods[0];\n\n if ($location.$$search.historyPeriod) {\n $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\n return period.value == $location.$$search.historyPeriod;\n })];\n }\n\n $scope.selectPeriod = function (period) {\n $scope.selectedPeriod = period;\n\n updateUI();\n };\n\n function updateUI() {\n if (subscription) {\n subscription.dispose();\n }\n\n var selectedPeriod = $scope.selectedPeriod;\n\n subscription = monitoringService.createEndpointDetailsSource($routeParams.endpointName, $routeParams.sourceIndex, selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\n if (endpoint.error) {\n connectivityNotifier.reportFailedConnection($routeParams.sourceIndex);\n if ($scope.endpoint && $scope.endpoint.instances) {\n $scope.endpoint.instances.forEach(function (item) {\n return item.isScMonitoringDisconnected = true;\n });\n }\n\n $scope.endpoint.isScMonitoringDisconnected = true;\n } else {\n connectivityNotifier.reportSuccessfulConnection($routeParams.sourceIndex);\n $scope.endpoint = endpoint;\n\n $scope.endpoint.instances.sort(function (first, second) {\n if (first.id < second.id) {\n return -1;\n }\n\n if (first.id > second.id) {\n return 1;\n }\n\n return 0;\n });\n\n $scope.loading = false;\n $scope.endpoint.messageTypes.forEach(function (messageType) {\n return fillDisplayValues(messageType);\n });\n\n $scope.endpoint.isStale = true;\n $scope.endpoint.isScMonitoringDisconnected = false;\n\n $scope.endpoint.instances.forEach(function (instance) {\n fillDisplayValues(instance);\n serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) {\n if (result.data.length > 0) {\n instance.serviceControlId = result.data[0].id;\n instance.errorCount = result.data[0].count;\n }\n }, function (err) {\n // Warn user?\n });\n $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale;\n });\n }\n\n serviceControlService.getExceptionGroupsForLogicalEndpoint($scope.endpointName).then(function (result) {\n if (result.data.length > 0) {\n $scope.endpoint.serviceControlId = result.data[0].id;\n $scope.endpoint.errorCount = result.data[0].count;\n }\n });\n });\n }\n\n function fillDisplayValues(instance) {\n $filter('graphduration')(instance.metrics.processingTime);\n $filter('graphduration')(instance.metrics.criticalTime);\n $filter('graphdecimal')(instance.metrics.throughput, 2);\n $filter('graphdecimal')(instance.metrics.retries, 2);\n }\n\n $scope.$on(\"$destroy\", function handler() {\n subscription.dispose();\n });\n\n updateUI();\n }\n\n controller.$inject = ['$scope', '$routeParams', '$location', 'toastService', 'serviceControlService', 'monitoringService', 'historyPeriods', '$filter', 'smallGraphsMinimumYAxis', 'largeGraphsMinimumYAxis', 'connectivityNotifier'];\n\n angular.module('endpoint_details').controller('endpointDetailsCtrl', controller);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/endpoint_details.controller.js?df84"],"names":["window","angular","undefined","controller","$scope","$routeParams","$location","toastService","serviceControlService","monitoringService","historyPeriods","$filter","smallGraphsMinimumYAxis","largeGraphsMinimumYAxis","connectivityNotifier","endpointName","sourceIndex","loading","showInstancesBreakdown","subscription","periods","selectedPeriod","$$search","historyPeriod","findIndex","period","value","selectPeriod","updateUI","dispose","createEndpointDetailsSource","refreshInterval","subscribe","endpoint","error","reportFailedConnection","instances","forEach","item","isScMonitoringDisconnected","reportSuccessfulConnection","sort","first","second","id","messageTypes","messageType","fillDisplayValues","isStale","instance","getExceptionGroupsForEndpointInstance","then","result","data","length","serviceControlId","errorCount","count","err","getExceptionGroupsForLogicalEndpoint","metrics","processingTime","criticalTime","throughput","retries","$on","handler","$inject","module"],"mappings":"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","file":"61.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    function controller(\r\n        $scope,\r\n        $routeParams,\r\n        $location,\r\n        toastService,\r\n        serviceControlService,\r\n        monitoringService,\r\n        historyPeriods,\r\n        $filter,\r\n        smallGraphsMinimumYAxis,\r\n        largeGraphsMinimumYAxis,\r\n        connectivityNotifier\r\n    ) {\r\n\r\n        $scope.endpointName = $routeParams.endpointName;\r\n        $scope.sourceIndex = $routeParams.sourceIndex;\r\n        $scope.loading = true;\r\n        $scope.showInstancesBreakdown = false;\r\n        $scope.largeGraphsMinimumYAxis = largeGraphsMinimumYAxis;\r\n        $scope.smallGraphsMinimumYAxis = smallGraphsMinimumYAxis;\r\n\r\n        var subscription;\r\n\r\n        $scope.periods = historyPeriods;\r\n        $scope.selectedPeriod = $scope.periods[0];\r\n\r\n        if ($location.$$search.historyPeriod) {\r\n            $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\r\n                return period.value == $location.$$search.historyPeriod;\r\n            })];\r\n        }\r\n\r\n        $scope.selectPeriod = function (period) {\r\n            $scope.selectedPeriod = period;\r\n\r\n            updateUI();\r\n        };\r\n\r\n        function updateUI() {\r\n            if (subscription) {\r\n                subscription.dispose();\r\n            }\r\n\r\n            var selectedPeriod = $scope.selectedPeriod;\r\n\r\n            subscription = monitoringService.createEndpointDetailsSource($routeParams.endpointName, $routeParams.sourceIndex, selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\r\n                if (endpoint.error) {\r\n                    connectivityNotifier.reportFailedConnection($routeParams.sourceIndex);\r\n                    if ($scope.endpoint && $scope.endpoint.instances) {\r\n                        $scope.endpoint.instances.forEach((item) => item.isScMonitoringDisconnected = true);\r\n                    }\r\n\r\n                    $scope.endpoint.isScMonitoringDisconnected = true;\r\n\r\n                } else {\r\n                    connectivityNotifier.reportSuccessfulConnection($routeParams.sourceIndex);\r\n                    $scope.endpoint = endpoint;\r\n\r\n                    $scope.endpoint.instances.sort(function (first, second) {\r\n                        if (first.id < second.id) {\r\n                            return -1;\r\n                        }\r\n\r\n                        if (first.id > second.id) {\r\n                            return 1;\r\n                        }\r\n\r\n                        return 0;\r\n                    });\r\n\r\n                    $scope.loading = false;\r\n                    $scope.endpoint.messageTypes.forEach((messageType) => fillDisplayValues(messageType));\r\n\r\n                    $scope.endpoint.isStale = true;\r\n                    $scope.endpoint.isScMonitoringDisconnected = false;\r\n\r\n                    $scope.endpoint.instances.forEach(function (instance) {\r\n                        fillDisplayValues(instance);\r\n                        serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) {\r\n                            if (result.data.length > 0) {\r\n                                instance.serviceControlId = result.data[0].id;\r\n                                instance.errorCount = result.data[0].count;\r\n                            }\r\n                        }, function (err) {\r\n                            // Warn user?\r\n                    });\r\n                        $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale;\r\n                    });\r\n                }\r\n\r\n                serviceControlService.getExceptionGroupsForLogicalEndpoint($scope.endpointName).then(function(result) {\r\n                    if (result.data.length > 0) {\r\n                        $scope.endpoint.serviceControlId = result.data[0].id;\r\n                        $scope.endpoint.errorCount = result.data[0].count;\r\n                    }\r\n                });\r\n            });\r\n        }\r\n\r\n        function fillDisplayValues(instance) {\r\n            $filter('graphduration')(instance.metrics.processingTime);\r\n            $filter('graphduration')(instance.metrics.criticalTime);\r\n            $filter('graphdecimal')(instance.metrics.throughput, 2);\r\n            $filter('graphdecimal')(instance.metrics.retries, 2);\r\n        }\r\n\r\n        $scope.$on(\"$destroy\", function handler() {\r\n            subscription.dispose();\r\n        });\r\n\r\n        updateUI();\r\n    }\r\n\r\n    controller.$inject = [\r\n        '$scope',\r\n        '$routeParams',\r\n        '$location',\r\n        'toastService',\r\n        'serviceControlService',\r\n        'monitoringService',\r\n        'historyPeriods',\r\n        '$filter',\r\n        'smallGraphsMinimumYAxis',\r\n        'largeGraphsMinimumYAxis',\r\n        'connectivityNotifier'\r\n    ];\r\n\r\n    angular.module('endpoint_details')\r\n        .controller('endpointDetailsCtrl', controller);\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/endpoint_details.controller.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///61\n"); /***/ }), -/* 8 */ + +/***/ 62: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function routeProvider($routeProvider) {\n var template = __webpack_require__(9);\n\n $routeProvider.when('/monitored_endpoints', {\n data: {\n pageTitle: 'Monitored Endpoints'\n },\n template: template,\n controller: 'monitoredEndpointsCtrl',\n controllerAs: 'vm',\n reloadOnSearch: false\n });\n };\n\n routeProvider.$inject = ['$routeProvider'];\n\n angular.module('monitored_endpoints').config(routeProvider);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL21vbml0b3JlZF9lbmRwb2ludHMucm91dGUuanM/MjcwNiJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwicm91dGVQcm92aWRlciIsIiRyb3V0ZVByb3ZpZGVyIiwidGVtcGxhdGUiLCJyZXF1aXJlIiwid2hlbiIsImRhdGEiLCJwYWdlVGl0bGUiLCJjb250cm9sbGVyIiwiY29udHJvbGxlckFzIiwicmVsb2FkT25TZWFyY2giLCIkaW5qZWN0IiwibW9kdWxlIiwiY29uZmlnIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQSxhQUFTQyxhQUFULENBQXVCQyxjQUF2QixFQUF1QztBQUNuQyxZQUFJQyxXQUFXLG1CQUFBQyxDQUFRLENBQVIsQ0FBZjs7QUFFQUYsdUJBQWVHLElBQWYsQ0FBb0Isc0JBQXBCLEVBQTRDO0FBQ3hDQyxrQkFBTTtBQUNGQywyQkFBVztBQURULGFBRGtDO0FBSXhDSixzQkFBVUEsUUFKOEI7QUFLeENLLHdCQUFZLHdCQUw0QjtBQU14Q0MsMEJBQWMsSUFOMEI7QUFPeENDLDRCQUFnQjtBQVB3QixTQUE1QztBQVNIOztBQUVEVCxrQkFBY1UsT0FBZCxHQUF3QixDQUNwQixnQkFEb0IsQ0FBeEI7O0FBSUFaLFlBQVFhLE1BQVIsQ0FBZSxxQkFBZixFQUNLQyxNQURMLENBQ1laLGFBRFo7QUFFSCxDQXZCQSxFQXVCRUgsTUF2QkYsRUF1QlVBLE9BQU9DLE9BdkJqQixDQUFEIiwiZmlsZSI6IjguanMiLCJzb3VyY2VzQ29udGVudCI6WyIoZnVuY3Rpb24gKHdpbmRvdywgYW5ndWxhciwgdW5kZWZpbmVkKSB7XHJcbiAgICAndXNlIHN0cmljdCc7XHJcblxyXG4gICAgZnVuY3Rpb24gcm91dGVQcm92aWRlcigkcm91dGVQcm92aWRlcikge1xyXG4gICAgICAgIGxldCB0ZW1wbGF0ZSA9IHJlcXVpcmUoJy4vLi4vdmlld3MvbW9uaXRvcmVkX2VuZHBvaW50cy5odG1sJyk7XHJcblxyXG4gICAgICAgICRyb3V0ZVByb3ZpZGVyLndoZW4oJy9tb25pdG9yZWRfZW5kcG9pbnRzJywge1xyXG4gICAgICAgICAgICBkYXRhOiB7XHJcbiAgICAgICAgICAgICAgICBwYWdlVGl0bGU6ICdNb25pdG9yZWQgRW5kcG9pbnRzJ1xyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgICAgICB0ZW1wbGF0ZTogdGVtcGxhdGUsXHJcbiAgICAgICAgICAgIGNvbnRyb2xsZXI6ICdtb25pdG9yZWRFbmRwb2ludHNDdHJsJyxcclxuICAgICAgICAgICAgY29udHJvbGxlckFzOiAndm0nLFxyXG4gICAgICAgICAgICByZWxvYWRPblNlYXJjaDogZmFsc2VcclxuICAgICAgICB9KTtcclxuICAgIH07XHJcblxyXG4gICAgcm91dGVQcm92aWRlci4kaW5qZWN0ID0gW1xyXG4gICAgICAgICckcm91dGVQcm92aWRlcidcclxuICAgIF07XHJcblxyXG4gICAgYW5ndWxhci5tb2R1bGUoJ21vbml0b3JlZF9lbmRwb2ludHMnKVxyXG4gICAgICAgIC5jb25maWcocm91dGVQcm92aWRlcik7XHJcbn0gKHdpbmRvdywgd2luZG93LmFuZ3VsYXIpKTtcblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL21vbml0b3JlZF9lbmRwb2ludHMucm91dGUuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function routeProvider($routeProvider) {\n var template = __webpack_require__(63);\n\n $routeProvider.when('/endpoint_details/:endpointName/:sourceIndex', {\n data: {\n pageTitle: 'Endpoint Details'\n },\n template: template,\n controller: 'endpointDetailsCtrl',\n controllerAs: 'vm',\n reloadOnSearch: false\n });\n };\n\n routeProvider.$inject = ['$routeProvider'];\n\n angular.module('endpoint_details').config(routeProvider);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2VuZHBvaW50X2RldGFpbHMucm91dGUuanM/NjViNiJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwicm91dGVQcm92aWRlciIsIiRyb3V0ZVByb3ZpZGVyIiwidGVtcGxhdGUiLCJyZXF1aXJlIiwid2hlbiIsImRhdGEiLCJwYWdlVGl0bGUiLCJjb250cm9sbGVyIiwiY29udHJvbGxlckFzIiwicmVsb2FkT25TZWFyY2giLCIkaW5qZWN0IiwibW9kdWxlIiwiY29uZmlnIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQSxhQUFTQyxhQUFULENBQXVCQyxjQUF2QixFQUF1QztBQUNuQyxZQUFJQyxXQUFXLG1CQUFBQyxDQUFRLEVBQVIsQ0FBZjs7QUFFQUYsdUJBQWVHLElBQWYsQ0FBb0IsOENBQXBCLEVBQW9FO0FBQ2hFQyxrQkFBTTtBQUNGQywyQkFBVztBQURULGFBRDBEO0FBSWhFSixzQkFBVUEsUUFKc0Q7QUFLaEVLLHdCQUFZLHFCQUxvRDtBQU1oRUMsMEJBQWMsSUFOa0Q7QUFPaEVDLDRCQUFnQjtBQVBnRCxTQUFwRTtBQVNIOztBQUVEVCxrQkFBY1UsT0FBZCxHQUF3QixDQUNwQixnQkFEb0IsQ0FBeEI7O0FBSUFaLFlBQVFhLE1BQVIsQ0FBZSxrQkFBZixFQUNLQyxNQURMLENBQ1laLGFBRFo7QUFFSCxDQXZCQSxFQXVCRUgsTUF2QkYsRUF1QlVBLE9BQU9DLE9BdkJqQixDQUFEIiwiZmlsZSI6IjYyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGZ1bmN0aW9uIHJvdXRlUHJvdmlkZXIoJHJvdXRlUHJvdmlkZXIpIHtcclxuICAgICAgICBsZXQgdGVtcGxhdGUgPSByZXF1aXJlKCcuLy4uL3ZpZXdzL2VuZHBvaW50X2RldGFpbHMuaHRtbCcpO1xyXG5cclxuICAgICAgICAkcm91dGVQcm92aWRlci53aGVuKCcvZW5kcG9pbnRfZGV0YWlscy86ZW5kcG9pbnROYW1lLzpzb3VyY2VJbmRleCcsIHtcclxuICAgICAgICAgICAgZGF0YToge1xyXG4gICAgICAgICAgICAgICAgcGFnZVRpdGxlOiAnRW5kcG9pbnQgRGV0YWlscydcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgdGVtcGxhdGU6IHRlbXBsYXRlLFxyXG4gICAgICAgICAgICBjb250cm9sbGVyOiAnZW5kcG9pbnREZXRhaWxzQ3RybCcsXHJcbiAgICAgICAgICAgIGNvbnRyb2xsZXJBczogJ3ZtJyxcclxuICAgICAgICAgICAgcmVsb2FkT25TZWFyY2g6IGZhbHNlXHJcbiAgICAgICAgfSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJvdXRlUHJvdmlkZXIuJGluamVjdCA9IFtcclxuICAgICAgICAnJHJvdXRlUHJvdmlkZXInXHJcbiAgICBdO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCdlbmRwb2ludF9kZXRhaWxzJylcclxuICAgICAgICAuY29uZmlnKHJvdXRlUHJvdmlkZXIpO1xyXG59ICh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vYXBwL21vZHVsZXMvbW9uaXRvcmluZy9qcy9lbmRwb2ludF9kZXRhaWxzLnJvdXRlLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///62\n"); /***/ }), -/* 9 */ + +/***/ 63: /***/ (function(module, exports) { -eval("module.exports = \"

Endpoints overview

\";//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/views/monitored_endpoints.html?3a87"],"names":[],"mappings":"AAAA,kdAAkd,qBAAqB,iLAAiL,cAAc,KAAK,aAAa,olFAAolF,yBAAyB,6HAA6H,eAAe,mGAAmG,qCAAqC,mWAAmW,0CAA0C,2UAA2U,qEAAqE,gdAAgd,oEAAoE,0cAA0c,iEAAiE,ydAAyd,8EAA8E,iCAAiC,mDAAmD,2dAA2d,4EAA4E,iCAAiC,iDAAiD","file":"9.js","sourcesContent":["module.exports = \"<div class=container ng-show=endpoints.length> <div class=\\\"row monitoring-head\\\"> <div class=\\\"col-sm-10 no-side-padding list-section\\\"> <h1>Endpoints overview</h1> </div> <div class=\\\"col-sm-2 no-side-padding toolbar-menus\\\"> <div class=\\\"msg-group-menu dropdown\\\"> <label class=control-label>Period:</label> <button type=button class=\\\"btn btn-default dropdown-toggle sp-btn-menu\\\" data-toggle=dropdown aria-haspopup=true aria-expanded=false> {{selectedPeriod.text}} <span class=caret></span> </button> <ul class=dropdown-menu> <li ng-repeat=\\\"period in periods\\\"> <a ng-click=selectPeriod(period) href=\\\"#/monitored_endpoints?historyPeriod={{period.value}}\\\">{{period.text}}</a> </li> </ul> </div> </div> </div> </div> <div class=container> <section ng-show=true> <div class=\\\"text-center monitoring-no-data\\\" ng-show=!endpoints.length> <h1>No endpoints available for monitoring</h1> <p>Ensure that your endpoints have auditing enabled and/or have the metrics plug-in enabled</p> <div class=action-toolbar> <a class=\\\"btn btn-default btn-primary\\\" href=\\\"https://www.google.com/search?site=&source=hp&q=metrics+%2Fsite%3Adocs.particular.net&oq=metrics+%2Fsite%3Adocs.particular.net\\\">Learn more</a> </div> </div> <div ng-show=endpoints.length class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-7\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> <p>Name</p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Queue length (# msgs): The estimated number of messages in an endpoint's queue.\\\"> <p>Queue Length <span>(msgs)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" uib-tooltip=\\\"Throughput (# msgs/s): The number of messages per second successfully processed by a receiving endpoint.\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <p>Throughput <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate (# msgs/s): The number of messages per second scheduled for retries (immediate or delayed).\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <p>Scheduled retry rate <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" uib-tooltip=\\\"Processing time (t): The time taken for a receiving endpoint to successfully process a message.\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <p>Processing Time <span>(t)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" uib-tooltip=\\\"Critical time (t): The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <p>Critical Time <span>(t)</span></p> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row box-group\\\" ng-repeat=\\\"endpoint in endpoints\\\" ng-mouseenter=\\\"endpoint.hover1=true\\\" ng-mouseleave=\\\"endpoint.hover1=false\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <a class=\\\"hard-wrap lead\\\" ng-click=\\\"endpoint.isExpanded = !endpoint.isExpanded\\\" ng-href={{getDetailsUrl(endpoint)}}> <div class=\\\"col-sm-2 col-xl-7 endpoint-name\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> {{endpoint.name}} <span ng-if=\\\"endpoint.endpointInstanceIds.length && endpoint.endpointInstanceIds.length > 1\\\">({{endpoint.endpointInstanceIds.length}})</span> <div class=endpoint-status> <span class=warning ng-if=endpoint.isStale> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> <span class=warning ng-if=endpoint.errorCount> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{endpoint.errorCount | metricslargenumber}}</span> </span> </div> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.queueLength class=\\\"graph queue-length pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{endpoint.isStale ? \\\"\\\" : endpoint.metrics.queueLength.displayValue}} <i ng-if=endpoint.isStale class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.throughput class=\\\"graph throughput pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{endpoint.isStale ? \\\"\\\" : endpoint.metrics.throughput.displayValue}} <i ng-if=endpoint.isStale class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.retries class=\\\"graph retries pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{endpoint.isStale ? \\\"\\\" : endpoint.metrics.retries.displayValue}} <i ng-if=endpoint.isStale class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.processingTime class=\\\"graph processing-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{endpoint.isStale ? \\\"\\\" : endpoint.metrics.processingTime.displayValue.value}} <span ng-if=!endpoint.isStale>{{endpoint.metrics.processingTime.displayValue.unit}}</span><i ng-if=endpoint.isStale class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=endpoint.isConnected> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=endpoint.metrics.criticalTime class=\\\"graph critical-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{endpoint.isStale ? \\\"\\\" : endpoint.metrics.criticalTime.displayValue.value}} <span ng-if=!endpoint.isStale>{{endpoint.metrics.criticalTime.displayValue.unit}}</span> <i ng-if=endpoint.isStale class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\" ng-if=!endpoint.isConnected> <div class=\\\"row box-header\\\"> No plug-ins installed. </div> </div> </a> </div> </div> </div> </div> </div> </section> </div> \";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./app/modules/monitoring/views/monitored_endpoints.html\n// module id = 9\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///9\n"); - +eval("module.exports = \"
Queue Length

Queue length: The estimated number of messages in an endpoint's queue.

NOTE: This is an experimental feature. Learn more

{{endpoint.digest.metrics.queueLength.latest | metricslargenumber:0}} MSGS
?
{{endpoint.digest.metrics.queueLength.average | metricslargenumber:0}} MSGS
? AVG
Throughput
{{endpoint.digest.metrics.throughput.latest | metricslargenumber:2}} MSGS/S
?
{{endpoint.digest.metrics.throughput.average | metricslargenumber:2}} MSGS/S
? AVG
Scheduled Retries Rate
{{endpoint.digest.metrics.retries.latest | metricslargenumber:2}} MSGS/S
?
{{endpoint.digest.metrics.retries.average | metricslargenumber:2}} MSGS/S
? AVG
Processing Time
{{endpoint.digest.metrics.processingTime.latest | durationValue}} {{endpoint.digest.metrics.processingTime.latest | durationUnit}}
?
{{endpoint.digest.metrics.processingTime.average | durationValue}} {{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG
? AVG
Critical Time
{{endpoint.digest.metrics.criticalTime.latest | durationValue}} {{endpoint.digest.metrics.criticalTime.latest | durationUnit}}
?
{{endpoint.digest.metrics.criticalTime.average | durationValue}} {{endpoint.digest.metrics.criticalTime.average | durationUnit}}
? AVG
Instance Name
Throughput (msgs/s)
Scheduled retry rate (msgs/s)
Processing Time (t)
Critical Time (t)
{{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.throughput.displayValue}} ?
{{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.retries.displayValue}} ?
{{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.processingTime.displayValue.value}} {{instance.metrics.processingTime.displayValue.unit}} ?
{{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.criticalTime.displayValue.value}} {{instance.metrics.criticalTime.displayValue.unit}} ?
Message type name
Throughput (msgs/s)
Scheduled retry rate (msgs/s)
Processing Time (t)
Critical Time (t)
{{messageType.typeName ? messageType.typeName : 'Unknown'}}
{{messageType.assemblyName + '-' + messageType.assemblyVersion}}
{{'Culture=' + messageType.culture}}
{{'PublicKeyToken=' + messageType.publicKeyToken}}
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.throughput.displayValue}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.retries.displayValue}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.processingTime.displayValue.value}} {{messageType.metrics.processingTime.displayValue.unit}} ?
{{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.criticalTime.displayValue.value}} {{messageType.metrics.criticalTime.displayValue.unit}} ?
\";//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/views/endpoint_details.html?e863"],"names":[],"mappings":"AAAA,+IAA+I,8HAA8H,cAAc,wbAAwb,cAAc,GAAG,aAAa,GAAG,2BAA2B,sFAAsF,0CAA0C,oTAAoT,qBAAqB,gKAAgK,cAAc,GAAG,aAAa,iBAAiB,cAAc,KAAK,aAAa,gaAAga,qCAAqC,81BAA81B,mEAAmE,uXAAuX,oEAAoE,wpBAAwpB,2CAA2C,+nBAA+nB,kEAAkE,qSAAqS,mEAAmE,wsBAAwsB,+DAA+D,qSAAqS,gEAAgE,8qBAA8qB,4CAA4C,8pBAA8pB,+DAA+D,0CAA0C,8DAA8D,uPAAuP,gEAAgE,0CAA0C,+DAA+D,iqBAAiqB,6DAA6D,0CAA0C,4DAA4D,uPAAuP,8DAA8D,0CAA0C,6DAA6D,8YAA8Y,gCAAgC,4GAA4G,+BAA+B,wiEAAwiE,eAAe,mgBAAmgB,cAAc,GAAG,aAAa,GAAG,2BAA2B,sFAAsF,0CAA0C,oNAAoN,oCAAoC,wGAAwG,6HAA6H,kRAAkR,iCAAiC,qGAAqG,0HAA0H,yRAAyR,wCAAwC,6GAA6G,uIAAuI,6FAA6F,mDAAmD,8RAA8R,sCAAsC,2GAA2G,qIAAqI,6FAA6F,iDAAiD,2qEAA2qE,yDAAyD,6DAA6D,wDAAwD,6BAA6B,8DAA8D,wBAAwB,sDAAsD,6BAA6B,kCAAkC,wBAAwB,oEAAoE,6BAA6B,gDAAgD,ojBAAojB,2BAA2B,sFAAsF,0CAA0C,uNAAuN,oCAAoC,wGAAwG,gIAAgI,qRAAqR,iCAAiC,qGAAqG,6HAA6H,4RAA4R,wCAAwC,6GAA6G,0IAA0I,6FAA6F,sDAAsD,iSAAiS,sCAAsC,2GAA2G,wIAAwI,6FAA6F,oDAAoD","file":"63.js","sourcesContent":["module.exports = \"<div class=container> <div class=\\\"row monitoring-head\\\"> <div class=back-nav> <span class=fake-link aria-hidden=true>&#9664;</span> <a href=/#/monitored_endpoints>All endpoints</a> </div> <div class=\\\"col-sm-10 no-side-padding list-section\\\"> <h1> {{endpointName}} <div class=endpoint-status> <span ng-if=endpoint.isStale class=warning> <i class=\\\"fa pa-endpoint-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to endpoint\\\"></i> </span> <span class=warning ng-if=endpoint.isScMonitoringDisconnected> <i class=\\\"fa pa-monitoring-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to monitoring server\\\"></i> </span> <a ng-if=endpoint.errorCount class=warning href=#/failed-messages/groups/{{endpointName}}/{{sourceIndex}}/{{endpoint.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{endpoint.errorCount | metricslargenumber}}</span> </a> </div> </h1> </div> <div class=\\\"col-sm-2 no-side-padding toolbar-menus\\\"> <div class=\\\"msg-group-menu dropdown\\\"> <label class=control-label>Period:</label> <button type=button class=\\\"btn btn-default dropdown-toggle sp-btn-menu\\\" data-toggle=dropdown aria-haspopup=true aria-expanded=false> {{selectedPeriod.text}} <span class=caret></span> </button> <ul class=dropdown-menu> <li ng-repeat=\\\"period in periods\\\"> <a ng-click=selectPeriod(period) href=\\\"#/endpoint_details/{{endpointName}}/{{sourceIndex}}?historyPeriod={{period.value}}\\\">{{period.text}}</a> </li> </ul> </div> </div> </div> </div> <div class=\\\"container large-graphs\\\"> <div class=container> <div class=row> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-queue-length\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.queueLength first-data-series=endpoint.metricDetails.metrics.queueLength xaxis-points=endpoint.metricDetails.metrics.queueLength.timeAxisValues minimum-yaxis={{largeGraphsMinimumYAxis.queueLength}} plot-width=750 plot-height=200 first-series-color=#EA7E00 first-series-fill-color=#EADDCE class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"row queue-length-values tooltip-trigger\\\"> <div class=metric-digest-header> Queue Length <i class=\\\"fa fa-flask fake-link\\\"></i> </div> <div class=interactive-tooltip> <div class=tooltip-contents> <p>Queue length: The estimated number of messages in an endpoint's queue.</p> <p>NOTE: This is an experimental feature. <a href=\\\"https://docs.particular.net/search?q=nservicebus+queue+length+metric+%2bexperimental\\\" target=_blank>Learn more</a> <i class=\\\"fa fa-external-link fake-link\\\"></i></p> </div> </div> </div> <div class=\\\"row metric-digest-value current\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.queueLength.latest | metricslargenumber:0}} <span ng-if=\\\"endpoint.isStale == false || endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix>MSGS</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> <div class=\\\"row metric-digest-value average\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.queueLength.average | metricslargenumber:0}} <span class=metric-digest-value-suffix>MSGS</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix> AVG</span> </div> </div> </div> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-message-retries-throughputs\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.throughput first-data-series=endpoint.metricDetails.metrics.throughput second-data-series=endpoint.metricDetails.metrics.retries xaxis-points=endpoint.metricDetails.metrics.throughput.timeAxisValues minimum-yaxis={{largeGraphsMinimumYAxis.throughputRetries}} plot-width=750 plot-height=200 first-series-color=#176397 first-series-fill-color=#CADCE8 second-series-color=#CC1252 second-series-fill-color=#E9C4D1 class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"col-sm-6 no-side-padding throughput-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Throughput: The number of messages per second successfully processed by a receiving endpoint.\\\"> Throughput </span> </div> <div class=\\\"row metric-digest-value current\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.throughput.latest | metricslargenumber:2}} <span class=metric-digest-value-suffix>MSGS/S</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> <div class=\\\"row metric-digest-value average\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.throughput.average | metricslargenumber:2}} <span class=metric-digest-value-suffix>MSGS/S</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix> AVG</span> </div> </div> <div class=\\\"col-sm-6 no-side-padding scheduled-retries-rate-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Scheduled retry rate: The number of messages per second scheduled for retries (immediate or delayed).\\\"> Scheduled Retries Rate </span> </div> <div class=\\\"row metric-digest-value current\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.retries.latest | metricslargenumber:2}} <span class=metric-digest-value-suffix>MSGS/S</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> <div class=\\\"row metric-digest-value average\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.retries.average | metricslargenumber:2}} <span class=metric-digest-value-suffix>MSGS/S</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix> AVG</span> </div> </div> </div> </div> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-critical-processing-times\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.processingTime first-data-series=endpoint.metricDetails.metrics.criticalTime second-data-series=endpoint.metricDetails.metrics.processingTime xaxis-points=endpoint.metricDetails.metrics.criticalTime.timeAxisValues minimum-yaxis={{largeGraphsMinimumYAxis.processingCritical}} plot-width=750 plot-height=200 first-series-color=#2700CB first-series-fill-color=#C4BCE5 second-series-color=#258135 second-series-fill-color=#BEE6C5 is-duration-graph=true class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"col-sm-6 no-side-padding processing-time-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Processing time: The time taken for a receiving endpoint to successfully process a message.\\\"> Processing Time </span> </div> <div class=\\\"row metric-digest-value current\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.processingTime.latest | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.processingTime.latest | durationUnit}}</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> <div class=\\\"row metric-digest-value average\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.processingTime.average | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix> AVG</span> </div> </div> <div class=\\\"col-sm-6 no-side-padding critical-time-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Critical time: The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> Critical Time </span> </div> <div class=\\\"row metric-digest-value current\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.criticalTime.latest | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.criticalTime.latest | durationUnit}}</span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> <div class=\\\"row metric-digest-value average\\\"> <div ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\"> {{endpoint.digest.metrics.criticalTime.average | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.criticalTime.average | durationUnit}} </span> </div> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> <span ng-if=\\\"endpoint.isStale == false && endpoint.isScMonitoringDisconnected == false\\\" class=metric-digest-value-suffix> AVG</span> </div> </div> </div> </div> </div> </div> </div> <div class=container> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div class=tabs> <h5 ng-class=\\\"{active: !showInstancesBreakdown}\\\"> <a ng-click=\\\"showInstancesBreakdown = false\\\" class=ng-binding>Message Types</a> </h5> <h5 ng-class=\\\"{active: showInstancesBreakdown}\\\"> <a ng-click=\\\"showInstancesBreakdown = true\\\" class=ng-binding>Instances</a> </h5> </div> <section ng-if=showInstancesBreakdown class=endpoint-instances> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div ng-show=!loading class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-8\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> Instance Name </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Throughput: The number of messages per second successfully processed by a receiving endpoint.\\\"> Throughput <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate: The number of messages per second scheduled for retries (immediate or delayed).\\\"> Scheduled retry rate <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Processing time: The time taken for a receiving endpoint to successfully process a message.\\\"> Processing Time <span class=table-header-unit>(t)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Critical time: The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> Critical Time <span class=table-header-unit>(t)</span> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row\\\" ng-repeat=\\\"instance in endpoint.instances\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <div class=\\\"col-sm-2 col-xl-8 endpoint-name\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-lg-max-9 no-side-padding lead\\\"> {{instance.name}} </div> <div class=\\\"col-lg-4 endpoint-status\\\"> <span class=warning ng-if=instance.isScMonitoringDisconnected> <i class=\\\"fa pa-monitoring-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to monitoring server\\\"></i> </span> <span class=warning ng-if=instance.isStale> <i class=\\\"fa pa-endpoint-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to instance\\\"></i> </span> <span class=warning ng-if=instance.errorCount> <a ng-if=instance.errorCount class=\\\"warning btn\\\" href=#/failed-messages/groups/{{endpointName}}/{{sourceIndex}}/{{instance.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{instance.errorCount | metricslargenumber}}</span> </a> </span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.throughput minimum-yaxis={{smallGraphsMinimumYAxis.throughput}} class=\\\"graph throughput pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.throughput.displayValue}} <strong ng-if=\\\"instance.isStale || instance.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.retries minimum-yaxis={{smallGraphsMinimumYAxis.retries}} class=\\\"graph retries pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.retries.displayValue}} <strong ng-if=\\\"instance.isStale || instance.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.processingTime minimum-yaxis={{smallGraphsMinimumYAxis.processingTime}} class=\\\"graph processing-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.processingTime.displayValue.value}} <span ng-if=\\\"instance.isStale == false || instance.isScMonitoringDisconnected == false\\\">{{instance.metrics.processingTime.displayValue.unit}}</span> <strong ng-if=\\\"instance.isStale || instance.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.criticalTime minimum-yaxis={{smallGraphsMinimumYAxis.criticalTime}} class=\\\"graph critical-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? \\\"\\\" : instance.metrics.criticalTime.displayValue.value}} <span ng-if=\\\"instance.isStale == false || instance.isScMonitoringDisconnected == false\\\">{{instance.metrics.criticalTime.displayValue.unit}}</span> <strong ng-if=\\\"instance.isStale || instance.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </section> <section ng-if=!showInstancesBreakdown class=endpoint-message-types> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div ng-show=!loading class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-8\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> Message type name </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Throughput: The number of messages per second successfully processed by a receiving endpoint.\\\"> Throughput <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate: The number of messages per second scheduled for retries (immediate or delayed).\\\"> Scheduled retry rate <span class=table-header-unit>(msgs/s)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Processing time: The time taken for a receiving endpoint to successfully process a message.\\\"> Processing Time <span class=table-header-unit>(t)</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Critical time: The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> Critical Time <span class=table-header-unit>(t)</span> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row\\\" ng-repeat=\\\"messageType in endpoint.messageTypes\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <div class=\\\"col-sm-2 col-xl-8 endpoint-name\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-lg-max-9 no-side-padding lead message-type-label\\\"> <div class=lead> {{messageType.typeName ? messageType.typeName : 'Unknown'}} </div> <div class=message-type-properties> <div ng-show=\\\"{{messageType.typeName && messageType.typeName != 'null'}}\\\" class=message-type-part>{{messageType.assemblyName + '-' + messageType.assemblyVersion}}</div> <div ng-show=\\\"{{messageType.culture && messageType.culture != 'null'}}\\\" class=message-type-part>{{'Culture=' + messageType.culture}}</div> <div ng-show=\\\"{{messageType.publicKeyToken && messageType.publicKeyToken != 'null'}}\\\" class=message-type-part>{{'PublicKeyToken=' + messageType.publicKeyToken}}</div> </div> </div> <div class=\\\"col-lg-4 no-side-padding endpoint-status message-type-status\\\"> <span class=warning ng-if=endpoint.isScMonitoringDisconnected> <i class=\\\"fa pa-monitoring-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to monitoring server\\\"></i> </span> <span class=warning ng-if=endpoint.isStale> <i class=\\\"fa pa-endpoint-lost endpoint-details\\\" uib-tooltip=\\\"Unable to connect to instance\\\"></i> </span> <span class=warning ng-if=endpoint.errorCount> <a ng-if=endpoint.errorCount class=\\\"warning btn\\\" href=#/failed-messages/groups/{{endpoint.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{endpoint.errorCount | metricslargenumber}}</span> </a> </span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.throughput minimum-yaxis={{smallGraphsMinimumYAxis.throughput}} class=\\\"graph throughput pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.throughput.displayValue}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.retries minimum-yaxis={{smallGraphsMinimumYAxis.retries}} class=\\\"graph retries pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.retries.displayValue}} <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.processingTime minimum-yaxis={{smallGraphsMinimumYAxis.processingTime}} class=\\\"graph processing-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.processingTime.displayValue.value}} <span ng-if=\\\"instance.isStale == false || instance.isScMonitoringDisconnected == false\\\">{{messageType.metrics.processingTime.displayValue.unit}}</span> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.criticalTime minimum-yaxis={{smallGraphsMinimumYAxis.criticalTime}} class=\\\"graph critical-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? \\\"\\\" : messageType.metrics.criticalTime.displayValue.value}} <span ng-if=\\\"instance.isStale == false || instance.isScMonitoringDisconnected == false\\\">{{messageType.metrics.criticalTime.displayValue.unit}}</span> <strong ng-if=\\\"endpoint.isStale || endpoint.isScMonitoringDisconnected\\\">?</strong> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </section> </div>\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./app/modules/monitoring/views/endpoint_details.html\n// module id = 63\n// module chunks = 1"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///63\n"); + /***/ }), -/* 10 */ + +/***/ 64: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('endpoint_details', []);\n\n __webpack_require__(11);\n __webpack_require__(12);\n\n __webpack_require__(0);\n __webpack_require__(1);\n __webpack_require__(14);\n __webpack_require__(2);\n __webpack_require__(15);\n __webpack_require__(3);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2VuZHBvaW50X2RldGFpbHMubW9kdWxlLmpzPzRmMGIiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsInJlcXVpcmUiXSwibWFwcGluZ3MiOiI7O0FBQUMsV0FBU0EsTUFBVCxFQUFpQkMsT0FBakIsRUFBMEJDLFNBQTFCLEVBQXFDO0FBQ2xDOztBQUVBRCxZQUFRRSxNQUFSLENBQWUsa0JBQWYsRUFBbUMsRUFBbkM7O0FBRUFDLElBQUEsbUJBQUFBLENBQVEsRUFBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLEVBQVI7O0FBRUFBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLENBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxFQUFSO0FBQ0FBLElBQUEsbUJBQUFBLENBQVEsQ0FBUjtBQUNBQSxJQUFBLG1CQUFBQSxDQUFRLEVBQVI7QUFDQUEsSUFBQSxtQkFBQUEsQ0FBUSxDQUFSO0FBQ0gsQ0FkQSxFQWNDSixNQWRELEVBY1NBLE9BQU9DLE9BZGhCLENBQUQiLCJmaWxlIjoiMTAuanMiLCJzb3VyY2VzQ29udGVudCI6WyIoZnVuY3Rpb24od2luZG93LCBhbmd1bGFyLCB1bmRlZmluZWQpIHtcclxuICAgICd1c2Ugc3RyaWN0JztcclxuXHJcbiAgICBhbmd1bGFyLm1vZHVsZSgnZW5kcG9pbnRfZGV0YWlscycsIFtdKTtcclxuXHJcbiAgICByZXF1aXJlKCcuL2VuZHBvaW50X2RldGFpbHMuY29udHJvbGxlcicpO1xyXG4gICAgcmVxdWlyZSgnLi9lbmRwb2ludF9kZXRhaWxzLnJvdXRlLmpzJyk7XHJcblxyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZ3JhcGguanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZGVjaW1hbC5qcycpO1xyXG4gICAgcmVxdWlyZSgnLi9kaXJlY3RpdmVzL3VpLnBhcnRpY3VsYXIuZHVyYXRpb24uanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZHVyYXRpb24uanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmxhcmdlR3JhcGguanMnKTtcclxuICAgIHJlcXVpcmUoJy4vZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLm1ldHJpY3NsYXJnZW51bWJlci5qcycpO1xyXG59KHdpbmRvdywgd2luZG93LmFuZ3VsYXIpKTtcblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2VuZHBvaW50X2RldGFpbHMubW9kdWxlLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///10\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.duration', []).filter('duration', ['formatter', function (formatter) {\n return function (input) {\n var time = formatter.formatTime(input);\n return time.value + ' ' + time.unit;\n };\n }]).filter('durationValue', ['formatter', function (formatter) {\n return function (input) {\n return formatter.formatTime(input).value;\n };\n }]).filter('durationUnit', ['formatter', function (formatter) {\n return function (input) {\n return formatter.formatTime(input).unit;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5kdXJhdGlvbi5qcz85YjhlIl0sIm5hbWVzIjpbIndpbmRvdyIsImFuZ3VsYXIiLCJ1bmRlZmluZWQiLCJtb2R1bGUiLCJmaWx0ZXIiLCJmb3JtYXR0ZXIiLCJpbnB1dCIsInRpbWUiLCJmb3JtYXRUaW1lIiwidmFsdWUiLCJ1bml0Il0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQUQsWUFBUUUsTUFBUixDQUFlLHdCQUFmLEVBQXlDLEVBQXpDLEVBQ0tDLE1BREwsQ0FDWSxVQURaLEVBQ3dCLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDbkQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCO0FBQ3BCLGdCQUFJQyxPQUFPRixVQUFVRyxVQUFWLENBQXFCRixLQUFyQixDQUFYO0FBQ0EsbUJBQVVDLEtBQUtFLEtBQWYsU0FBd0JGLEtBQUtHLElBQTdCO0FBQ0gsU0FIRDtBQUlILEtBTG1CLENBRHhCLEVBT0tOLE1BUEwsQ0FPWSxlQVBaLEVBTzZCLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDeEQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCO0FBQ3BCLG1CQUFPRCxVQUFVRyxVQUFWLENBQXFCRixLQUFyQixFQUE0QkcsS0FBbkM7QUFDSCxTQUZEO0FBR0gsS0FKd0IsQ0FQN0IsRUFZS0wsTUFaTCxDQVlZLGNBWlosRUFZNEIsQ0FBQyxXQUFELEVBQWMsVUFBVUMsU0FBVixFQUFxQjtBQUN2RCxlQUFPLFVBQVVDLEtBQVYsRUFBaUI7QUFDcEIsbUJBQU9ELFVBQVVHLFVBQVYsQ0FBcUJGLEtBQXJCLEVBQTRCSSxJQUFuQztBQUNILFNBRkQ7QUFHSCxLQUp1QixDQVo1QjtBQWlCSCxDQXBCQSxFQW9CQ1YsTUFwQkQsRUFvQlNBLE9BQU9DLE9BcEJoQixDQUFEIiwiZmlsZSI6IjY0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCd1aS5wYXJ0aWN1bGFyLmR1cmF0aW9uJywgW10pXHJcbiAgICAgICAgLmZpbHRlcignZHVyYXRpb24nLCBbJ2Zvcm1hdHRlcicsIGZ1bmN0aW9uIChmb3JtYXR0ZXIpIHtcclxuICAgICAgICAgICAgcmV0dXJuIGZ1bmN0aW9uIChpbnB1dCkge1xyXG4gICAgICAgICAgICAgICAgdmFyIHRpbWUgPSBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCk7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gYCR7dGltZS52YWx1ZX0gJHt0aW1lLnVuaXR9YDtcclxuICAgICAgICAgICAgfTtcclxuICAgICAgICB9XSlcclxuICAgICAgICAuZmlsdGVyKCdkdXJhdGlvblZhbHVlJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCkudmFsdWU7XHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgfV0pXHJcbiAgICAgICAgLmZpbHRlcignZHVyYXRpb25Vbml0JywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCkudW5pdDtcclxuICAgICAgICAgICAgfTtcclxuICAgICAgICB9XSk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhcikpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmR1cmF0aW9uLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///64\n"); /***/ }), -/* 11 */ + +/***/ 65: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function controller($scope, $routeParams, $location, toastService, serviceControlService, monitoringService, historyPeriods, $filter) {\n\n $scope.endpointName = $routeParams.endpointName;\n $scope.sourceIndex = $routeParams.sourceIndex;\n $scope.loading = true;\n $scope.showInstancesBreakdown = false;\n\n var subscription;\n\n $scope.periods = historyPeriods;\n $scope.selectedPeriod = $scope.periods[0];\n\n if ($location.$$search.historyPeriod) {\n $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\n return period.value == $location.$$search.historyPeriod;\n })];\n }\n\n $scope.selectPeriod = function (period) {\n $scope.selectedPeriod = period;\n\n updateUI();\n };\n\n function updateUI() {\n if (subscription) {\n subscription.dispose();\n }\n\n var selectedPeriod = $scope.selectedPeriod;\n\n subscription = monitoringService.createEndpointDetailsSource($routeParams.endpointName, $routeParams.sourceIndex, selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\n if (endpoint.error) {\n toastService.showWarning('Could not load endpoint details');\n } else {\n $scope.endpoint = endpoint;\n\n $scope.endpoint.instances.sort(function (first, second) {\n if (first.id < second.id) {\n return -1;\n }\n\n if (first.id > second.id) {\n return 1;\n }\n\n return 0;\n });\n\n $scope.loading = false;\n }\n\n $scope.endpoint.messageTypes.forEach(function (messageType) {\n return fillDisplayValues(messageType);\n });\n\n $scope.endpoint.isStale = true;\n\n $scope.endpoint.instances.forEach(function (instance) {\n fillDisplayValues(instance);\n serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) {\n if (result.data.length > 0) {\n instance.serviceControlId = result.data[0].id;\n instance.errorCount = result.data[0].count;\n }\n }, function (err) {\n // Warn user?\n });\n\n $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale;\n });\n });\n }\n\n function fillDisplayValues(instance) {\n $filter('graphduration')(instance.metrics.processingTime);\n $filter('graphduration')(instance.metrics.criticalTime);\n $filter('graphdecimal')(instance.metrics.throughput, 2);\n $filter('graphdecimal')(instance.metrics.retries, 2);\n }\n\n $scope.$on(\"$destroy\", function handler() {\n subscription.dispose();\n });\n\n updateUI();\n }\n\n controller.$inject = ['$scope', '$routeParams', '$location', 'toastService', 'serviceControlService', 'monitoringService', 'historyPeriods', '$filter'];\n\n angular.module('endpoint_details').controller('endpointDetailsCtrl', controller);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/endpoint_details.controller.js?df84"],"names":["window","angular","undefined","controller","$scope","$routeParams","$location","toastService","serviceControlService","monitoringService","historyPeriods","$filter","endpointName","sourceIndex","loading","showInstancesBreakdown","subscription","periods","selectedPeriod","$$search","historyPeriod","findIndex","period","value","selectPeriod","updateUI","dispose","createEndpointDetailsSource","refreshInterval","subscribe","endpoint","error","showWarning","instances","sort","first","second","id","messageTypes","forEach","messageType","fillDisplayValues","isStale","instance","getExceptionGroupsForEndpointInstance","then","result","data","length","serviceControlId","errorCount","count","err","metrics","processingTime","criticalTime","throughput","retries","$on","handler","$inject","module"],"mappings":";;AAAC,WAASA,MAAT,EAAiBC,OAAjB,EAA0BC,SAA1B,EAAqC;AAClC;;AAEA,aAASC,UAAT,CACIC,MADJ,EAEIC,YAFJ,EAGIC,SAHJ,EAIIC,YAJJ,EAKIC,qBALJ,EAMIC,iBANJ,EAOIC,cAPJ,EAQIC,OARJ,EAQa;;AAETP,eAAOQ,YAAP,GAAsBP,aAAaO,YAAnC;AACAR,eAAOS,WAAP,GAAqBR,aAAaQ,WAAlC;AACAT,eAAOU,OAAP,GAAiB,IAAjB;AACAV,eAAOW,sBAAP,GAAgC,KAAhC;;AAEA,YAAIC,YAAJ;;AAEAZ,eAAOa,OAAP,GAAiBP,cAAjB;AACAN,eAAOc,cAAP,GAAwBd,OAAOa,OAAP,CAAe,CAAf,CAAxB;;AAEA,YAAIX,UAAUa,QAAV,CAAmBC,aAAvB,EAAsC;AAClChB,mBAAOc,cAAP,GAAwBd,OAAOa,OAAP,CAAeb,OAAOa,OAAP,CAAeI,SAAf,CAAyB,UAAUC,MAAV,EAAkB;AAC9E,uBAAOA,OAAOC,KAAP,IAAgBjB,UAAUa,QAAV,CAAmBC,aAA1C;AACH,aAFsC,CAAf,CAAxB;AAGH;;AAEDhB,eAAOoB,YAAP,GAAsB,UAAUF,MAAV,EAAkB;AACpClB,mBAAOc,cAAP,GAAwBI,MAAxB;;AAEAG;AACH,SAJD;;AAMA,iBAASA,QAAT,GAAoB;AAChB,gBAAIT,YAAJ,EAAkB;AACdA,6BAAaU,OAAb;AACH;;AAED,gBAAIR,iBAAiBd,OAAOc,cAA5B;;AAEAF,2BAAeP,kBAAkBkB,2BAAlB,CAA8CtB,aAAaO,YAA3D,EAAyEP,aAAaQ,WAAtF,EAAmGK,eAAeK,KAAlH,EAAyHL,eAAeU,eAAxI,EAAyJC,SAAzJ,CAAmK,UAAUC,QAAV,EAAoB;AAClM,oBAAIA,SAASC,KAAb,EAAoB;AAChBxB,iCAAayB,WAAb,CAAyB,iCAAzB;AACH,iBAFD,MAEO;AACH5B,2BAAO0B,QAAP,GAAkBA,QAAlB;;AAEA1B,2BAAO0B,QAAP,CAAgBG,SAAhB,CAA0BC,IAA1B,CAA+B,UAAUC,KAAV,EAAiBC,MAAjB,EAAyB;AACpD,4BAAID,MAAME,EAAN,GAAWD,OAAOC,EAAtB,EAA0B;AACtB,mCAAO,CAAC,CAAR;AACH;;AAED,4BAAIF,MAAME,EAAN,GAAWD,OAAOC,EAAtB,EAA0B;AACtB,mCAAO,CAAP;AACH;;AAED,+BAAO,CAAP;AACH,qBAVD;;AAYAjC,2BAAOU,OAAP,GAAiB,KAAjB;AACH;;AAEDV,uBAAO0B,QAAP,CAAgBQ,YAAhB,CAA6BC,OAA7B,CAAsC,UAACC,WAAD;AAAA,2BAAiBC,kBAAkBD,WAAlB,CAAjB;AAAA,iBAAtC;;AAEApC,uBAAO0B,QAAP,CAAgBY,OAAhB,GAA0B,IAA1B;;AAEAtC,uBAAO0B,QAAP,CAAgBG,SAAhB,CAA0BM,OAA1B,CAAkC,UAAUI,QAAV,EAAoB;AAClDF,sCAAkBE,QAAlB;AACAnC,0CAAsBoC,qCAAtB,CAA4DD,SAASN,EAArE,EAAyEQ,IAAzE,CAA8E,UAAUC,MAAV,EAAkB;AAC5F,4BAAIA,OAAOC,IAAP,CAAYC,MAAZ,GAAqB,CAAzB,EAA4B;AACxBL,qCAASM,gBAAT,GAA4BH,OAAOC,IAAP,CAAY,CAAZ,EAAeV,EAA3C;AACAM,qCAASO,UAAT,GAAsBJ,OAAOC,IAAP,CAAY,CAAZ,EAAeI,KAArC;AACH;AACJ,qBALD,EAKG,UAAUC,GAAV,EAAe;AACd;AACC,qBAPL;;AASAhD,2BAAO0B,QAAP,CAAgBY,OAAhB,GAA0BtC,OAAO0B,QAAP,CAAgBY,OAAhB,IAA2BC,SAASD,OAA9D;AACH,iBAZD;AAaH,aAtCc,CAAf;AAuCH;;AAED,iBAASD,iBAAT,CAA2BE,QAA3B,EAAqC;AACjChC,oBAAQ,eAAR,EAAyBgC,SAASU,OAAT,CAAiBC,cAA1C;AACA3C,oBAAQ,eAAR,EAAyBgC,SAASU,OAAT,CAAiBE,YAA1C;AACA5C,oBAAQ,cAAR,EAAwBgC,SAASU,OAAT,CAAiBG,UAAzC,EAAqD,CAArD;AACA7C,oBAAQ,cAAR,EAAwBgC,SAASU,OAAT,CAAiBI,OAAzC,EAAkD,CAAlD;AACH;;AAEDrD,eAAOsD,GAAP,CAAW,UAAX,EAAuB,SAASC,OAAT,GAAmB;AACtC3C,yBAAaU,OAAb;AACH,SAFD;;AAIAD;AACH;;AAEDtB,eAAWyD,OAAX,GAAqB,CACjB,QADiB,EAEjB,cAFiB,EAGjB,WAHiB,EAIjB,cAJiB,EAKjB,uBALiB,EAMjB,mBANiB,EAOjB,gBAPiB,EAQjB,SARiB,CAArB;;AAWA3D,YAAQ4D,MAAR,CAAe,kBAAf,EACK1D,UADL,CACgB,qBADhB,EACuCA,UADvC;AAGH,CA/GA,EA+GCH,MA/GD,EA+GSA,OAAOC,OA/GhB,CAAD","file":"11.js","sourcesContent":["(function(window, angular, undefined) {\r\n    'use strict';\r\n\r\n    function controller(\r\n        $scope,\r\n        $routeParams,\r\n        $location,\r\n        toastService,\r\n        serviceControlService,\r\n        monitoringService,\r\n        historyPeriods,\r\n        $filter) {\r\n\r\n        $scope.endpointName = $routeParams.endpointName;\r\n        $scope.sourceIndex = $routeParams.sourceIndex;\r\n        $scope.loading = true;\r\n        $scope.showInstancesBreakdown = false;\r\n\r\n        var subscription;\r\n\r\n        $scope.periods = historyPeriods;\r\n        $scope.selectedPeriod = $scope.periods[0];\r\n\r\n        if ($location.$$search.historyPeriod) {\r\n            $scope.selectedPeriod = $scope.periods[$scope.periods.findIndex(function (period) {\r\n                return period.value == $location.$$search.historyPeriod;\r\n            })];\r\n        }\r\n\r\n        $scope.selectPeriod = function (period) {\r\n            $scope.selectedPeriod = period;\r\n\r\n            updateUI();\r\n        };\r\n\r\n        function updateUI() {\r\n            if (subscription) {\r\n                subscription.dispose();\r\n            }\r\n\r\n            var selectedPeriod = $scope.selectedPeriod;\r\n\r\n            subscription = monitoringService.createEndpointDetailsSource($routeParams.endpointName, $routeParams.sourceIndex, selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) {\r\n                if (endpoint.error) {\r\n                    toastService.showWarning('Could not load endpoint details');\r\n                } else {\r\n                    $scope.endpoint = endpoint;\r\n\r\n                    $scope.endpoint.instances.sort(function (first, second) {\r\n                        if (first.id < second.id) {\r\n                            return -1;\r\n                        }\r\n\r\n                        if (first.id > second.id) {\r\n                            return 1;\r\n                        }\r\n\r\n                        return 0;\r\n                    });\r\n\r\n                    $scope.loading = false;\r\n                }\r\n                \r\n                $scope.endpoint.messageTypes.forEach( (messageType) => fillDisplayValues(messageType));\r\n\r\n                $scope.endpoint.isStale = true;\r\n\r\n                $scope.endpoint.instances.forEach(function (instance) {\r\n                    fillDisplayValues(instance);\r\n                    serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) {\r\n                        if (result.data.length > 0) {\r\n                            instance.serviceControlId = result.data[0].id;\r\n                            instance.errorCount = result.data[0].count;\r\n                        }\r\n                    }, function (err) {\r\n                        // Warn user?\r\n                        });\r\n\r\n                    $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale;\r\n                });\r\n            });\r\n        }\r\n\r\n        function fillDisplayValues(instance) {\r\n            $filter('graphduration')(instance.metrics.processingTime);\r\n            $filter('graphduration')(instance.metrics.criticalTime);\r\n            $filter('graphdecimal')(instance.metrics.throughput, 2);\r\n            $filter('graphdecimal')(instance.metrics.retries, 2);\r\n        }\r\n\r\n        $scope.$on(\"$destroy\", function handler() {\r\n            subscription.dispose();\r\n        });\r\n\r\n        updateUI();\r\n    }\r\n\r\n    controller.$inject = [\r\n        '$scope',\r\n        '$routeParams',\r\n        '$location',\r\n        'toastService',\r\n        'serviceControlService',\r\n        'monitoringService',\r\n        'historyPeriods',\r\n        '$filter'\r\n    ];\r\n\r\n    angular.module('endpoint_details')\r\n        .controller('endpointDetailsCtrl', controller);\r\n\r\n}(window, window.angular));\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/endpoint_details.controller.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///11\n"); +eval("\n\n(function (window, angular) {\n 'use strict';\n\n function drawDataSeries(chart, data, color, fillColor, scaleX, scaleY) {\n\n var area = d3.area().x(function (d, i) {\n return scaleX(i);\n }).y(function (d) {\n return scaleY(d);\n }).y1(function () {\n return scaleY(0);\n }).curve(d3.curveLinear);\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var group = chart.append('g').attr('class', 'dataSeries');\n\n group.append('path').datum(data.points).attr('d', area).attr('fill', fillColor).attr('opacity', 0.8).attr('stroke', fillColor);\n\n group.append('path').datum(data.points).attr('d', line).attr('stroke', color).attr('stroke-width', 2.75).attr('fill', 'none');\n }\n\n function drawAverageLine(chart, data, color, fillColor, scaleX, scaleY) {\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var group = chart.append('g').attr('class', 'dataAverage');\n\n group.append('path').datum(Array(data.points.length).fill(data.average)).attr('d', line).attr('stroke', color).attr('stroke-width', 1.5).attr('opacity', 0.5).attr('stroke-dasharray', '10,10');\n }\n\n function padToWholeValue(value) {\n var emptyDataSetyAxisMax = 10;\n\n if (!value) {\n return emptyDataSetyAxisMax;\n }\n\n var upperBound = 10;\n\n while (value > upperBound) {\n upperBound *= 10;\n }\n\n upperBound /= 10;\n\n return Math.floor(value / upperBound) * upperBound + upperBound;\n }\n\n angular.module('ui.particular.largeGraph', []).directive('largeGraph', function (formatter) {\n return {\n restrict: 'E',\n scope: {\n dates: '=xaxisPoints',\n firstDataSeries: '=firstDataSeries',\n secondDataSeries: '=secondDataSeries',\n isDurationGraph: '=isDurationGraph',\n minimumYaxis: '@',\n width: '=plotWidth',\n height: '=plotHeight'\n },\n template: '',\n link: function link(scope, element, attrs) {\n scope.$watch('firstDataSeries', function () {\n\n var svg = element.find('svg')[0];\n\n d3.select(svg).selectAll('*').remove();\n\n var topMargin = 10;\n var bottomMargin = 5;\n var leftMargin = 60;\n\n var chart = d3.select(svg).attr('width', scope.width).attr('height', scope.height);\n\n var width = svg.clientWidth;\n var height = svg.clientHeight;\n\n //HINT: This is workaround for Firefox\n if (width === 0) {\n var box = svg.getBoundingClientRect();\n\n width = box.right - box.left;\n height = box.bottom - box.top;\n }\n\n var firstSeries = scope.firstDataSeries;\n var secondSeries = scope.secondDataSeries;\n\n var scaleX = d3.scaleLinear().domain([0, firstSeries.points.length - 1]).range([leftMargin, width]);\n\n chart.append('rect').attr('width', width - leftMargin).attr('height', height - topMargin - bottomMargin).attr('transform', 'translate(' + leftMargin + ',' + topMargin + ')').attr('fill', '#F2F6F7');\n\n var minimumYaxis = !isNaN(scope.minimumYaxis) ? Number(scope.minimumYaxis) : 10;\n var max = Math.max(firstSeries.average, d3.max(firstSeries.points), minimumYaxis);\n\n if (secondSeries && secondSeries.points.length > 0) {\n max = Math.max(max, secondSeries.average, d3.max(secondSeries.points));\n }\n\n var max = padToWholeValue(max);\n\n var scaleY = d3.scaleLinear().domain([0, max]).range([height - bottomMargin, topMargin]);\n\n var yAxis = d3.axisLeft(scaleY).tickValues([0, max * 1 / 4, max * 1 / 2, max * 3 / 4, max]);\n\n if (scope.isDurationGraph) {\n yAxis = yAxis.tickFormat(function (v) {\n var formattedTime = formatter.formatTime(v);\n\n return formattedTime.value + ' ' + formattedTime.unit;\n });\n }\n\n chart.append('g').attr('class', 'y axis').attr('transform', 'translate(' + leftMargin + ', 0)').call(function (g) {\n g.call(yAxis);\n g.select('.domain').remove();\n g.selectAll('.tick line').attr('stroke', 'black').attr('stroke-width', '1.75').attr('opacity', 0.1).attr('x', 0).attr('x2', width - leftMargin);\n g.selectAll('.tick text').attr('x', -4).attr('fill', '#828282');\n });\n\n var drawSeries = function drawSeries(data, lineColor, fillColor) {\n drawDataSeries(chart, data, lineColor, fillColor, scaleX, scaleY);\n };\n\n var drawAverage = function drawAverage(data, lineColor, fillColor) {\n drawAverageLine(chart, data, lineColor, fillColor, scaleX, scaleY);\n };\n\n drawSeries(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\n\n if (secondSeries) {\n drawSeries(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\n }\n\n drawAverage(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\n\n if (secondSeries) {\n drawAverage(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\n }\n });\n }\n };\n });\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/directives/ui.particular.largeGraph.js?070b"],"names":["window","angular","drawDataSeries","chart","data","color","fillColor","scaleX","scaleY","area","d3","x","d","i","y","y1","curve","curveLinear","line","group","append","attr","datum","points","drawAverageLine","Array","length","fill","average","padToWholeValue","value","emptyDataSetyAxisMax","upperBound","Math","floor","module","directive","formatter","restrict","scope","dates","firstDataSeries","secondDataSeries","isDurationGraph","minimumYaxis","width","height","template","link","element","attrs","$watch","svg","find","select","selectAll","remove","topMargin","bottomMargin","leftMargin","clientWidth","clientHeight","box","getBoundingClientRect","right","left","bottom","top","firstSeries","secondSeries","scaleLinear","domain","range","isNaN","Number","max","yAxis","axisLeft","tickValues","tickFormat","v","formattedTime","formatTime","unit","call","g","drawSeries","lineColor","drawAverage","firstSeriesColor","firstSeriesFillColor","secondSeriesColor","secondSeriesFillColor"],"mappings":"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","file":"65.js","sourcesContent":["(function(window, angular) {\r\n    'use strict';\r\n\r\n    function drawDataSeries(chart, data, color, fillColor, scaleX, scaleY) {\r\n\r\n        var area = d3.area()\r\n            .x(function (d, i) { return scaleX(i);})\r\n            .y(function (d)    { return scaleY(d); })\r\n            .y1(function ()    { return scaleY(0); })\r\n            .curve(d3.curveLinear);\r\n\r\n        var line = d3.line()\r\n            .x(function (d, i) { return scaleX(i);})\r\n            .y(function (d, i) { return scaleY(d);})\r\n            .curve(d3.curveLinear);\r\n\r\n        var group = chart.append('g').attr('class', 'dataSeries');\r\n\r\n        group.append('path')\r\n            .datum(data.points)\r\n            .attr('d', area)\r\n            .attr('fill', fillColor)\r\n            .attr('opacity', 0.8)\r\n            .attr('stroke', fillColor);\r\n\r\n        group.append('path')\r\n            .datum(data.points)\r\n            .attr('d', line)\r\n            .attr('stroke', color)\r\n            .attr('stroke-width', 2.75)\r\n            .attr('fill', 'none');\r\n    }\r\n\r\n    function drawAverageLine(chart, data, color, fillColor, scaleX, scaleY) {\r\n\r\n        var line = d3.line()\r\n            .x(function (d, i) { return scaleX(i); })\r\n            .y(function (d, i) { return scaleY(d); })\r\n            .curve(d3.curveLinear);\r\n\r\n        var group = chart.append('g').attr('class', 'dataAverage');\r\n\r\n        group.append('path')\r\n            .datum(Array(data.points.length).fill(data.average))\r\n            .attr('d', line)\r\n            .attr('stroke', color)\r\n            .attr('stroke-width', 1.5)\r\n            .attr('opacity', 0.5)\r\n            .attr('stroke-dasharray', '10,10');\r\n    }\r\n\r\n    function padToWholeValue(value) {\r\n        var emptyDataSetyAxisMax = 10;\r\n\r\n        if (!value) {\r\n            return emptyDataSetyAxisMax;\r\n        }\r\n\r\n        var upperBound = 10;\r\n\r\n        while (value > upperBound) {\r\n            upperBound *= 10;\r\n        }\r\n\r\n        upperBound /= 10;\r\n\r\n        return Math.floor(value / upperBound) * upperBound + upperBound;\r\n    }\r\n\r\n    angular.module('ui.particular.largeGraph', [])\r\n        .directive('largeGraph',\r\n            function(formatter) {\r\n                return {\r\n                    restrict: 'E',\r\n                    scope: {                        \r\n                        dates: '=xaxisPoints',\r\n                        firstDataSeries: '=firstDataSeries',\r\n                        secondDataSeries: '=secondDataSeries',\r\n                        isDurationGraph: '=isDurationGraph',\r\n                        minimumYaxis: '@',\r\n                        width: '=plotWidth',\r\n                        height: '=plotHeight'\r\n                    },\r\n                    template: '<svg></svg>',\r\n                    link: function link(scope, element, attrs) {\r\n                        scope.$watch('firstDataSeries', function () {\r\n\r\n                            var svg = element.find('svg')[0];\r\n\r\n                            d3.select(svg).selectAll('*').remove();\r\n\r\n                            var topMargin = 10;\r\n                            var bottomMargin = 5;\r\n                            var leftMargin = 60;\r\n\r\n                            var chart = d3.select(svg)\r\n                                .attr('width', scope.width)\r\n                                .attr('height', scope.height);\r\n\r\n                            var width = svg.clientWidth;\r\n                            var height = svg.clientHeight;\r\n\r\n                            //HINT: This is workaround for Firefox\r\n                            if (width === 0) {\r\n                                var box = svg.getBoundingClientRect();\r\n\r\n                                width = box.right - box.left;\r\n                                height = box.bottom - box.top;\r\n                            }\r\n\r\n                            var firstSeries = scope.firstDataSeries;\r\n                            var secondSeries = scope.secondDataSeries;\r\n\r\n                            var scaleX = d3.scaleLinear()\r\n                                .domain([0, firstSeries.points.length - 1])\r\n                                .range([leftMargin, width]);\r\n\r\n                            chart.append('rect')\r\n                                .attr('width', width - leftMargin)\r\n                                .attr('height', height - topMargin - bottomMargin)\r\n                                .attr('transform', 'translate(' + leftMargin + ',' + topMargin + ')')\r\n                                .attr('fill', '#F2F6F7');\r\n\r\n                            var minimumYaxis = !isNaN(scope.minimumYaxis) ? Number(scope.minimumYaxis) : 10;\r\n                            var max = Math.max(firstSeries.average, d3.max(firstSeries.points), minimumYaxis);\r\n\r\n                            if (secondSeries && secondSeries.points.length > 0) {\r\n                                max = Math.max(max, secondSeries.average, d3.max(secondSeries.points));\r\n                            }\r\n\r\n                            var max = padToWholeValue(max);\r\n\r\n                            var scaleY = d3.scaleLinear()\r\n                                .domain([0, max])\r\n                                .range([height - bottomMargin, topMargin]);\r\n\r\n                            var yAxis = d3.axisLeft(scaleY) \r\n                                .tickValues([0, max * 1/4, max * 1/2, max * 3/4, max]);\r\n\r\n                            if (scope.isDurationGraph) {\r\n                                yAxis = yAxis.tickFormat(function (v) {\r\n                                    var formattedTime = formatter.formatTime(v);\r\n\r\n                                    return formattedTime.value + '  ' + formattedTime.unit;\r\n                                });\r\n                            }\r\n\r\n                            chart.append('g')\r\n                                .attr('class', 'y axis')\r\n                                .attr('transform', 'translate(' + leftMargin + ', 0)')\r\n                                .call(function (g) {\r\n                                    g.call(yAxis);\r\n                                    g.select('.domain').remove();\r\n                                    g.selectAll('.tick line').attr('stroke', 'black').attr('stroke-width', '1.75').attr('opacity', 0.1).attr('x', 0).attr('x2', width - leftMargin);\r\n                                    g.selectAll('.tick text').attr('x', -4).attr('fill', '#828282');\r\n                                });\r\n\r\n                            var drawSeries = function(data, lineColor, fillColor) {\r\n                                drawDataSeries(chart, data, lineColor, fillColor, scaleX, scaleY);\r\n                            }\r\n\r\n                            var drawAverage = function(data, lineColor, fillColor) {\r\n                                drawAverageLine(chart, data, lineColor, fillColor, scaleX, scaleY);\r\n                            }\r\n\r\n                            drawSeries(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\r\n\r\n                            if (secondSeries) {\r\n                                drawSeries(secondSeries, attrs.secondSeriesColor,attrs.secondSeriesFillColor);\r\n                            }\r\n\r\n                            drawAverage(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor );\r\n\r\n                            if (secondSeries) {\r\n                                drawAverage(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\r\n                            }\r\n                        });\r\n                    }\r\n                };\r\n            });\r\n\r\n}(window, window.angular));\r\n\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/directives/ui.particular.largeGraph.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///65\n"); /***/ }), -/* 12 */ + +/***/ 7: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n function routeProvider($routeProvider) {\n var template = __webpack_require__(13);\n\n $routeProvider.when('/endpoint_details/:endpointName/:sourceIndex', {\n data: {\n pageTitle: 'Endpoint Details'\n },\n template: template,\n controller: 'endpointDetailsCtrl',\n controllerAs: 'vm',\n reloadOnSearch: false\n });\n };\n\n routeProvider.$inject = ['$routeProvider'];\n\n angular.module('endpoint_details').config(routeProvider);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2VuZHBvaW50X2RldGFpbHMucm91dGUuanM/NjViNiJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwicm91dGVQcm92aWRlciIsIiRyb3V0ZVByb3ZpZGVyIiwidGVtcGxhdGUiLCJyZXF1aXJlIiwid2hlbiIsImRhdGEiLCJwYWdlVGl0bGUiLCJjb250cm9sbGVyIiwiY29udHJvbGxlckFzIiwicmVsb2FkT25TZWFyY2giLCIkaW5qZWN0IiwibW9kdWxlIiwiY29uZmlnIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQSxhQUFTQyxhQUFULENBQXVCQyxjQUF2QixFQUF1QztBQUNuQyxZQUFJQyxXQUFXLG1CQUFBQyxDQUFRLEVBQVIsQ0FBZjs7QUFFQUYsdUJBQWVHLElBQWYsQ0FBb0IsOENBQXBCLEVBQW9FO0FBQ2hFQyxrQkFBTTtBQUNGQywyQkFBVztBQURULGFBRDBEO0FBSWhFSixzQkFBVUEsUUFKc0Q7QUFLaEVLLHdCQUFZLHFCQUxvRDtBQU1oRUMsMEJBQWMsSUFOa0Q7QUFPaEVDLDRCQUFnQjtBQVBnRCxTQUFwRTtBQVNIOztBQUVEVCxrQkFBY1UsT0FBZCxHQUF3QixDQUNwQixnQkFEb0IsQ0FBeEI7O0FBSUFaLFlBQVFhLE1BQVIsQ0FBZSxrQkFBZixFQUNLQyxNQURMLENBQ1laLGFBRFo7QUFFSCxDQXZCQSxFQXVCRUgsTUF2QkYsRUF1QlVBLE9BQU9DLE9BdkJqQixDQUFEIiwiZmlsZSI6IjEyLmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGZ1bmN0aW9uIHJvdXRlUHJvdmlkZXIoJHJvdXRlUHJvdmlkZXIpIHtcclxuICAgICAgICBsZXQgdGVtcGxhdGUgPSByZXF1aXJlKCcuLy4uL3ZpZXdzL2VuZHBvaW50X2RldGFpbHMuaHRtbCcpO1xyXG5cclxuICAgICAgICAkcm91dGVQcm92aWRlci53aGVuKCcvZW5kcG9pbnRfZGV0YWlscy86ZW5kcG9pbnROYW1lLzpzb3VyY2VJbmRleCcsIHtcclxuICAgICAgICAgICAgZGF0YToge1xyXG4gICAgICAgICAgICAgICAgcGFnZVRpdGxlOiAnRW5kcG9pbnQgRGV0YWlscydcclxuICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgdGVtcGxhdGU6IHRlbXBsYXRlLFxyXG4gICAgICAgICAgICBjb250cm9sbGVyOiAnZW5kcG9pbnREZXRhaWxzQ3RybCcsXHJcbiAgICAgICAgICAgIGNvbnRyb2xsZXJBczogJ3ZtJyxcclxuICAgICAgICAgICAgcmVsb2FkT25TZWFyY2g6IGZhbHNlXHJcbiAgICAgICAgfSk7XHJcbiAgICB9O1xyXG5cclxuICAgIHJvdXRlUHJvdmlkZXIuJGluamVjdCA9IFtcclxuICAgICAgICAnJHJvdXRlUHJvdmlkZXInXHJcbiAgICBdO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCdlbmRwb2ludF9kZXRhaWxzJylcclxuICAgICAgICAuY29uZmlnKHJvdXRlUHJvdmlkZXIpO1xyXG59ICh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vYXBwL21vZHVsZXMvbW9uaXRvcmluZy9qcy9lbmRwb2ludF9kZXRhaWxzLnJvdXRlLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///12\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graphdecimal', []).filter('graphdecimal', ['$filter', function ($filter) {\n return function (input, decimals) {\n if (input) {\n var lastValue = input.points.length > 0 ? input.points[input.points.length - 1] : 0;\n input.displayValue = $filter(\"metricslargenumber\")(lastValue, decimals);\n } else {\n input = {\n points: [],\n average: 0,\n displayValue: 0\n };\n }\n\n return input;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGRlY2ltYWwuanM/NTFkMyJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwidW5kZWZpbmVkIiwibW9kdWxlIiwiZmlsdGVyIiwiJGZpbHRlciIsImlucHV0IiwiZGVjaW1hbHMiLCJsYXN0VmFsdWUiLCJwb2ludHMiLCJsZW5ndGgiLCJkaXNwbGF5VmFsdWUiLCJhdmVyYWdlIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQUQsWUFBUUUsTUFBUixDQUFlLDRCQUFmLEVBQTZDLEVBQTdDLEVBQ0tDLE1BREwsQ0FDWSxjQURaLEVBQzRCLENBQUMsU0FBRCxFQUFZLFVBQVVDLE9BQVYsRUFBbUI7QUFDbkQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCQyxRQUFqQixFQUEyQjtBQUM5QixnQkFBSUQsS0FBSixFQUFXO0FBQ1Asb0JBQUlFLFlBQVlGLE1BQU1HLE1BQU4sQ0FBYUMsTUFBYixHQUFzQixDQUF0QixHQUEwQkosTUFBTUcsTUFBTixDQUFhSCxNQUFNRyxNQUFOLENBQWFDLE1BQWIsR0FBc0IsQ0FBbkMsQ0FBMUIsR0FBa0UsQ0FBbEY7QUFDQUosc0JBQU1LLFlBQU4sR0FBcUJOLFFBQVEsb0JBQVIsRUFBOEJHLFNBQTlCLEVBQXlDRCxRQUF6QyxDQUFyQjtBQUNILGFBSEQsTUFHTztBQUNIRCx3QkFBUTtBQUNKRyw0QkFBUSxFQURKO0FBRUpHLDZCQUFTLENBRkw7QUFHSkQsa0NBQWM7QUFIVixpQkFBUjtBQUtIOztBQUVELG1CQUFPTCxLQUFQO0FBQ0gsU0FiRDtBQWNILEtBZnVCLENBRDVCO0FBaUJILENBcEJBLEVBb0JDTixNQXBCRCxFQW9CU0EsT0FBT0MsT0FwQmhCLENBQUQiLCJmaWxlIjoiNy5qcyIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbiAod2luZG93LCBhbmd1bGFyLCB1bmRlZmluZWQpIHtcclxuICAgICd1c2Ugc3RyaWN0JztcclxuXHJcbiAgICBhbmd1bGFyLm1vZHVsZSgndWkucGFydGljdWxhci5ncmFwaGRlY2ltYWwnLCBbXSlcclxuICAgICAgICAuZmlsdGVyKCdncmFwaGRlY2ltYWwnLCBbJyRmaWx0ZXInLCBmdW5jdGlvbiAoJGZpbHRlcikge1xyXG4gICAgICAgICAgICByZXR1cm4gZnVuY3Rpb24gKGlucHV0LCBkZWNpbWFscykge1xyXG4gICAgICAgICAgICAgICAgaWYgKGlucHV0KSB7XHJcbiAgICAgICAgICAgICAgICAgICAgdmFyIGxhc3RWYWx1ZSA9IGlucHV0LnBvaW50cy5sZW5ndGggPiAwID8gaW5wdXQucG9pbnRzW2lucHV0LnBvaW50cy5sZW5ndGggLSAxXSA6IDA7XHJcbiAgICAgICAgICAgICAgICAgICAgaW5wdXQuZGlzcGxheVZhbHVlID0gJGZpbHRlcihcIm1ldHJpY3NsYXJnZW51bWJlclwiKShsYXN0VmFsdWUsIGRlY2ltYWxzKTtcclxuICAgICAgICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgICAgICAgICAgaW5wdXQgPSB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHBvaW50czogW10sXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGF2ZXJhZ2U6IDAsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGRpc3BsYXlWYWx1ZTogMFxyXG4gICAgICAgICAgICAgICAgICAgIH07XHJcbiAgICAgICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGlucHV0O1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1dKTtcclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XHJcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZGVjaW1hbC5qcyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///7\n"); /***/ }), -/* 13 */ -/***/ (function(module, exports) { -eval("module.exports = \"
Queue Length
{{endpoint.digest.metrics.queueLength.latest | number:0}} MSGS
{{endpoint.digest.metrics.queueLength.average | number:0}} MSGS AVG
Throughput
{{endpoint.digest.metrics.throughput.latest | number:2}} MSGS/S
{{endpoint.digest.metrics.throughput.average | number:2}} MSGS/S AVG
Scheduled Retries Rate
{{endpoint.digest.metrics.retries.latest | number:2}} MSGS
{{endpoint.digest.metrics.retries.average | number:2}} MSGS AVG
Processing Time
{{endpoint.digest.metrics.processingTime.latest | durationValue}} {{endpoint.digest.metrics.processingTime.latest | durationUnit}}
{{endpoint.digest.metrics.processingTime.average | durationValue}} {{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG
Critical Time
{{endpoint.digest.metrics.criticalTime.latest | durationValue}} {{endpoint.digest.metrics.criticalTime.latest | durationUnit}}
{{endpoint.digest.metrics.criticalTime.average | durationValue}} {{endpoint.digest.metrics.criticalTime.average | durationUnit}} AVG

Instance Name

Throughput (msgs/s)

Scheduled retry rate (msgs/s)

Processing Time (t)

Critical Time (t)

{{instance.metrics.throughput.displayValue}}
{{instance.metrics.retries.displayValue}}
{{instance.metrics.processingTime.displayValue.value}} {{instance.metrics.processingTime.displayValue.unit}}
{{instance.metrics.criticalTime.displayValue.value}} {{instance.metrics.criticalTime.displayValue.unit}}

Message Type

Throughput (msgs/s)

Scheduled retry rate (msgs/s)

Processing Time (t)

Critical Time (t)

N/A
{{messageType.typeName}}
{{messageType.assemblyName + '-' + messageType.assemblyVersion}}
{{'Culture=' + messageType.culture}}
{{'PublicKeyToken=' + messageType.publicKeyToken}}
{{messageType.metrics.throughput.displayValue}}
{{messageType.metrics.retries.displayValue}}
{{messageType.metrics.processingTime.displayValue.value}} {{messageType.metrics.processingTime.displayValue.unit}}
{{messageType.metrics.criticalTime.displayValue.value}} {{messageType.metrics.criticalTime.displayValue.unit}}
\";//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/views/endpoint_details.html?e863"],"names":[],"mappings":"AAAA,+IAA+I,8HAA8H,cAAc,mSAAmS,cAAc,GAAG,aAAa,GAAG,2BAA2B,sFAAsF,0CAA0C,oTAAoT,qBAAqB,gKAAgK,cAAc,GAAG,aAAa,iBAAiB,cAAc,KAAK,aAAa,w0BAAw0B,uDAAuD,6GAA6G,wDAAwD,w9BAAw9B,sDAAsD,+GAA+G,uDAAuD,0ZAA0Z,mDAAmD,6GAA6G,oDAAoD,ogCAAogC,+DAA+D,0CAA0C,8DAA8D,kEAAkE,gEAAgE,0CAA0C,+DAA+D,wWAAwW,6DAA6D,0CAA0C,4DAA4D,kEAAkE,8DAA8D,0CAA0C,6DAA6D,8KAA8K,gCAAgC,4GAA4G,+BAA+B,6+DAA6+D,aAAa,mSAAmS,cAAc,GAAG,aAAa,GAAG,2BAA2B,sFAAsF,0CAA0C,8fAA8f,0CAA0C,qeAAqe,uCAAuC,ofAAof,oDAAoD,SAAS,mDAAmD,ufAAuf,kDAAkD,SAAS,iDAAiD,8gEAA8gE,uBAAuB,4BAA4B,4BAA4B,KAAK,sBAAsB,wBAAwB,4BAA4B,6BAA6B,8DAA8D,wBAAwB,2BAA2B,6BAA6B,kCAAkC,wBAAwB,kCAAkC,6BAA6B,gDAAgD,gSAAgS,6CAA6C,oRAAoR,0CAA0C,mSAAmS,uDAAuD,SAAS,sDAAsD,sSAAsS,qDAAqD,SAAS,oDAAoD","file":"13.js","sourcesContent":["module.exports = \"<div class=container> <div class=\\\"row monitoring-head\\\"> <div class=back-nav> <span class=fake-link aria-hidden=true>&#9664;</span> <a href=/#/monitored_endpoints>All endpoints</a> </div> <div class=\\\"col-sm-10 no-side-padding list-section\\\"> <h1> {{endpointName}} <div class=endpoint-status> <span ng-if=endpoint.isStale class=warning> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> <a ng-if=endpoint.errorCount class=warning href=#/failed-messages/groups/{{endpointName}}/{{sourceIndex}}/{{endpoint.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{endpoint.errorCount | metricslargenumber}}</span> </a> </div> </h1> </div> <div class=\\\"col-sm-2 no-side-padding toolbar-menus\\\"> <div class=\\\"msg-group-menu dropdown\\\"> <label class=control-label>Period:</label> <button type=button class=\\\"btn btn-default dropdown-toggle sp-btn-menu\\\" data-toggle=dropdown aria-haspopup=true aria-expanded=false> {{selectedPeriod.text}} <span class=caret></span> </button> <ul class=dropdown-menu> <li ng-repeat=\\\"period in periods\\\"> <a ng-click=selectPeriod(period) href=\\\"#/endpoint_details/{{endpointName}}/{{sourceIndex}}?historyPeriod={{period.value}}\\\">{{period.text}}</a> </li> </ul> </div> </div> </div> </div> <div class=\\\"container large-graphs\\\"> <div class=container> <div class=row> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-queue-length\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.queueLength first-data-series=endpoint.metricDetails.metrics.queueLength xaxis-points=endpoint.metricDetails.metrics.queueLength.timeAxisValues plot-width=750 plot-height=200 first-series-color=#EA7E00 first-series-fill-color=#EADDCE class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"row queue-length-values\\\"> <span class=metric-digest-header uib-tooltip=\\\"Queue length (# msgs): The estimated number of messages in an endpoint's queue.\\\"> Queue Length </span> </div> <div class=\\\"row metric-digest-value current\\\"> {{endpoint.digest.metrics.queueLength.latest | number:0}} <span class=metric-digest-value-suffix>MSGS</span> </div> <div class=\\\"row metric-digest-value average\\\"> {{endpoint.digest.metrics.queueLength.average | number:0}} <span class=metric-digest-value-suffix>MSGS AVG</span> </div> </div> </div> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-message-retries-throughputs\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.throughput first-data-series=endpoint.metricDetails.metrics.throughput second-data-series=endpoint.metricDetails.metrics.retries xaxis-points=endpoint.metricDetails.metrics.throughput.timeAxisValues plot-width=750 plot-height=200 first-series-color=#176397 first-series-fill-color=#CADCE8 second-series-color=#CC1252 second-series-fill-color=#E9C4D1 class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"col-sm-6 no-side-padding throughput-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Throughput (# msgs/s): The number of messages per second successfully processed by a receiving endpoint.\\\"> Throughput </span> </div> <div class=\\\"row metric-digest-value current\\\"> {{endpoint.digest.metrics.throughput.latest | number:2}} <span class=metric-digest-value-suffix>MSGS/S</span> </div> <div class=\\\"row metric-digest-value average\\\"> {{endpoint.digest.metrics.throughput.average | number:2}} <span class=metric-digest-value-suffix>MSGS/S AVG</span> </div> </div> <div class=\\\"col-sm-6 no-side-padding scheduled-retries-rate-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Scheduled retry rate (# msgs/s): The number of messages per second scheduled for retries (immediate or delayed).\\\"> Scheduled Retries Rate </span> </div> <div class=\\\"row metric-digest-value current\\\"> {{endpoint.digest.metrics.retries.latest | number:2}} <span class=metric-digest-value-suffix>MSGS</span> </div> <div class=\\\"row metric-digest-value average\\\"> {{endpoint.digest.metrics.retries.average | number:2}} <span class=metric-digest-value-suffix>MSGS AVG</span> </div> </div> </div> </div> <div class=\\\"col-sm-4 no-side-padding list-section graph-area graph-critical-processing-times\\\"> <large-graph ng-if=endpoint.metricDetails.metrics.processingTime first-data-series=endpoint.metricDetails.metrics.criticalTime second-data-series=endpoint.metricDetails.metrics.processingTime xaxis-points=endpoint.metricDetails.metrics.criticalTime.timeAxisValues plot-width=750 plot-height=200 first-series-color=#2700CB first-series-fill-color=#C4BCE5 second-series-color=#258135 second-series-fill-color=#BEE6C5 is-duration-graph=true class=\\\"large-graph pull-left\\\"></large-graph> <div class=\\\"col-sm-12 no-side-padding graph-values\\\"> <div class=\\\"col-sm-6 no-side-padding processing-time-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Processing time (t): The time taken for a receiving endpoint to successfully process a message.\\\"> Processing Time </span> </div> <div class=\\\"row metric-digest-value current\\\"> {{endpoint.digest.metrics.processingTime.latest | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.processingTime.latest | durationUnit}} </span> </div> <div class=\\\"row metric-digest-value average\\\"> {{endpoint.digest.metrics.processingTime.average | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG</span> </div> </div> <div class=\\\"col-sm-6 no-side-padding critical-time-values\\\"> <div class=row> <span class=metric-digest-header uib-tooltip=\\\"Critical time (t): The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> Critical Time </span> </div> <div class=\\\"row metric-digest-value current\\\"> {{endpoint.digest.metrics.criticalTime.latest | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.criticalTime.latest | durationUnit}} </span> </div> <div class=\\\"row metric-digest-value average\\\"> {{endpoint.digest.metrics.criticalTime.average | durationValue}} <span class=metric-digest-value-suffix>{{endpoint.digest.metrics.criticalTime.average | durationUnit}} AVG</span> </div> </div> </div> </div> </div> </div> </div> <div class=container> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div class=tabs> <h5 ng-class=\\\"{active: !showInstancesBreakdown}\\\"> <a ng-click=\\\"showInstancesBreakdown = false\\\" class=ng-binding>Message Types</a> </h5> <h5 ng-class=\\\"{active: showInstancesBreakdown}\\\"> <a ng-click=\\\"showInstancesBreakdown = true\\\" class=ng-binding>Instances</a> </h5> </div> <section ng-if=showInstancesBreakdown> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div ng-show=!loading class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-8\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> <p>Instance Name</p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Throughput (# msgs/s): The number of messages per second successfully processed by a receiving endpoint.\\\"> <p>Throughput <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate (# msgs/s): The number of messages per second scheduled for retries (immediate or delayed).\\\"> <p>Scheduled retry rate <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Processing time (t): The time taken for a receiving endpoint to successfully process a message.\\\"> <p>Processing Time <span>(t)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Critical time (t): The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> <p>Critical Time <span>(t)</span></p> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row\\\" ng-repeat=\\\"instance in endpoint.instances\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <div class=\\\"col-sm-2 col-xl-8 endpoint-name\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding lead\\\"> {{instance.id}} <div class=endpoint-status> <span ng-if=instance.isStale class=warning> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> <a ng-if=instance.errorCount class=warning href=#/failed-messages/groups/{{endpointName}}/{{sourceIndex}}/{{instance.serviceControlId}}> <i class=\\\"fa fa-envelope\\\"></i> <span class=\\\"badge badge-important ng-binding\\\">{{instance.errorCount | metricslargenumber}}</span> </a> </div> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.throughput class=\\\"graph throughput pull-left\\\"></graph> <span ng-if=instance.isStale class=\\\"warning pull-right graphicon\\\"> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{instance.metrics.throughput.displayValue}} </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.retries class=\\\"graph retries pull-left\\\"></graph> <span ng-if=instance.isStale class=\\\"warning pull-right graphicon\\\"> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{instance.metrics.retries.displayValue}} </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.processingTime class=\\\"graph processing-time pull-left\\\"></graph> <span ng-if=instance.isStale class=\\\"warning pull-right graphicon\\\"> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{instance.metrics.processingTime.displayValue.value}} <span>{{instance.metrics.processingTime.displayValue.unit}}</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=instance.metrics.criticalTime class=\\\"graph critical-time pull-left\\\"></graph> <span ng-if=instance.isStale class=\\\"warning pull-right graphicon\\\"> <i class=\\\"fa fa-exclamation-triangle\\\" uib-tooltip=\\\"Endpoint does not appear to be connected to the monitoring server anymore\\\"></i> </span> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{instance.metrics.criticalTime.displayValue.value}} <span>{{instance.metrics.criticalTime.displayValue.unit}}</span> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </section> <section ng-if=!showInstancesBreakdown> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <busy ng-show=loading message=\\\"Loading details\\\"></busy> <div ng-show=!loading class=\\\"row box box-no-click table-head-row\\\"> <div class=\\\"col-sm-2 col-xl-8\\\"> <div class=\\\"row box-header\\\"> <div class=col-sm-12> <p>Message Type</p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Throughput (# msgs/s): The number of messages per second successfully processed by a receiving endpoint.\\\"> <p>Throughput <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Scheduled retry rate (# msgs/s): The number of messages per second scheduled for retries (immediate or delayed).\\\"> <p>Scheduled retry rate <span>(msgs/s)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Processing time (t): The time taken for a receiving endpoint to successfully process a message.\\\"> <p>Processing Time <span>(t)</span></p> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding\\\" uib-tooltip=\\\"Critical time (t): The elapsed time from when a message was sent, until it was successfully processed by a receiving endpoint.\\\"> <p>Critical Time <span>(t)</span></p> </div> </div> </div> </div> <div class=row> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=\\\"row box endpoint-row\\\" ng-repeat=\\\"messageType in endpoint.messageTypes\\\"> <div class=\\\"col-sm-12 no-side-padding\\\"> <div class=row> <div class=\\\"col-sm-2 col-xl-8 endpoint-name\\\"> <div class=\\\"row box-header\\\"> <div class=\\\"col-sm-12 no-side-padding lead message-type-label\\\"> <div ng-show={{!messageType.typeName}}>N/A</div> <div ng-show=\\\"{{messageType.typeName != ''}}\\\">{{messageType.typeName}}</div> <div ng-show=\\\"{{messageType.typeName != ''}}\\\" class=message-type-part>{{messageType.assemblyName + '-' + messageType.assemblyVersion}}</div> <div ng-show=\\\"{{messageType.culture != ''}}\\\" class=message-type-part>{{'Culture=' + messageType.culture}}</div> <div ng-show=\\\"{{messageType.publicKeyToken != ''}}\\\" class=message-type-part>{{'PublicKeyToken=' + messageType.publicKeyToken}}</div> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.throughput class=\\\"graph throughput pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{messageType.metrics.throughput.displayValue}} </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.retries class=\\\"graph retries pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{messageType.metrics.retries.displayValue}} </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.processingTime class=\\\"graph processing-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{messageType.metrics.processingTime.displayValue.value}} <span>{{messageType.metrics.processingTime.displayValue.unit}}</span> </div> </div> </div> <div class=\\\"col-sm-2 col-xl-1 no-side-padding\\\"> <div class=\\\"row box-header\\\"> <div class=no-side-padding> <graph plot-data=messageType.metrics.criticalTime class=\\\"graph critical-time pull-left\\\"></graph> </div> <div class=\\\"no-side-padding sparkline-value\\\"> {{messageType.metrics.criticalTime.displayValue.value}} <span>{{messageType.metrics.criticalTime.displayValue.unit}}</span> </div> </div> </div> </div> </div> </div> </div> </div> </div> </div> </section> </div> \";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./app/modules/monitoring/views/endpoint_details.html\n// module id = 13\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///13\n"); +/***/ 78: +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; +eval("\n\n;\n(function (window, angular, $, undefined) {\n 'use strict';\n\n function Service(toastService, scConfig) {\n\n var isConnectedToSourceIndex = Array(scConfig.monitoring_urls.length).fill(true);\n\n function reportFailedConnection(sourceIndex) {\n\n if (isConnectedToSourceIndex[sourceIndex]) {\n var message = 'Could not connect to the ServiceControl Monitoring service.';\n if (scConfig.monitoring_urls.length > 1) {\n message = 'Could not connect to the ServiceControl Monitoring service at' + scConfig.monitoring_urls[sourceIndex] + '.';\n }\n toastService.showError(message);\n }\n isConnectedToSourceIndex[sourceIndex] = false;\n }\n\n function reportSuccessfulConnection(sourceIndex) {\n if (!isConnectedToSourceIndex[sourceIndex]) {\n var message = 'Connection to ServiceControl Monitoring service was successful.';\n if (scConfig.monitoring_urls.length > 1) {\n message = 'Connection to ServiceControl Monitoring service was successful ' + scConfig.monitoring_urls[sourceIndex] + '.';\n }\n toastService.showInfo(message, 'Info', true);\n }\n isConnectedToSourceIndex[sourceIndex] = true;\n }\n\n var service = {\n reportFailedConnection: reportFailedConnection,\n reportSuccessfulConnection: reportSuccessfulConnection\n };\n\n return service;\n }\n\n Service.$inject = ['toastService', 'scConfig'];\n\n angular.module('services.connectivityNotifier', ['sc']).service('connectivityNotifier', Service);\n})(window, window.angular, window.jQuery);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL3NlcnZpY2VzL3NlcnZpY2VzLmNvbm5lY3Rpdml0eU5vdGlmaWVyLmpzP2RjZjYiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsIiQiLCJ1bmRlZmluZWQiLCJTZXJ2aWNlIiwidG9hc3RTZXJ2aWNlIiwic2NDb25maWciLCJpc0Nvbm5lY3RlZFRvU291cmNlSW5kZXgiLCJBcnJheSIsIm1vbml0b3JpbmdfdXJscyIsImxlbmd0aCIsImZpbGwiLCJyZXBvcnRGYWlsZWRDb25uZWN0aW9uIiwic291cmNlSW5kZXgiLCJtZXNzYWdlIiwic2hvd0Vycm9yIiwicmVwb3J0U3VjY2Vzc2Z1bENvbm5lY3Rpb24iLCJzaG93SW5mbyIsInNlcnZpY2UiLCIkaW5qZWN0IiwibW9kdWxlIiwialF1ZXJ5Il0sIm1hcHBpbmdzIjoiOztBQUFBO0FBQ0MsV0FBVUEsTUFBVixFQUFrQkMsT0FBbEIsRUFBMkJDLENBQTNCLEVBQThCQyxTQUE5QixFQUF5QztBQUN0Qzs7QUFFQSxhQUFTQyxPQUFULENBQWlCQyxZQUFqQixFQUErQkMsUUFBL0IsRUFBeUM7O0FBRXJDLFlBQUlDLDJCQUEyQkMsTUFBTUYsU0FBU0csZUFBVCxDQUF5QkMsTUFBL0IsRUFBdUNDLElBQXZDLENBQTRDLElBQTVDLENBQS9COztBQUVBLGlCQUFTQyxzQkFBVCxDQUFnQ0MsV0FBaEMsRUFBNkM7O0FBRXpDLGdCQUFJTix5QkFBeUJNLFdBQXpCLENBQUosRUFBMkM7QUFDdkMsb0JBQUlDLFVBQVUsNkRBQWQ7QUFDQSxvQkFBSVIsU0FBU0csZUFBVCxDQUF5QkMsTUFBekIsR0FBa0MsQ0FBdEMsRUFBeUM7QUFDckNJLDhCQUFVLGtFQUFrRVIsU0FBU0csZUFBVCxDQUF5QkksV0FBekIsQ0FBbEUsR0FBMEcsR0FBcEg7QUFDSDtBQUNEUiw2QkFBYVUsU0FBYixDQUF1QkQsT0FBdkI7QUFDSDtBQUNEUCxxQ0FBeUJNLFdBQXpCLElBQXdDLEtBQXhDO0FBQ0g7O0FBRUQsaUJBQVNHLDBCQUFULENBQW9DSCxXQUFwQyxFQUFpRDtBQUM3QyxnQkFBSSxDQUFDTix5QkFBeUJNLFdBQXpCLENBQUwsRUFBNEM7QUFDeEMsb0JBQUlDLFVBQVUsaUVBQWQ7QUFDQSxvQkFBSVIsU0FBU0csZUFBVCxDQUF5QkMsTUFBekIsR0FBa0MsQ0FBdEMsRUFBeUM7QUFDckNJLDhCQUFVLG9FQUFvRVIsU0FBU0csZUFBVCxDQUF5QkksV0FBekIsQ0FBcEUsR0FBMkcsR0FBckg7QUFDSDtBQUNEUiw2QkFBYVksUUFBYixDQUFzQkgsT0FBdEIsRUFBK0IsTUFBL0IsRUFBdUMsSUFBdkM7QUFDSDtBQUNEUCxxQ0FBeUJNLFdBQXpCLElBQXdDLElBQXhDO0FBQ0g7O0FBRUQsWUFBSUssVUFBVTtBQUNWTixvQ0FBd0JBLHNCQURkO0FBRVZJLHdDQUE0QkE7QUFGbEIsU0FBZDs7QUFLQSxlQUFPRSxPQUFQO0FBQ0g7O0FBRURkLFlBQVFlLE9BQVIsR0FBa0IsQ0FBQyxjQUFELEVBQWlCLFVBQWpCLENBQWxCOztBQUVBbEIsWUFBUW1CLE1BQVIsQ0FBZSwrQkFBZixFQUFnRCxDQUFDLElBQUQsQ0FBaEQsRUFDS0YsT0FETCxDQUNhLHNCQURiLEVBQ3FDZCxPQURyQztBQUVILENBMUNBLEVBMENDSixNQTFDRCxFQTBDU0EsT0FBT0MsT0ExQ2hCLEVBMEN5QkQsT0FBT3FCLE1BMUNoQyxDQUFEIiwiZmlsZSI6Ijc4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiO1xyXG4oZnVuY3Rpb24gKHdpbmRvdywgYW5ndWxhciwgJCwgdW5kZWZpbmVkKSB7XHJcbiAgICAndXNlIHN0cmljdCc7XHJcblxyXG4gICAgZnVuY3Rpb24gU2VydmljZSh0b2FzdFNlcnZpY2UsIHNjQ29uZmlnKSB7XHJcblxyXG4gICAgICAgIHZhciBpc0Nvbm5lY3RlZFRvU291cmNlSW5kZXggPSBBcnJheShzY0NvbmZpZy5tb25pdG9yaW5nX3VybHMubGVuZ3RoKS5maWxsKHRydWUpO1xyXG4gICAgICAgIFxyXG4gICAgICAgIGZ1bmN0aW9uIHJlcG9ydEZhaWxlZENvbm5lY3Rpb24oc291cmNlSW5kZXgpIHtcclxuXHJcbiAgICAgICAgICAgIGlmIChpc0Nvbm5lY3RlZFRvU291cmNlSW5kZXhbc291cmNlSW5kZXhdKSB7XHJcbiAgICAgICAgICAgICAgICB2YXIgbWVzc2FnZSA9ICdDb3VsZCBub3QgY29ubmVjdCB0byB0aGUgU2VydmljZUNvbnRyb2wgTW9uaXRvcmluZyBzZXJ2aWNlLic7XHJcbiAgICAgICAgICAgICAgICBpZiAoc2NDb25maWcubW9uaXRvcmluZ191cmxzLmxlbmd0aCA+IDEpIHtcclxuICAgICAgICAgICAgICAgICAgICBtZXNzYWdlID0gJ0NvdWxkIG5vdCBjb25uZWN0IHRvIHRoZSBTZXJ2aWNlQ29udHJvbCBNb25pdG9yaW5nIHNlcnZpY2UgYXQnICsgc2NDb25maWcubW9uaXRvcmluZ191cmxzW3NvdXJjZUluZGV4XSArICcuJztcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHRvYXN0U2VydmljZS5zaG93RXJyb3IobWVzc2FnZSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgaXNDb25uZWN0ZWRUb1NvdXJjZUluZGV4W3NvdXJjZUluZGV4XSA9IGZhbHNlO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgZnVuY3Rpb24gcmVwb3J0U3VjY2Vzc2Z1bENvbm5lY3Rpb24oc291cmNlSW5kZXgpIHtcclxuICAgICAgICAgICAgaWYgKCFpc0Nvbm5lY3RlZFRvU291cmNlSW5kZXhbc291cmNlSW5kZXhdKSB7XHJcbiAgICAgICAgICAgICAgICB2YXIgbWVzc2FnZSA9ICdDb25uZWN0aW9uIHRvIFNlcnZpY2VDb250cm9sIE1vbml0b3Jpbmcgc2VydmljZSB3YXMgc3VjY2Vzc2Z1bC4nO1xyXG4gICAgICAgICAgICAgICAgaWYgKHNjQ29uZmlnLm1vbml0b3JpbmdfdXJscy5sZW5ndGggPiAxKSB7XHJcbiAgICAgICAgICAgICAgICAgICAgbWVzc2FnZSA9ICdDb25uZWN0aW9uIHRvIFNlcnZpY2VDb250cm9sIE1vbml0b3Jpbmcgc2VydmljZSB3YXMgc3VjY2Vzc2Z1bCAnICsgc2NDb25maWcubW9uaXRvcmluZ191cmxzW3NvdXJjZUluZGV4XSArJy4nO1xyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgdG9hc3RTZXJ2aWNlLnNob3dJbmZvKG1lc3NhZ2UsICdJbmZvJywgdHJ1ZSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgaXNDb25uZWN0ZWRUb1NvdXJjZUluZGV4W3NvdXJjZUluZGV4XSA9IHRydWU7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB2YXIgc2VydmljZSA9IHtcclxuICAgICAgICAgICAgcmVwb3J0RmFpbGVkQ29ubmVjdGlvbjogcmVwb3J0RmFpbGVkQ29ubmVjdGlvbixcclxuICAgICAgICAgICAgcmVwb3J0U3VjY2Vzc2Z1bENvbm5lY3Rpb246IHJlcG9ydFN1Y2Nlc3NmdWxDb25uZWN0aW9uXHJcbiAgICAgICAgfTtcclxuXHJcbiAgICAgICAgcmV0dXJuIHNlcnZpY2U7XHJcbiAgICB9XHJcblxyXG4gICAgU2VydmljZS4kaW5qZWN0ID0gWyd0b2FzdFNlcnZpY2UnLCAnc2NDb25maWcnXTtcclxuXHJcbiAgICBhbmd1bGFyLm1vZHVsZSgnc2VydmljZXMuY29ubmVjdGl2aXR5Tm90aWZpZXInLCBbJ3NjJ10pXHJcbiAgICAgICAgLnNlcnZpY2UoJ2Nvbm5lY3Rpdml0eU5vdGlmaWVyJywgU2VydmljZSk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhciwgd2luZG93LmpRdWVyeSkpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvc2VydmljZXMvc2VydmljZXMuY29ubmVjdGl2aXR5Tm90aWZpZXIuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///78\n"); /***/ }), -/* 14 */ + +/***/ 8: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.duration', []).filter('duration', ['formatter', function (formatter) {\n return function (input) {\n var time = formatter.formatTime(input);\n return time.value + ' ' + time.unit;\n };\n }]).filter('durationValue', ['formatter', function (formatter) {\n return function (input) {\n return formatter.formatTime(input).value;\n };\n }]).filter('durationUnit', ['formatter', function (formatter) {\n return function (input) {\n return formatter.formatTime(input).unit;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5kdXJhdGlvbi5qcz85YjhlIl0sIm5hbWVzIjpbIndpbmRvdyIsImFuZ3VsYXIiLCJ1bmRlZmluZWQiLCJtb2R1bGUiLCJmaWx0ZXIiLCJmb3JtYXR0ZXIiLCJpbnB1dCIsInRpbWUiLCJmb3JtYXRUaW1lIiwidmFsdWUiLCJ1bml0Il0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVVBLE1BQVYsRUFBa0JDLE9BQWxCLEVBQTJCQyxTQUEzQixFQUFzQztBQUNuQzs7QUFFQUQsWUFBUUUsTUFBUixDQUFlLHdCQUFmLEVBQXlDLEVBQXpDLEVBQ0tDLE1BREwsQ0FDWSxVQURaLEVBQ3dCLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDbkQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCO0FBQ3BCLGdCQUFJQyxPQUFPRixVQUFVRyxVQUFWLENBQXFCRixLQUFyQixDQUFYO0FBQ0EsbUJBQVVDLEtBQUtFLEtBQWYsU0FBd0JGLEtBQUtHLElBQTdCO0FBQ0gsU0FIRDtBQUlILEtBTG1CLENBRHhCLEVBT0tOLE1BUEwsQ0FPWSxlQVBaLEVBTzZCLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDeEQsZUFBTyxVQUFVQyxLQUFWLEVBQWlCO0FBQ3BCLG1CQUFPRCxVQUFVRyxVQUFWLENBQXFCRixLQUFyQixFQUE0QkcsS0FBbkM7QUFDSCxTQUZEO0FBR0gsS0FKd0IsQ0FQN0IsRUFZS0wsTUFaTCxDQVlZLGNBWlosRUFZNEIsQ0FBQyxXQUFELEVBQWMsVUFBVUMsU0FBVixFQUFxQjtBQUN2RCxlQUFPLFVBQVVDLEtBQVYsRUFBaUI7QUFDcEIsbUJBQU9ELFVBQVVHLFVBQVYsQ0FBcUJGLEtBQXJCLEVBQTRCSSxJQUFuQztBQUNILFNBRkQ7QUFHSCxLQUp1QixDQVo1QjtBQWlCSCxDQXBCQSxFQW9CQ1YsTUFwQkQsRUFvQlNBLE9BQU9DLE9BcEJoQixDQUFEIiwiZmlsZSI6IjE0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCd1aS5wYXJ0aWN1bGFyLmR1cmF0aW9uJywgW10pXHJcbiAgICAgICAgLmZpbHRlcignZHVyYXRpb24nLCBbJ2Zvcm1hdHRlcicsIGZ1bmN0aW9uIChmb3JtYXR0ZXIpIHtcclxuICAgICAgICAgICAgcmV0dXJuIGZ1bmN0aW9uIChpbnB1dCkge1xyXG4gICAgICAgICAgICAgICAgdmFyIHRpbWUgPSBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCk7XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gYCR7dGltZS52YWx1ZX0gJHt0aW1lLnVuaXR9YDtcclxuICAgICAgICAgICAgfTtcclxuICAgICAgICB9XSlcclxuICAgICAgICAuZmlsdGVyKCdkdXJhdGlvblZhbHVlJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCkudmFsdWU7XHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgfV0pXHJcbiAgICAgICAgLmZpbHRlcignZHVyYXRpb25Vbml0JywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0VGltZShpbnB1dCkudW5pdDtcclxuICAgICAgICAgICAgfTtcclxuICAgICAgICB9XSk7XHJcbn0od2luZG93LCB3aW5kb3cuYW5ndWxhcikpO1xuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmR1cmF0aW9uLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///14\n"); +eval("\n\n(function (window, angular, undefined) {\n 'use strict';\n\n angular.module('ui.particular.graphduration', []).filter('graphduration', ['formatter', function (formatter) {\n return function (input) {\n if (input) {\n var lastValue = input.points.length > 0 ? input.points[input.points.length - 1] : 0;\n input.displayValue = formatter.formatTime(lastValue);\n }\n\n return input;\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5ncmFwaGR1cmF0aW9uLmpzP2Y3NWIiXSwibmFtZXMiOlsid2luZG93IiwiYW5ndWxhciIsInVuZGVmaW5lZCIsIm1vZHVsZSIsImZpbHRlciIsImZvcm1hdHRlciIsImlucHV0IiwibGFzdFZhbHVlIiwicG9pbnRzIiwibGVuZ3RoIiwiZGlzcGxheVZhbHVlIiwiZm9ybWF0VGltZSJdLCJtYXBwaW5ncyI6Ijs7QUFBQyxXQUFVQSxNQUFWLEVBQWtCQyxPQUFsQixFQUEyQkMsU0FBM0IsRUFBc0M7QUFDbkM7O0FBRUFELFlBQVFFLE1BQVIsQ0FBZSw2QkFBZixFQUE4QyxFQUE5QyxFQUNLQyxNQURMLENBQ1ksZUFEWixFQUM2QixDQUFDLFdBQUQsRUFBYyxVQUFVQyxTQUFWLEVBQXFCO0FBQ3hELGVBQU8sVUFBVUMsS0FBVixFQUFpQjtBQUNwQixnQkFBSUEsS0FBSixFQUFXO0FBQ1Asb0JBQUlDLFlBQVlELE1BQU1FLE1BQU4sQ0FBYUMsTUFBYixHQUFzQixDQUF0QixHQUEwQkgsTUFBTUUsTUFBTixDQUFhRixNQUFNRSxNQUFOLENBQWFDLE1BQWIsR0FBc0IsQ0FBbkMsQ0FBMUIsR0FBa0UsQ0FBbEY7QUFDQUgsc0JBQU1JLFlBQU4sR0FBcUJMLFVBQVVNLFVBQVYsQ0FBcUJKLFNBQXJCLENBQXJCO0FBQ0g7O0FBRUQsbUJBQU9ELEtBQVA7QUFDSCxTQVBEO0FBUUgsS0FUd0IsQ0FEN0I7QUFXSCxDQWRBLEVBY0NOLE1BZEQsRUFjU0EsT0FBT0MsT0FkaEIsQ0FBRCIsImZpbGUiOiI4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiKGZ1bmN0aW9uICh3aW5kb3csIGFuZ3VsYXIsIHVuZGVmaW5lZCkge1xyXG4gICAgJ3VzZSBzdHJpY3QnO1xyXG5cclxuICAgIGFuZ3VsYXIubW9kdWxlKCd1aS5wYXJ0aWN1bGFyLmdyYXBoZHVyYXRpb24nLCBbXSlcclxuICAgICAgICAuZmlsdGVyKCdncmFwaGR1cmF0aW9uJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQpIHtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dCkge1xyXG4gICAgICAgICAgICAgICAgICAgIHZhciBsYXN0VmFsdWUgPSBpbnB1dC5wb2ludHMubGVuZ3RoID4gMCA/IGlucHV0LnBvaW50c1tpbnB1dC5wb2ludHMubGVuZ3RoIC0gMV0gOiAwO1xyXG4gICAgICAgICAgICAgICAgICAgIGlucHV0LmRpc3BsYXlWYWx1ZSA9IGZvcm1hdHRlci5mb3JtYXRUaW1lKGxhc3RWYWx1ZSk7XHJcbiAgICAgICAgICAgICAgICB9XHJcblxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIGlucHV0O1xyXG4gICAgICAgICAgICB9O1xyXG4gICAgICAgIH1dKTtcclxufSh3aW5kb3csIHdpbmRvdy5hbmd1bGFyKSk7XHJcblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL2FwcC9tb2R1bGVzL21vbml0b3JpbmcvanMvZGlyZWN0aXZlcy91aS5wYXJ0aWN1bGFyLmdyYXBoZHVyYXRpb24uanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///8\n"); /***/ }), -/* 15 */ + +/***/ 9: /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\n(function (window, angular) {\n 'use strict';\n\n function drawDataSeries(chart, data, color, fillColor, scaleX, scaleY) {\n\n var area = d3.area().x(function (d, i) {\n return scaleX(i);\n }).y(function (d) {\n return scaleY(d);\n }).y1(function () {\n return scaleY(0);\n }).curve(d3.curveLinear);\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var group = chart.append('g').attr('class', 'dataSeries');\n\n group.append('path').datum(data.points).attr('d', area).attr('fill', fillColor).attr('opacity', 0.8).attr('stroke', fillColor);\n\n group.append('path').datum(data.points).attr('d', line).attr('stroke', color).attr('stroke-width', 2.75).attr('fill', 'none');\n }\n\n function drawAverageLine(chart, data, color, fillColor, scaleX, scaleY) {\n\n var line = d3.line().x(function (d, i) {\n return scaleX(i);\n }).y(function (d, i) {\n return scaleY(d);\n }).curve(d3.curveLinear);\n\n var group = chart.append('g').attr('class', 'dataAverage');\n\n group.append('path').datum(Array(data.points.length).fill(data.average)).attr('d', line).attr('stroke', color).attr('stroke-width', 1.5).attr('opacity', 0.5).attr('stroke-dasharray', '10,10');\n }\n\n function padToWholeValue(value) {\n var emptyDataSetyAxisMax = 10;\n\n if (!value) {\n return emptyDataSetyAxisMax;\n }\n\n var upperBound = 10;\n\n while (value > upperBound) {\n upperBound *= 10;\n }\n\n upperBound /= 10;\n\n return Math.floor(value / upperBound) * upperBound + upperBound;\n }\n\n angular.module('ui.particular.largeGraph', []).directive('largeGraph', function (formatter) {\n return {\n restrict: 'E',\n scope: {\n dates: '=xaxisPoints',\n firstDataSeries: '=firstDataSeries',\n secondDataSeries: '=secondDataSeries',\n isDurationGraph: '=isDurationGraph',\n width: '=plotWidth',\n height: '=plotHeight'\n },\n template: '',\n link: function link(scope, element, attrs) {\n scope.$watch('firstDataSeries', function () {\n\n var svg = element.find('svg')[0];\n\n d3.select(svg).selectAll('*').remove();\n\n var topMargin = 10;\n var bottomMargin = 5;\n var leftMargin = 60;\n\n var chart = d3.select(svg).attr('width', scope.width).attr('height', scope.height);\n\n var width = svg.clientWidth;\n var height = svg.clientHeight;\n\n //HINT: This is workaround for Firefox\n if (width === 0) {\n var box = svg.getBoundingClientRect();\n\n width = box.right - box.left;\n height = box.bottom - box.top;\n }\n\n var firstSeries = scope.firstDataSeries;\n var secondSeries = scope.secondDataSeries;\n\n var scaleX = d3.scaleLinear().domain([0, firstSeries.points.length - 1]).range([leftMargin, width]);\n\n chart.append('rect').attr('width', width - leftMargin).attr('height', height - topMargin - bottomMargin).attr('transform', 'translate(' + leftMargin + ',' + topMargin + ')').attr('fill', '#F2F6F7');\n\n var max = Math.max(firstSeries.average, d3.max(firstSeries.points));\n\n if (secondSeries && secondSeries.points.length > 0) {\n max = Math.max(max, secondSeries.average, d3.max(secondSeries.points));\n }\n\n var max = padToWholeValue(max);\n\n var scaleY = d3.scaleLinear().domain([0, max]).range([height - bottomMargin, topMargin]);\n\n var yAxis = d3.axisLeft(scaleY).tickValues([0, max * 1 / 4, max * 1 / 2, max * 3 / 4, max]);\n\n if (scope.isDurationGraph) {\n yAxis = yAxis.tickFormat(function (v) {\n var formattedTime = formatter.formatTime(v);\n\n return formattedTime.value + ' ' + formattedTime.unit;\n });\n }\n\n chart.append('g').attr('class', 'y axis').attr('transform', 'translate(' + leftMargin + ', 0)').call(function (g) {\n g.call(yAxis);\n g.select('.domain').remove();\n g.selectAll('.tick line').attr('stroke', 'black').attr('stroke-width', '1.75').attr('opacity', 0.1).attr('x', 0).attr('x2', width - leftMargin);\n g.selectAll('.tick text').attr('x', -4).attr('fill', '#828282');\n });\n\n var drawSeries = function drawSeries(data, lineColor, fillColor) {\n drawDataSeries(chart, data, lineColor, fillColor, scaleX, scaleY);\n };\n\n var drawAverage = function drawAverage(data, lineColor, fillColor) {\n drawAverageLine(chart, data, lineColor, fillColor, scaleX, scaleY);\n };\n\n drawSeries(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\n\n if (secondSeries) {\n drawSeries(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\n }\n\n drawAverage(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\n\n if (secondSeries) {\n drawAverage(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\n }\n });\n }\n };\n });\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./app/modules/monitoring/js/directives/ui.particular.largeGraph.js?070b"],"names":["window","angular","drawDataSeries","chart","data","color","fillColor","scaleX","scaleY","area","d3","x","d","i","y","y1","curve","curveLinear","line","group","append","attr","datum","points","drawAverageLine","Array","length","fill","average","padToWholeValue","value","emptyDataSetyAxisMax","upperBound","Math","floor","module","directive","formatter","restrict","scope","dates","firstDataSeries","secondDataSeries","isDurationGraph","width","height","template","link","element","attrs","$watch","svg","find","select","selectAll","remove","topMargin","bottomMargin","leftMargin","clientWidth","clientHeight","box","getBoundingClientRect","right","left","bottom","top","firstSeries","secondSeries","scaleLinear","domain","range","max","yAxis","axisLeft","tickValues","tickFormat","v","formattedTime","formatTime","unit","call","g","drawSeries","lineColor","drawAverage","firstSeriesColor","firstSeriesFillColor","secondSeriesColor","secondSeriesFillColor"],"mappings":"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","file":"15.js","sourcesContent":["(function(window, angular) {\r\n    'use strict';\r\n\r\n    function drawDataSeries(chart, data, color, fillColor, scaleX, scaleY) {\r\n\r\n        var area = d3.area()\r\n            .x(function (d, i) { return scaleX(i);})\r\n            .y(function (d)    { return scaleY(d); })\r\n            .y1(function ()    { return scaleY(0); })\r\n            .curve(d3.curveLinear);\r\n\r\n        var line = d3.line()\r\n            .x(function (d, i) { return scaleX(i);})\r\n            .y(function (d, i) { return scaleY(d);})\r\n            .curve(d3.curveLinear);\r\n\r\n        var group = chart.append('g').attr('class', 'dataSeries');\r\n\r\n        group.append('path')\r\n            .datum(data.points)\r\n            .attr('d', area)\r\n            .attr('fill', fillColor)\r\n            .attr('opacity', 0.8)\r\n            .attr('stroke', fillColor);\r\n\r\n        group.append('path')\r\n            .datum(data.points)\r\n            .attr('d', line)\r\n            .attr('stroke', color)\r\n            .attr('stroke-width', 2.75)\r\n            .attr('fill', 'none');\r\n    }\r\n\r\n    function drawAverageLine(chart, data, color, fillColor, scaleX, scaleY) {\r\n\r\n        var line = d3.line()\r\n            .x(function (d, i) { return scaleX(i); })\r\n            .y(function (d, i) { return scaleY(d); })\r\n            .curve(d3.curveLinear);\r\n\r\n        var group = chart.append('g').attr('class', 'dataAverage');\r\n\r\n        group.append('path')\r\n            .datum(Array(data.points.length).fill(data.average))\r\n            .attr('d', line)\r\n            .attr('stroke', color)\r\n            .attr('stroke-width', 1.5)\r\n            .attr('opacity', 0.5)\r\n            .attr('stroke-dasharray', '10,10');\r\n    }\r\n\r\n    function padToWholeValue(value) {\r\n        var emptyDataSetyAxisMax = 10;\r\n\r\n        if (!value) {\r\n            return emptyDataSetyAxisMax;\r\n        }\r\n\r\n        var upperBound = 10;\r\n\r\n        while (value > upperBound) {\r\n            upperBound *= 10;\r\n        }\r\n\r\n        upperBound /= 10;\r\n\r\n        return Math.floor(value / upperBound) * upperBound + upperBound;\r\n    }\r\n\r\n    angular.module('ui.particular.largeGraph', [])\r\n        .directive('largeGraph',\r\n            function(formatter) {\r\n                return {\r\n                    restrict: 'E',\r\n                    scope: {                        \r\n                        dates: '=xaxisPoints',\r\n                        firstDataSeries: '=firstDataSeries',\r\n                        secondDataSeries: '=secondDataSeries',\r\n                        isDurationGraph: '=isDurationGraph',\r\n                        width: '=plotWidth',\r\n                        height: '=plotHeight'\r\n                    },\r\n                    template: '<svg></svg>',\r\n                    link: function link(scope, element, attrs) {\r\n                        scope.$watch('firstDataSeries', function () {\r\n\r\n                            var svg = element.find('svg')[0];\r\n\r\n                            d3.select(svg).selectAll('*').remove();\r\n\r\n                            var topMargin = 10;\r\n                            var bottomMargin = 5;\r\n                            var leftMargin = 60;\r\n\r\n                            var chart = d3.select(svg)\r\n                                .attr('width', scope.width)\r\n                                .attr('height', scope.height);\r\n\r\n                            var width = svg.clientWidth;\r\n                            var height = svg.clientHeight;\r\n\r\n                            //HINT: This is workaround for Firefox\r\n                            if (width === 0) {\r\n                                var box = svg.getBoundingClientRect();\r\n\r\n                                width = box.right - box.left;\r\n                                height = box.bottom - box.top;\r\n                            }\r\n\r\n                            var firstSeries = scope.firstDataSeries;\r\n                            var secondSeries = scope.secondDataSeries;\r\n\r\n                            var scaleX = d3.scaleLinear()\r\n                                .domain([0, firstSeries.points.length - 1])\r\n                                .range([leftMargin, width]);\r\n\r\n                            chart.append('rect')\r\n                                .attr('width', width - leftMargin)\r\n                                .attr('height', height - topMargin - bottomMargin)\r\n                                .attr('transform', 'translate(' + leftMargin + ',' + topMargin + ')')\r\n                                .attr('fill', '#F2F6F7');\r\n\r\n                            var max = Math.max(firstSeries.average, d3.max(firstSeries.points));\r\n\r\n                            if (secondSeries && secondSeries.points.length > 0) {\r\n                                max = Math.max(max, secondSeries.average, d3.max(secondSeries.points));\r\n                            }\r\n\r\n                            var max = padToWholeValue(max);\r\n\r\n                            var scaleY = d3.scaleLinear()\r\n                                .domain([0, max])\r\n                                .range([height - bottomMargin, topMargin]);\r\n\r\n                            var yAxis = d3.axisLeft(scaleY) \r\n                                .tickValues([0, max * 1/4, max * 1/2, max * 3/4, max]);\r\n\r\n                            if (scope.isDurationGraph) {\r\n                                yAxis = yAxis.tickFormat(function (v) {\r\n                                    var formattedTime = formatter.formatTime(v);\r\n\r\n                                    return formattedTime.value + '  ' + formattedTime.unit;\r\n                                });\r\n                            }\r\n\r\n                            chart.append('g')\r\n                                .attr('class', 'y axis')\r\n                                .attr('transform', 'translate(' + leftMargin + ', 0)')\r\n                                .call(function (g) {\r\n                                    g.call(yAxis);\r\n                                    g.select('.domain').remove();\r\n                                    g.selectAll('.tick line').attr('stroke', 'black').attr('stroke-width', '1.75').attr('opacity', 0.1).attr('x', 0).attr('x2', width - leftMargin);\r\n                                    g.selectAll('.tick text').attr('x', -4).attr('fill', '#828282');\r\n                                });\r\n\r\n                            var drawSeries = function(data, lineColor, fillColor) {\r\n                                drawDataSeries(chart, data, lineColor, fillColor, scaleX, scaleY);\r\n                            }\r\n\r\n                            var drawAverage = function(data, lineColor, fillColor) {\r\n                                drawAverageLine(chart, data, lineColor, fillColor, scaleX, scaleY);\r\n                            }\r\n\r\n                            drawSeries(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor);\r\n\r\n                            if (secondSeries) {\r\n                                drawSeries(secondSeries, attrs.secondSeriesColor,attrs.secondSeriesFillColor);\r\n                            }\r\n\r\n                            drawAverage(firstSeries, attrs.firstSeriesColor, attrs.firstSeriesFillColor );\r\n\r\n                            if (secondSeries) {\r\n                                drawAverage(secondSeries, attrs.secondSeriesColor, attrs.secondSeriesFillColor);\r\n                            }\r\n                        });\r\n                    }\r\n                };\r\n            });\r\n\r\n}(window, window.angular));\r\n\n\n\n// WEBPACK FOOTER //\n// ./app/modules/monitoring/js/directives/ui.particular.largeGraph.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///15\n"); +eval("\n\n(function (window, angular) {\n 'use strict';\n\n angular.module('ui.particular.metricslargenumber', []).filter('metricslargenumber', ['formatter', function (formatter) {\n return function (input, dec) {\n var decimals = 0;\n if (input < 10 || input > 1000000) {\n decimals = 2;\n }\n return formatter.formatLargeNumber(input, dec || decimals);\n };\n }]);\n})(window, window.angular);//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5tZXRyaWNzbGFyZ2VudW1iZXIuanM/ZWQ2MSJdLCJuYW1lcyI6WyJ3aW5kb3ciLCJhbmd1bGFyIiwibW9kdWxlIiwiZmlsdGVyIiwiZm9ybWF0dGVyIiwiaW5wdXQiLCJkZWMiLCJkZWNpbWFscyIsImZvcm1hdExhcmdlTnVtYmVyIl0sIm1hcHBpbmdzIjoiOztBQUFDLFdBQVNBLE1BQVQsRUFBaUJDLE9BQWpCLEVBQTBCO0FBQzFCOztBQUVHQSxZQUFRQyxNQUFSLENBQWUsa0NBQWYsRUFBbUQsRUFBbkQsRUFDS0MsTUFETCxDQUNZLG9CQURaLEVBQ2tDLENBQUMsV0FBRCxFQUFjLFVBQVVDLFNBQVYsRUFBcUI7QUFDN0QsZUFBTyxVQUFVQyxLQUFWLEVBQWlCQyxHQUFqQixFQUFzQjtBQUN6QixnQkFBSUMsV0FBVyxDQUFmO0FBQ0EsZ0JBQUlGLFFBQVEsRUFBUixJQUFjQSxRQUFRLE9BQTFCLEVBQW1DO0FBQy9CRSwyQkFBVyxDQUFYO0FBQ0g7QUFDRCxtQkFBT0gsVUFBVUksaUJBQVYsQ0FBNEJILEtBQTVCLEVBQW1DQyxPQUFPQyxRQUExQyxDQUFQO0FBQ0gsU0FORDtBQU9ILEtBUjZCLENBRGxDO0FBVUgsQ0FiQSxFQWFDUCxNQWJELEVBYVNBLE9BQU9DLE9BYmhCLENBQUQiLCJmaWxlIjoiOS5qcyIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbih3aW5kb3csIGFuZ3VsYXIpIHtcclxuXHQndXNlIHN0cmljdCc7XHJcblxyXG4gICAgYW5ndWxhci5tb2R1bGUoJ3VpLnBhcnRpY3VsYXIubWV0cmljc2xhcmdlbnVtYmVyJywgW10pXHJcbiAgICAgICAgLmZpbHRlcignbWV0cmljc2xhcmdlbnVtYmVyJywgWydmb3JtYXR0ZXInLCBmdW5jdGlvbiAoZm9ybWF0dGVyKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBmdW5jdGlvbiAoaW5wdXQsIGRlYykge1xyXG4gICAgICAgICAgICAgICAgdmFyIGRlY2ltYWxzID0gMDtcclxuICAgICAgICAgICAgICAgIGlmIChpbnB1dCA8IDEwIHx8IGlucHV0ID4gMTAwMDAwMCkge1xyXG4gICAgICAgICAgICAgICAgICAgIGRlY2ltYWxzID0gMjtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIHJldHVybiBmb3JtYXR0ZXIuZm9ybWF0TGFyZ2VOdW1iZXIoaW5wdXQsIGRlYyB8fCBkZWNpbWFscyk7XHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgfV0pO1xyXG59KHdpbmRvdywgd2luZG93LmFuZ3VsYXIpKTtcblxuXG4vLyBXRUJQQUNLIEZPT1RFUiAvL1xuLy8gLi9hcHAvbW9kdWxlcy9tb25pdG9yaW5nL2pzL2RpcmVjdGl2ZXMvdWkucGFydGljdWxhci5tZXRyaWNzbGFyZ2VudW1iZXIuanMiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///9\n"); /***/ }) -/******/ ]); \ No newline at end of file + +/******/ }); \ No newline at end of file diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.controller.js b/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.controller.js index 7e8c5b866..dbba7a464 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.controller.js +++ b/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.controller.js @@ -11,7 +11,8 @@ historyPeriods, $filter, smallGraphsMinimumYAxis, - largeGraphsMinimumYAxis + largeGraphsMinimumYAxis, + connectivityNotifier ) { $scope.endpointName = $routeParams.endpointName; @@ -46,7 +47,16 @@ var selectedPeriod = $scope.selectedPeriod; subscription = monitoringService.createEndpointDetailsSource($routeParams.endpointName, $routeParams.sourceIndex, selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) { - if (!endpoint.error) { + if (endpoint.error) { + connectivityNotifier.reportFailedConnection($routeParams.sourceIndex); + if ($scope.endpoint && $scope.endpoint.instances) { + $scope.endpoint.instances.forEach((item) => item.isScMonitoringDisconnected = true); + } + + $scope.endpoint.isScMonitoringDisconnected = true; + + } else { + connectivityNotifier.reportSuccessfulConnection($routeParams.sourceIndex); $scope.endpoint = endpoint; $scope.endpoint.instances.sort(function (first, second) { @@ -62,25 +72,24 @@ }); $scope.loading = false; + $scope.endpoint.messageTypes.forEach((messageType) => fillDisplayValues(messageType)); + + $scope.endpoint.isStale = true; + $scope.endpoint.isScMonitoringDisconnected = false; + + $scope.endpoint.instances.forEach(function (instance) { + fillDisplayValues(instance); + serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) { + if (result.data.length > 0) { + instance.serviceControlId = result.data[0].id; + instance.errorCount = result.data[0].count; + } + }, function (err) { + // Warn user? + }); + $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale; + }); } - - $scope.endpoint.messageTypes.forEach( (messageType) => fillDisplayValues(messageType)); - - $scope.endpoint.isStale = true; - - $scope.endpoint.instances.forEach(function (instance) { - fillDisplayValues(instance); - serviceControlService.getExceptionGroupsForEndpointInstance(instance.id).then(function (result) { - if (result.data.length > 0) { - instance.serviceControlId = result.data[0].id; - instance.errorCount = result.data[0].count; - } - }, function (err) { - // Warn user? - }); - - $scope.endpoint.isStale = $scope.endpoint.isStale && instance.isStale; - }); serviceControlService.getExceptionGroupsForLogicalEndpoint($scope.endpointName).then(function(result) { if (result.data.length > 0) { @@ -115,7 +124,8 @@ 'historyPeriods', '$filter', 'smallGraphsMinimumYAxis', - 'largeGraphsMinimumYAxis' + 'largeGraphsMinimumYAxis', + 'connectivityNotifier' ]; angular.module('endpoint_details') diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.module.js b/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.module.js index 549b6da8e..0e96e9d5c 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.module.js +++ b/src/ServicePulse.Host/app/modules/monitoring/js/endpoint_details.module.js @@ -3,6 +3,7 @@ angular.module('endpoint_details', []); + require('./services/services.connectivityNotifier'); require('./endpoint_details.controller'); require('./endpoint_details.route.js'); require('./constant.diagrams.js'); diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.controller.js b/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.controller.js index f4a4ccd7f..8c303a4bf 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.controller.js +++ b/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.controller.js @@ -10,7 +10,8 @@ historyPeriods, rx, $filter, - smallGraphsMinimumYAxis) { + smallGraphsMinimumYAxis, + connectivityNotifier) { var subscription, endpointsFromScSubscription; @@ -60,36 +61,47 @@ var selectedPeriod = $scope.selectedPeriod; - subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval).subscribe(function (endpoint) { - var index = $scope.endpoints.findIndex(function (item) { return item.name === endpoint.name }); - - endpoint.isConnected = true; - fillDisplayValuesForEndpoint(endpoint); - if (index >= 0) { - var previousServiceControlId = $scope.endpoints[index].serviceControlId; - var previousErrorCount = $scope.endpoints[index].errorCount; - - $scope.endpoints[index] = endpoint; - $scope.endpoints[index].serviceControlId = previousServiceControlId; - $scope.endpoints[index].errorCount = previousErrorCount; - } else { - $scope.endpoints.push(endpoint); - - $scope.endpoints.sort(function (first, second) { - if (first.name < second.name) { - return -1; + subscription = monitoringService.createEndpointsSource(selectedPeriod.value, selectedPeriod.refreshInterval) + .subscribe(function(endpoint) { + if (endpoint.error) { + connectivityNotifier.reportFailedConnection(endpoint.sourceIndex); + if ($scope.endpoints) { + $scope.endpoints.filter((item) => item.sourceIndex === endpoint.sourceIndex) + .forEach((item) => item.isScMonitoringDisconnected = true); } - - if (first.name > second.name) { - return 1; + } else { + connectivityNotifier.reportSuccessfulConnection(endpoint.sourceIndex); + var index = $scope.endpoints.findIndex(function(item) { return item.name === endpoint.name }); + + endpoint.isConnected = true; + endpoint.isScMonitoringDisconnected = false; + fillDisplayValuesForEndpoint(endpoint); + if (index >= 0) { + var previousServiceControlId = $scope.endpoints[index].serviceControlId; + var previousErrorCount = $scope.endpoints[index].errorCount; + + $scope.endpoints[index] = endpoint; + $scope.endpoints[index].serviceControlId = previousServiceControlId; + $scope.endpoints[index].errorCount = previousErrorCount; + } else { + $scope.endpoints.push(endpoint); + + $scope.endpoints.sort(function(first, second) { + if (first.name < second.name) { + return -1; + } + + if (first.name > second.name) { + return 1; + } + + return 0; + }); } + } - return 0; - }); - } - - $scope.$apply(); - }); + $scope.$apply(); + }); endpointsFromScSubscription = Rx.Observable.interval(5000).startWith(0) @@ -125,7 +137,8 @@ 'historyPeriods', 'rx', '$filter', - 'smallGraphsMinimumYAxis' + 'smallGraphsMinimumYAxis', + 'connectivityNotifier' ]; angular.module('monitored_endpoints') diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.module.js b/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.module.js index 978ca8db4..7d9158e47 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.module.js +++ b/src/ServicePulse.Host/app/modules/monitoring/js/monitored_endpoints.module.js @@ -3,6 +3,7 @@ angular.module('monitored_endpoints', []); require('./services/services.monitoring'); + require('./services/services.connectivityNotifier'); require('./monitored_endpoints.controller'); require('./monitored_endpoints.route.js'); require('./constant.diagrams.js'); diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/services/services.connectivityNotifier.js b/src/ServicePulse.Host/app/modules/monitoring/js/services/services.connectivityNotifier.js new file mode 100644 index 000000000..25355fb7a --- /dev/null +++ b/src/ServicePulse.Host/app/modules/monitoring/js/services/services.connectivityNotifier.js @@ -0,0 +1,44 @@ +; +(function (window, angular, $, undefined) { + 'use strict'; + + function Service(toastService, scConfig) { + + var isConnectedToSourceIndex = Array(scConfig.monitoring_urls.length).fill(true); + + function reportFailedConnection(sourceIndex) { + + if (isConnectedToSourceIndex[sourceIndex]) { + var message = 'Could not connect to the ServiceControl Monitoring service.'; + if (scConfig.monitoring_urls.length > 1) { + message = 'Could not connect to the ServiceControl Monitoring service at' + scConfig.monitoring_urls[sourceIndex] + '.'; + } + toastService.showError(message); + } + isConnectedToSourceIndex[sourceIndex] = false; + } + + function reportSuccessfulConnection(sourceIndex) { + if (!isConnectedToSourceIndex[sourceIndex]) { + var message = 'Connection to ServiceControl Monitoring service was successful.'; + if (scConfig.monitoring_urls.length > 1) { + message = 'Connection to ServiceControl Monitoring service was successful ' + scConfig.monitoring_urls[sourceIndex] +'.'; + } + toastService.showInfo(message, 'Info', true); + } + isConnectedToSourceIndex[sourceIndex] = true; + } + + var service = { + reportFailedConnection: reportFailedConnection, + reportSuccessfulConnection: reportSuccessfulConnection + }; + + return service; + } + + Service.$inject = ['toastService', 'scConfig']; + + angular.module('services.connectivityNotifier', ['sc']) + .service('connectivityNotifier', Service); +}(window, window.angular, window.jQuery)); \ No newline at end of file diff --git a/src/ServicePulse.Host/app/modules/monitoring/js/services/services.monitoring.js b/src/ServicePulse.Host/app/modules/monitoring/js/services/services.monitoring.js index fe5e5ade8..cad39b639 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/js/services/services.monitoring.js +++ b/src/ServicePulse.Host/app/modules/monitoring/js/services/services.monitoring.js @@ -2,17 +2,7 @@ (function (window, angular, $, undefined) { 'use strict'; - function Service($http, rx, scConfig, uri, $q, toastService) { - - var isDisconnected = false; - - var notifyDisconnected = function() { - if (isDisconnected === false) { - toastService.showError("Can not connect to Monitoring.\n Reload the page to check connection"); - } - - isDisconnected = true; - }; + function Service($http, rx, scConfig, uri, $q) { function createEndpointsSource(historyPeriod, refreshInterval) { return Rx.Observable.interval(refreshInterval).startWith(0) @@ -39,10 +29,12 @@ }); return result.data; - }, function(error) { - notifyDisconnected(); - return error; - }); + }, + (error) => { + var sourceIndex = scConfig.monitoring_urls.indexOf(url); + return [{ error: error, sourceIndex: sourceIndex }]; + } + ); }); } @@ -51,7 +43,6 @@ .then(function (result) { return result.data; }, function (error) { - notifyDisconnected(); return { error: error }; }); } diff --git a/src/ServicePulse.Host/app/modules/monitoring/views/endpoint_details.html b/src/ServicePulse.Host/app/modules/monitoring/views/endpoint_details.html index ea0de1bcf..f2d855923 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/views/endpoint_details.html +++ b/src/ServicePulse.Host/app/modules/monitoring/views/endpoint_details.html @@ -6,16 +6,20 @@

- {{endpointName}} + {{endpointName}} +

@@ -41,14 +45,14 @@

+ first-data-series="endpoint.metricDetails.metrics.queueLength" + xAxis-points="endpoint.metricDetails.metrics.queueLength.timeAxisValues" + minimum-YAxis="{{largeGraphsMinimumYAxis.queueLength}}" + plot-width="750" + plot-height="200" + first-series-color="#EA7E00" + first-series-fill-color="#EADDCE" + class="large-graph pull-left">
@@ -63,11 +67,17 @@

- {{endpoint.isStale ? "" : (endpoint.digest.metrics.queueLength.latest | metricslargenumber:0)}} MSGS - +
+ {{endpoint.digest.metrics.queueLength.latest | metricslargenumber:0}} MSGS +
+ ?
- {{endpoint.digest.metrics.queueLength.average | metricslargenumber:0}} MSGS AVG +
+ {{endpoint.digest.metrics.queueLength.average | metricslargenumber:0}} MSGS +
+ ? + AVG

@@ -75,17 +85,17 @@

+ first-data-series="endpoint.metricDetails.metrics.throughput" + second-data-series="endpoint.metricDetails.metrics.retries" + xAxis-points="endpoint.metricDetails.metrics.throughput.timeAxisValues" + minimum-YAxis="{{largeGraphsMinimumYAxis.throughputRetries}}" + plot-width="750" + plot-height="200" + first-series-color="#176397" + first-series-fill-color="#CADCE8" + second-series-color="#CC1252" + second-series-fill-color="#E9C4D1" + class="large-graph pull-left">
@@ -95,11 +105,17 @@

- {{endpoint.isStale ? "" : (endpoint.digest.metrics.throughput.latest | metricslargenumber:2)}} MSGS/S - +
+ {{endpoint.digest.metrics.throughput.latest | metricslargenumber:2}} MSGS/S +
+ ?
- {{endpoint.digest.metrics.throughput.average | metricslargenumber:2}} MSGS/S AVG +
+ {{endpoint.digest.metrics.throughput.average | metricslargenumber:2}} MSGS/S +
+ ? + AVG
@@ -110,11 +126,17 @@

- {{endpoint.isStale ? "" : (endpoint.digest.metrics.retries.latest | metricslargenumber:2)}} MSGS/S - +
+ {{endpoint.digest.metrics.retries.latest | metricslargenumber:2}} MSGS/S +
+ ?
- {{endpoint.digest.metrics.retries.average | metricslargenumber:2}} MSGS/S AVG +
+ {{endpoint.digest.metrics.retries.average | metricslargenumber:2}} MSGS/S +
+ ? + AVG
@@ -123,18 +145,18 @@

+ first-data-series="endpoint.metricDetails.metrics.criticalTime" + second-data-series="endpoint.metricDetails.metrics.processingTime" + xAxis-points="endpoint.metricDetails.metrics.criticalTime.timeAxisValues" + minimum-YAxis="{{largeGraphsMinimumYAxis.processingCritical}}" + plot-width="750" + plot-height="200" + first-series-color="#2700CB" + first-series-fill-color="#C4BCE5" + second-series-color="#258135" + second-series-fill-color="#BEE6C5" + is-duration-graph="true" + class="large-graph pull-left">
@@ -144,13 +166,17 @@

- {{endpoint.isStale ? "" : (endpoint.digest.metrics.processingTime.latest | durationValue)}} - {{endpoint.digest.metrics.processingTime.latest | durationUnit}} - +
+ {{endpoint.digest.metrics.processingTime.latest | durationValue}} {{endpoint.digest.metrics.processingTime.latest | durationUnit}} +
+ ?
- {{endpoint.digest.metrics.processingTime.average | durationValue}} - {{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG +
+ {{endpoint.digest.metrics.processingTime.average | durationValue}} {{endpoint.digest.metrics.processingTime.average | durationUnit}} AVG +
+ ? + AVG
@@ -161,13 +187,17 @@

- {{endpoint.isStale ? "" : (endpoint.digest.metrics.criticalTime.latest | durationValue)}} - {{endpoint.digest.metrics.criticalTime.latest | durationUnit}} - +
+ {{endpoint.digest.metrics.criticalTime.latest | durationValue}} {{endpoint.digest.metrics.criticalTime.latest | durationUnit}} +
+ ?
- {{endpoint.digest.metrics.criticalTime.average | durationValue}} - {{endpoint.digest.metrics.criticalTime.average | durationUnit}} AVG +
+ {{endpoint.digest.metrics.criticalTime.average | durationValue}} {{endpoint.digest.metrics.criticalTime.average | durationUnit}} +
+ ? + AVG
@@ -188,7 +218,7 @@

-
+
@@ -238,33 +268,35 @@
-
-
- +
+
+
+ {{instance.name}} +
+
+
- - -
- {{instance.isStale ? "" : instance.metrics.throughput.displayValue}} - + {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? "" : instance.metrics.throughput.displayValue}} + ?
@@ -272,13 +304,10 @@
- - -
- {{instance.isStale ? "" : instance.metrics.retries.displayValue}} - + {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? "" : instance.metrics.retries.displayValue}} + ?
@@ -286,13 +315,11 @@
- - -
- {{instance.isStale ? "" : instance.metrics.processingTime.displayValue.value}} - {{instance.metrics.processingTime.displayValue.unit}} + {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? "" : instance.metrics.processingTime.displayValue.value}} + {{instance.metrics.processingTime.displayValue.unit}} + ?
@@ -300,26 +327,24 @@
- - -
- {{instance.isStale ? "" : instance.metrics.criticalTime.displayValue.value}} - {{instance.metrics.criticalTime.displayValue.unit}} + {{(instance.isStale == true || instance.isScMonitoringDisconnected == true) ? "" : instance.metrics.criticalTime.displayValue.value}} + {{instance.metrics.criticalTime.displayValue.unit}} + ?
+
-
-
+
@@ -370,20 +395,29 @@
-
- -
- {{messageType.typeName ? messageType.typeName : 'Unknown'}} -
- - - -
-
+
+
+ {{messageType.typeName ? messageType.typeName : 'Unknown'}} +
+
{{messageType.assemblyName + '-' + messageType.assemblyVersion}}
{{'Culture=' + messageType.culture}}
-
{{'PublicKeyToken=' + messageType.publicKeyToken}}
- +
{{'PublicKeyToken=' + messageType.publicKeyToken}}
+
+
+
@@ -393,7 +427,8 @@
- {{endpoint.isStale ? "" : messageType.metrics.throughput.displayValue}} + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : messageType.metrics.throughput.displayValue}} + ?
@@ -403,7 +438,8 @@
- {{endpoint.isStale ? "" : messageType.metrics.retries.displayValue}} + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : messageType.metrics.retries.displayValue}} + ?
@@ -413,8 +449,9 @@
- {{endpoint.isStale ? "" : messageType.metrics.processingTime.displayValue.value}} - {{messageType.metrics.processingTime.displayValue.unit}} + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : messageType.metrics.processingTime.displayValue.value}} + {{messageType.metrics.processingTime.displayValue.unit}} + ?
@@ -424,8 +461,9 @@
- {{endpoint.isStale ? "" : messageType.metrics.criticalTime.displayValue.value}} - {{messageType.metrics.criticalTime.displayValue.unit}} + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : messageType.metrics.criticalTime.displayValue.value}} + {{messageType.metrics.criticalTime.displayValue.unit}} + ?
@@ -437,4 +475,4 @@
- + \ No newline at end of file diff --git a/src/ServicePulse.Host/app/modules/monitoring/views/monitored_endpoints.html b/src/ServicePulse.Host/app/modules/monitoring/views/monitored_endpoints.html index 2724a2216..0cbfc6ec2 100644 --- a/src/ServicePulse.Host/app/modules/monitoring/views/monitored_endpoints.html +++ b/src/ServicePulse.Host/app/modules/monitoring/views/monitored_endpoints.html @@ -23,10 +23,15 @@

Endpoints overview

-

No endpoints available for monitoring

-

Ensure that your endpoints have auditing enabled and/or have the metrics plug-in enabled

+

Endpoint monitoring not available

+

Monitoring is not available due to one or more of these reasons:

+
    +
  • the monitoring server is not configured or is unavailable
  • +
  • the monitoring plugin is not installed on the endpoints to be monitored
  • +
  • endpoints without the monitoring plugin do not have auditing enabled
  • +
@@ -46,7 +51,7 @@

No endpoints available for monitoring

Queue length: The estimated number of messages in an endpoint's queue.

-

NOTE: This is an experimental feature. Learn more

+

WARNING: This is an experimental feature. Learn more

@@ -88,22 +93,27 @@

No endpoints available for monitoring

- -
+ +
@@ -111,13 +121,10 @@

No endpoints available for monitoring

- - -
- {{endpoint.isStale ? "" : endpoint.metrics.queueLength.displayValue}} - + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : endpoint.metrics.queueLength.displayValue}} + ?
@@ -125,13 +132,10 @@

No endpoints available for monitoring

- - -
- {{endpoint.isStale ? "" : endpoint.metrics.throughput.displayValue}} - + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : endpoint.metrics.throughput.displayValue}} + ?
@@ -139,13 +143,10 @@

No endpoints available for monitoring

- - -
- {{endpoint.isStale ? "" : endpoint.metrics.retries.displayValue}} - + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : endpoint.metrics.retries.displayValue}} + ?
@@ -153,12 +154,11 @@

No endpoints available for monitoring

- - -
- {{endpoint.isStale ? "" : endpoint.metrics.processingTime.displayValue.value}} {{endpoint.metrics.processingTime.displayValue.unit}} + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : endpoint.metrics.processingTime.displayValue.value}} + ? + {{endpoint.metrics.processingTime.displayValue.unit}}
@@ -166,13 +166,11 @@

No endpoints available for monitoring

- - -
- {{endpoint.isStale ? "" : endpoint.metrics.criticalTime.displayValue.value}} {{endpoint.metrics.criticalTime.displayValue.unit}} - + {{(endpoint.isStale == true || endpoint.isScMonitoringDisconnected == true) ? "" : endpoint.metrics.criticalTime.displayValue.value}} + ? + {{endpoint.metrics.criticalTime.displayValue.unit}}