2022-09-22 01:01:10 +02:00
|
|
|
const axios = require('axios')
|
2022-09-21 01:08:41 +02:00
|
|
|
const Logger = require("../Logger")
|
2022-09-23 01:12:48 +02:00
|
|
|
const { notificationData } = require('../utils/notifications')
|
2022-09-21 01:08:41 +02:00
|
|
|
|
|
|
|
class NotificationManager {
|
2022-09-22 01:01:10 +02:00
|
|
|
constructor(db) {
|
|
|
|
this.db = db
|
2022-09-21 01:08:41 +02:00
|
|
|
|
2022-09-22 01:01:10 +02:00
|
|
|
this.notificationFailedMap = {}
|
|
|
|
}
|
|
|
|
|
2022-09-23 01:12:48 +02:00
|
|
|
getData() {
|
|
|
|
return notificationData
|
|
|
|
}
|
|
|
|
|
2022-09-22 01:01:10 +02:00
|
|
|
onPodcastEpisodeDownloaded(libraryItem, episode) {
|
|
|
|
if (!this.db.notificationSettings.isUseable) return
|
|
|
|
|
|
|
|
Logger.debug(`[NotificationManager] onPodcastEpisodeDownloaded: Episode "${episode.title}" for podcast ${libraryItem.media.metadata.title}`)
|
|
|
|
this.triggerNotification('onPodcastEpisodeDownloaded', { libraryItem, episode })
|
|
|
|
}
|
|
|
|
|
|
|
|
onTest() {
|
|
|
|
this.triggerNotification('onTest')
|
|
|
|
}
|
|
|
|
|
|
|
|
async triggerNotification(eventName, eventData) {
|
|
|
|
if (!this.db.notificationSettings.isUseable) return
|
|
|
|
|
|
|
|
const notifications = this.db.notificationSettings.getNotificationsForEvent(eventName)
|
|
|
|
for (const notification of notifications) {
|
|
|
|
Logger.debug(`[NotificationManager] triggerNotification: Sending ${eventName} notification ${notification.id}`)
|
|
|
|
const success = await this.sendNotification(notification, eventData)
|
|
|
|
|
|
|
|
if (!success) { // Failed notification
|
|
|
|
if (!this.notificationFailedMap[notification.id]) this.notificationFailedMap[notification.id] = 1
|
|
|
|
else this.notificationFailedMap[notification.id]++
|
|
|
|
|
|
|
|
if (this.notificationFailedMap[notification.id] > 2) {
|
|
|
|
Logger.error(`[NotificationManager] triggerNotification: ${notification.eventName}/${notification.id} reached max failed attempts`)
|
|
|
|
// TODO: Do something like disable the notification
|
|
|
|
}
|
|
|
|
} else { // Successful notification
|
|
|
|
delete this.notificationFailedMap[notification.id]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sendNotification(notification, eventData) {
|
|
|
|
const payload = notification.getApprisePayload(eventData)
|
|
|
|
return axios.post(`${this.db.notificationSettings.appriseApiUrl}/notify`, payload, { timeout: 6000 }).then((data) => {
|
|
|
|
Logger.debug(`[NotificationManager] sendNotification: ${notification.eventName}/${notification.id} response=${data}`)
|
|
|
|
return true
|
|
|
|
}).catch((error) => {
|
|
|
|
Logger.error(`[NotificationManager] sendNotification: ${notification.eventName}/${notification.id} error=`, error)
|
|
|
|
return false
|
|
|
|
})
|
2022-09-21 01:08:41 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = NotificationManager
|