mirror of
https://github.com/nezhahq/nezha.git
synced 2025-01-22 20:58:14 -05:00
96 lines
2.2 KiB
Go
96 lines
2.2 KiB
Go
package singleton
|
|
|
|
import (
|
|
"crypto/md5" // #nosec
|
|
"encoding/hex"
|
|
"log"
|
|
"sync"
|
|
"time"
|
|
|
|
"github.com/naiba/nezha/model"
|
|
)
|
|
|
|
const firstNotificationDelay = time.Minute * 15
|
|
|
|
// 通知方式
|
|
var notifications []model.Notification
|
|
var notificationsLock sync.RWMutex
|
|
|
|
func LoadNotifications() {
|
|
notificationsLock.Lock()
|
|
if err := DB.Find(¬ifications).Error; err != nil {
|
|
panic(err)
|
|
}
|
|
notificationsLock.Unlock()
|
|
}
|
|
|
|
func OnRefreshOrAddNotification(n model.Notification) {
|
|
notificationsLock.Lock()
|
|
defer notificationsLock.Unlock()
|
|
var isEdit bool
|
|
for i := 0; i < len(notifications); i++ {
|
|
if notifications[i].ID == n.ID {
|
|
notifications[i] = n
|
|
isEdit = true
|
|
}
|
|
}
|
|
if !isEdit {
|
|
notifications = append(notifications, n)
|
|
}
|
|
}
|
|
|
|
func OnDeleteNotification(id uint64) {
|
|
notificationsLock.Lock()
|
|
defer notificationsLock.Unlock()
|
|
for i := 0; i < len(notifications); i++ {
|
|
if notifications[i].ID == id {
|
|
notifications = append(notifications[:i], notifications[i+1:]...)
|
|
i--
|
|
}
|
|
}
|
|
}
|
|
|
|
func SendNotification(desc string, muteable bool) {
|
|
if muteable {
|
|
// 通知防骚扰策略
|
|
nID := hex.EncodeToString(md5.New().Sum([]byte(desc))) // #nosec
|
|
var flag bool
|
|
if cacheN, has := Cache.Get(nID); has {
|
|
nHistory := cacheN.(NotificationHistory)
|
|
// 每次提醒都增加一倍等待时间,最后每天最多提醒一次
|
|
if time.Now().After(nHistory.Until) {
|
|
flag = true
|
|
nHistory.Duration *= 2
|
|
if nHistory.Duration > time.Hour*24 {
|
|
nHistory.Duration = time.Hour * 24
|
|
}
|
|
nHistory.Until = time.Now().Add(nHistory.Duration)
|
|
// 缓存有效期加 10 分钟
|
|
Cache.Set(nID, nHistory, nHistory.Duration+time.Minute*10)
|
|
}
|
|
} else {
|
|
// 新提醒直接通知
|
|
flag = true
|
|
Cache.Set(nID, NotificationHistory{
|
|
Duration: firstNotificationDelay,
|
|
Until: time.Now().Add(firstNotificationDelay),
|
|
}, firstNotificationDelay+time.Minute*10)
|
|
}
|
|
|
|
if !flag {
|
|
if Conf.Debug {
|
|
log.Println("NEZHA>> 静音的重复通知:", desc, muteable)
|
|
}
|
|
return
|
|
}
|
|
}
|
|
// 发出通知
|
|
notificationsLock.RLock()
|
|
defer notificationsLock.RUnlock()
|
|
for i := 0; i < len(notifications); i++ {
|
|
if err := notifications[i].Send(desc); err != nil {
|
|
log.Println("NEZHA>> 发送通知失败:", err)
|
|
}
|
|
}
|
|
}
|