blob: 301345ca6e0ee2b157e853be7ab79e9c1487e067 [file] [log] [blame]
Matteo Scandolo29069112016-05-27 14:52:37 -07001'use strict';
2
3angular.module('xos.synchronizerNotifier', [
4 'ngResource',
5 'ngCookies',
6 'ui.router',
7 'xos.helpers'
8])
Matteo Scandolo29069112016-05-27 14:52:37 -07009.service('Diag', function($rootScope, $http, $q, $interval){
10
11 let isRunning = false;
12
13 this.getDiags = () => {
14 let d = $q.defer();
15 $http.get('/api/core/diags')
16 .then(res => {
17 d.resolve(res.data);
18 })
19 .catch(err => {
20 d.reject(err);
21 });
22
23 return d.promise;
24 };
25
26 this.sendEvents = (diags) => {
27 diags.forEach(d => {
28 let status = JSON.parse(d.backend_register);
29 status.last_run = new Date(status.last_run * 1000);
Matteo Scandolo0c989e02016-05-31 16:57:50 -070030 status.last_duration = status.last_duration * 1000;
Matteo Scandolo24464a62016-05-31 14:26:26 -070031 status.last_synchronizer_start = new Date(status.last_synchronizer_start * 1000);
32 status.last_syncrecord_start = status.last_syncrecord_start ? new Date(status.last_syncrecord_start * 1000) : null;
Matteo Scandolo29069112016-05-27 14:52:37 -070033 $rootScope.$broadcast(`diag`, {
34 name: d.name,
35 updated: d.updated,
36 info: status,
37 status: this.getSyncStatus(status)
38 });
39 });
40 };
41
42 this.start = () => {
43 isRunning = true;
44 this.getDiags()
45 .then(diags => {
46 this.sendEvents(diags);
47 });
48 return isRunning;
49 };
50
51 this.stop = () => {
52 isRunning = false;
53 return isRunning;
54 };
55
56 this.getSyncStatus = (status) => {
57
Matteo Scandoloc8065742016-06-01 08:35:15 -070058 const now = new Date();
59 // let gap = 15 * 60 * 1000; /* ms */
60 const gap = 1 * 60 * 1000;
61 // if all of this values are older than 15 min,
62 // probably something is wrong
63 if (
64 (now - status.last_synchronizer_start) > gap &&
65 (now - status.last_syncrecord_start) > gap &&
66 (now - status.last_run) > gap
67 ){
68 return false;
69 }
70 else{
71 return true;
72 }
Matteo Scandolo29069112016-05-27 14:52:37 -070073 }
74
75 $interval(() => {
76 if(isRunning){
77 this.getDiags()
78 .then(diags => {
79 this.sendEvents(diags);
80 });
81 }
Matteo Scandolo0c989e02016-05-31 16:57:50 -070082 }, 10000);
Matteo Scandolo29069112016-05-27 14:52:37 -070083})
84.directive('syncStatus', function() {
85 return {
86 restrict: 'E',
87 scope: {},
88 bindToController: true,
89 controllerAs: 'vm',
90 templateUrl: 'templates/sync-status.tpl.html',
Matteo Scandolo0c989e02016-05-31 16:57:50 -070091 controller: function($log, $rootScope, Diag, xosNotification){
Matteo Scandolo29069112016-05-27 14:52:37 -070092 Diag.start();
Matteo Scandolo24464a62016-05-31 14:26:26 -070093 this.showNotificationPanel = true;
Matteo Scandolo29069112016-05-27 14:52:37 -070094 this.synchronizers = {};
95
Matteo Scandolo0c989e02016-05-31 16:57:50 -070096 const notified = {};
97
Matteo Scandolo29069112016-05-27 14:52:37 -070098 this.showNoSync = true;
99
100 $rootScope.$on('diag', (e, d) => {
Matteo Scandolo29069112016-05-27 14:52:37 -0700101 this.synchronizers[d.name] = d;
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700102
Matteo Scandoloc8065742016-06-01 08:35:15 -0700103 // if errored
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700104 if(!d.status){
Matteo Scandoloc8065742016-06-01 08:35:15 -0700105 // and not already notified
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700106 if(!notified[d.name]){
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700107 xosNotification.notify('CORD Synchronizer Error', {
Matteo Scandoloc8065742016-06-01 08:35:15 -0700108 icon: '/xos/core/static/cord-logo.png',
109 body: `The ${d.name} synchronizer has stopped.`
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700110 });
111 }
Matteo Scandolo0c989e02016-05-31 16:57:50 -0700112 notified[d.name] = true;
113 }
114 else {
115 notified[d.name] = false;
116 }
117
118 // hide list if empty
Matteo Scandolo29069112016-05-27 14:52:37 -0700119 this.showNoSync = false;
120 if(Object.keys(this.synchronizers).length === 0){
121 this.showNoSync = true;
122 }
123 });
124
125 }
126 }
127});
128
129angular.element(document).ready(function() {
130 angular.bootstrap('#xosSynchronizerNotifier', ['xos.synchronizerNotifier']);
131});