Merge pull request #1212 from OidaTiftla/introduce-resend-interval
Resend Notification if Down X times consequently
This commit is contained in:
		
						commit
						30b72d81cf
					
				
					 7 changed files with 47 additions and 1 deletions
				
			
		
							
								
								
									
										10
									
								
								db/patch-monitor-add-resend-interval.sql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								db/patch-monitor-add-resend-interval.sql
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | ||||||
|  | -- You should not modify if this have pushed to Github, unless it does serious wrong with the db. | ||||||
|  | BEGIN TRANSACTION; | ||||||
|  | 
 | ||||||
|  | ALTER TABLE monitor | ||||||
|  |     ADD resend_interval INTEGER default 0 not null; | ||||||
|  | 
 | ||||||
|  | ALTER TABLE heartbeat | ||||||
|  |     ADD down_count INTEGER default 0 not null; | ||||||
|  | 
 | ||||||
|  | COMMIT; | ||||||
|  | @ -63,6 +63,7 @@ class Database { | ||||||
|         "patch-add-sqlserver-monitor.sql": true, |         "patch-add-sqlserver-monitor.sql": true, | ||||||
|         "patch-add-other-auth.sql": { parents: [ "patch-monitor-basic-auth.sql" ] }, |         "patch-add-other-auth.sql": { parents: [ "patch-monitor-basic-auth.sql" ] }, | ||||||
|         "patch-add-radius-monitor.sql": true, |         "patch-add-radius-monitor.sql": true, | ||||||
|  |         "patch-monitor-add-resend-interval.sql": true, | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
|  |  | ||||||
|  | @ -79,6 +79,7 @@ class Monitor extends BeanModel { | ||||||
|             type: this.type, |             type: this.type, | ||||||
|             interval: this.interval, |             interval: this.interval, | ||||||
|             retryInterval: this.retryInterval, |             retryInterval: this.retryInterval, | ||||||
|  |             resendInterval: this.resendInterval, | ||||||
|             keyword: this.keyword, |             keyword: this.keyword, | ||||||
|             expiryNotification: this.isEnabledExpiryNotification(), |             expiryNotification: this.isEnabledExpiryNotification(), | ||||||
|             ignoreTls: this.getIgnoreTls(), |             ignoreTls: this.getIgnoreTls(), | ||||||
|  | @ -214,6 +215,7 @@ class Monitor extends BeanModel { | ||||||
|             bean.monitor_id = this.id; |             bean.monitor_id = this.id; | ||||||
|             bean.time = R.isoDateTimeMillis(dayjs.utc()); |             bean.time = R.isoDateTimeMillis(dayjs.utc()); | ||||||
|             bean.status = DOWN; |             bean.status = DOWN; | ||||||
|  |             bean.downCount = previousBeat?.downCount || 0; | ||||||
| 
 | 
 | ||||||
|             if (this.isUpsideDown()) { |             if (this.isUpsideDown()) { | ||||||
|                 bean.status = flipStatus(bean.status); |                 bean.status = flipStatus(bean.status); | ||||||
|  | @ -594,12 +596,27 @@ class Monitor extends BeanModel { | ||||||
|                 log.debug("monitor", `[${this.name}] sendNotification`); |                 log.debug("monitor", `[${this.name}] sendNotification`); | ||||||
|                 await Monitor.sendNotification(isFirstBeat, this, bean); |                 await Monitor.sendNotification(isFirstBeat, this, bean); | ||||||
| 
 | 
 | ||||||
|  |                 // Reset down count
 | ||||||
|  |                 bean.downCount = 0; | ||||||
|  | 
 | ||||||
|                 // Clear Status Page Cache
 |                 // Clear Status Page Cache
 | ||||||
|                 log.debug("monitor", `[${this.name}] apicache clear`); |                 log.debug("monitor", `[${this.name}] apicache clear`); | ||||||
|                 apicache.clear(); |                 apicache.clear(); | ||||||
| 
 | 
 | ||||||
|             } else { |             } else { | ||||||
|                 bean.important = false; |                 bean.important = false; | ||||||
|  | 
 | ||||||
|  |                 if (bean.status === DOWN && this.resendInterval > 0) { | ||||||
|  |                     ++bean.downCount; | ||||||
|  |                     if (bean.downCount >= this.resendInterval) { | ||||||
|  |                         // Send notification again, because we are still DOWN
 | ||||||
|  |                         log.debug("monitor", `[${this.name}] sendNotification again: Down Count: ${bean.downCount} | Resend Interval: ${this.resendInterval}`); | ||||||
|  |                         await Monitor.sendNotification(isFirstBeat, this, bean); | ||||||
|  | 
 | ||||||
|  |                         // Reset down count
 | ||||||
|  |                         bean.downCount = 0; | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (bean.status === UP) { |             if (bean.status === UP) { | ||||||
|  | @ -610,7 +627,7 @@ class Monitor extends BeanModel { | ||||||
|                 } |                 } | ||||||
|                 log.warn("monitor", `Monitor #${this.id} '${this.name}': Pending: ${bean.msg} | Max retries: ${this.maxretries} | Retry: ${retries} | Retry Interval: ${beatInterval} seconds | Type: ${this.type}`); |                 log.warn("monitor", `Monitor #${this.id} '${this.name}': Pending: ${bean.msg} | Max retries: ${this.maxretries} | Retry: ${retries} | Retry Interval: ${beatInterval} seconds | Type: ${this.type}`); | ||||||
|             } else { |             } else { | ||||||
|                 log.warn("monitor", `Monitor #${this.id} '${this.name}': Failing: ${bean.msg} | Interval: ${beatInterval} seconds | Type: ${this.type}`); |                 log.warn("monitor", `Monitor #${this.id} '${this.name}': Failing: ${bean.msg} | Interval: ${beatInterval} seconds | Type: ${this.type} | Down Count: ${bean.downCount} | Resend Interval: ${this.resendInterval}`); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             log.debug("monitor", `[${this.name}] Send to socket`); |             log.debug("monitor", `[${this.name}] Send to socket`); | ||||||
|  |  | ||||||
|  | @ -669,6 +669,7 @@ let needSetup = false; | ||||||
|                 bean.basic_auth_pass = monitor.basic_auth_pass; |                 bean.basic_auth_pass = monitor.basic_auth_pass; | ||||||
|                 bean.interval = monitor.interval; |                 bean.interval = monitor.interval; | ||||||
|                 bean.retryInterval = monitor.retryInterval; |                 bean.retryInterval = monitor.retryInterval; | ||||||
|  |                 bean.resendInterval = monitor.resendInterval; | ||||||
|                 bean.hostname = monitor.hostname; |                 bean.hostname = monitor.hostname; | ||||||
|                 bean.maxretries = monitor.maxretries; |                 bean.maxretries = monitor.maxretries; | ||||||
|                 bean.port = parseInt(monitor.port); |                 bean.port = parseInt(monitor.port); | ||||||
|  | @ -1278,6 +1279,7 @@ let needSetup = false; | ||||||
|                                 authDomain: monitorListData[i].authDomain, |                                 authDomain: monitorListData[i].authDomain, | ||||||
|                                 interval: monitorListData[i].interval, |                                 interval: monitorListData[i].interval, | ||||||
|                                 retryInterval: retryInterval, |                                 retryInterval: retryInterval, | ||||||
|  |                                 resendInterval: monitorListData[i].resendInterval || 0, | ||||||
|                                 hostname: monitorListData[i].hostname, |                                 hostname: monitorListData[i].hostname, | ||||||
|                                 maxretries: monitorListData[i].maxretries, |                                 maxretries: monitorListData[i].maxretries, | ||||||
|                                 port: monitorListData[i].port, |                                 port: monitorListData[i].port, | ||||||
|  |  | ||||||
|  | @ -165,7 +165,10 @@ export default { | ||||||
|     Pink: "Pink", |     Pink: "Pink", | ||||||
|     "Search...": "Suchen...", |     "Search...": "Suchen...", | ||||||
|     "Heartbeat Retry Interval": "Überprüfungsintervall", |     "Heartbeat Retry Interval": "Überprüfungsintervall", | ||||||
|  |     "Resend Notification if Down X times consequently": "Benachrichtigung erneut senden, wenn Inaktiv X mal hintereinander", | ||||||
|     retryCheckEverySecond: "Alle {0} Sekunden neu versuchen", |     retryCheckEverySecond: "Alle {0} Sekunden neu versuchen", | ||||||
|  |     resendEveryXTimes: "Erneut versenden alle {0} mal", | ||||||
|  |     resendDisabled: "Erneut versenden deaktiviert", | ||||||
|     "Import Backup": "Backup importieren", |     "Import Backup": "Backup importieren", | ||||||
|     "Export Backup": "Backup exportieren", |     "Export Backup": "Backup exportieren", | ||||||
|     "Avg. Ping": "Durchschn. Ping", |     "Avg. Ping": "Durchschn. Ping", | ||||||
|  |  | ||||||
|  | @ -2,6 +2,8 @@ export default { | ||||||
|     languageName: "English", |     languageName: "English", | ||||||
|     checkEverySecond: "Check every {0} seconds", |     checkEverySecond: "Check every {0} seconds", | ||||||
|     retryCheckEverySecond: "Retry every {0} seconds", |     retryCheckEverySecond: "Retry every {0} seconds", | ||||||
|  |     resendEveryXTimes: "Resend every {0} times", | ||||||
|  |     resendDisabled: "Resend disabled", | ||||||
|     retriesDescription: "Maximum retries before the service is marked as down and a notification is sent", |     retriesDescription: "Maximum retries before the service is marked as down and a notification is sent", | ||||||
|     ignoreTLSError: "Ignore TLS/SSL error for HTTPS websites", |     ignoreTLSError: "Ignore TLS/SSL error for HTTPS websites", | ||||||
|     upsideDownModeDescription: "Flip the status upside down. If the service is reachable, it is DOWN.", |     upsideDownModeDescription: "Flip the status upside down. If the service is reachable, it is DOWN.", | ||||||
|  | @ -72,6 +74,7 @@ export default { | ||||||
|     "Heartbeat Interval": "Heartbeat Interval", |     "Heartbeat Interval": "Heartbeat Interval", | ||||||
|     Retries: "Retries", |     Retries: "Retries", | ||||||
|     "Heartbeat Retry Interval": "Heartbeat Retry Interval", |     "Heartbeat Retry Interval": "Heartbeat Retry Interval", | ||||||
|  |     "Resend Notification if Down X times consequently": "Resend Notification if Down X times consequently", | ||||||
|     Advanced: "Advanced", |     Advanced: "Advanced", | ||||||
|     "Upside Down Mode": "Upside Down Mode", |     "Upside Down Mode": "Upside Down Mode", | ||||||
|     "Max. Redirects": "Max. Redirects", |     "Max. Redirects": "Max. Redirects", | ||||||
|  |  | ||||||
|  | @ -275,6 +275,15 @@ | ||||||
|                                 <input id="retry-interval" v-model="monitor.retryInterval" type="number" class="form-control" required min="20" step="1"> |                                 <input id="retry-interval" v-model="monitor.retryInterval" type="number" class="form-control" required min="20" step="1"> | ||||||
|                             </div> |                             </div> | ||||||
| 
 | 
 | ||||||
|  |                             <div class="my-3"> | ||||||
|  |                                 <label for="resend-interval" class="form-label"> | ||||||
|  |                                     {{ $t("Resend Notification if Down X times consequently") }} | ||||||
|  |                                     <span v-if="monitor.resendInterval > 0">({{ $t("resendEveryXTimes", [ monitor.resendInterval ]) }})</span> | ||||||
|  |                                     <span v-else>({{ $t("resendDisabled") }})</span> | ||||||
|  |                                 </label> | ||||||
|  |                                 <input id="resend-interval" v-model="monitor.resendInterval" type="number" class="form-control" required min="0" step="1"> | ||||||
|  |                             </div> | ||||||
|  | 
 | ||||||
|                             <h2 v-if="monitor.type !== 'push'" class="mt-5 mb-2">{{ $t("Advanced") }}</h2> |                             <h2 v-if="monitor.type !== 'push'" class="mt-5 mb-2">{{ $t("Advanced") }}</h2> | ||||||
| 
 | 
 | ||||||
|                             <div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3 form-check"> |                             <div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3 form-check"> | ||||||
|  | @ -660,6 +669,7 @@ export default { | ||||||
|                     method: "GET", |                     method: "GET", | ||||||
|                     interval: 60, |                     interval: 60, | ||||||
|                     retryInterval: this.interval, |                     retryInterval: this.interval, | ||||||
|  |                     resendInterval: 0, | ||||||
|                     maxretries: 0, |                     maxretries: 0, | ||||||
|                     notificationIDList: {}, |                     notificationIDList: {}, | ||||||
|                     ignoreTls: false, |                     ignoreTls: false, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue