mirror of
https://github.com/nezhahq/nezha.git
synced 2025-02-02 01:28:13 -05:00
update: 增加更多占位符与单元测试
This commit is contained in:
parent
b5b521e8cf
commit
e20b37b590
@ -157,14 +157,42 @@ func (ns *NotificationServerBundle) Send(message string) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// replaceParamInString 替换字符串中的占位符
|
||||||
func replaceParamsInString(s *Server, str string, message string, mod func(string) string) string {
|
func replaceParamsInString(s *Server, str string, message string, mod func(string) string) string {
|
||||||
if mod != nil {
|
if mod != nil {
|
||||||
str = strings.ReplaceAll(str, "#NEZHA#", mod(message))
|
str = strings.ReplaceAll(str, "#NEZHA#", mod(message))
|
||||||
|
if s != nil {
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.NAME#", mod(s.Name))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.IP#", mod(s.Host.IP))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.CPU#", mod(fmt.Sprintf("%f", s.State.CPU)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.MEM#", mod(fmt.Sprintf("%d", s.State.MemUsed)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.SWAP#", mod(fmt.Sprintf("%d", s.State.SwapUsed)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.DISK#", mod(fmt.Sprintf("%d", s.State.DiskUsed)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.NETINSPEED#", mod(fmt.Sprintf("%d", s.State.NetInSpeed)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.NETOUTSPEED#", mod(fmt.Sprintf("%d", s.State.NetOutSpeed)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.TRANSFERIN#", mod(fmt.Sprintf("%d", s.State.NetInTransfer)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.TRANSFEROUT#", mod(fmt.Sprintf("%d", s.State.NetOutTransfer)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD1#", mod(fmt.Sprintf("%f", s.State.Load1)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD5#", mod(fmt.Sprintf("%f", s.State.Load5)))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD15#", mod(fmt.Sprintf("%f", s.State.Load15)))
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
str = strings.ReplaceAll(str, "#NEZHA#", message)
|
str = strings.ReplaceAll(str, "#NEZHA#", message)
|
||||||
}
|
if s != nil {
|
||||||
if s != nil {
|
str = strings.ReplaceAll(str, "#SERVER.NAME#", s.Name)
|
||||||
str = strings.ReplaceAll(str, "#SERVER#", s.Name)
|
str = strings.ReplaceAll(str, "#SERVER.IP#", s.Host.IP)
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.CPU#", fmt.Sprintf("%f", s.State.CPU))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.MEM#", fmt.Sprintf("%d", s.State.MemUsed))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.SWAP#", fmt.Sprintf("%d", s.State.SwapUsed))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.DISK#", fmt.Sprintf("%d", s.State.DiskUsed))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.NETINSPEED#", fmt.Sprintf("%d", s.State.NetInSpeed))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.NETOUTSPEED#", fmt.Sprintf("%d", s.State.NetOutSpeed))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.TRANSFERIN#", fmt.Sprintf("%d", s.State.NetInTransfer))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.TRANSFEROUT#", fmt.Sprintf("%d", s.State.NetOutTransfer))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD1#", fmt.Sprintf("%f", s.State.Load1))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD5#", fmt.Sprintf("%f", s.State.Load5))
|
||||||
|
str = strings.ReplaceAll(str, "#SERVER.LOAD15#", fmt.Sprintf("%f", s.State.Load15))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return str
|
return str
|
||||||
}
|
}
|
||||||
|
@ -37,14 +37,43 @@ func execCase(t *testing.T, item testSt) {
|
|||||||
RequestHeader: item.header,
|
RequestHeader: item.header,
|
||||||
}
|
}
|
||||||
server := Server{
|
server := Server{
|
||||||
Common: Common{},
|
Common: Common{},
|
||||||
Name: "ServerName",
|
Name: "ServerName",
|
||||||
Tag: "",
|
Tag: "",
|
||||||
Secret: "",
|
Secret: "",
|
||||||
Note: "",
|
Note: "",
|
||||||
DisplayIndex: 0,
|
DisplayIndex: 0,
|
||||||
Host: nil,
|
Host: &Host{
|
||||||
State: nil,
|
Platform: "",
|
||||||
|
PlatformVersion: "",
|
||||||
|
CPU: nil,
|
||||||
|
MemTotal: 0,
|
||||||
|
DiskTotal: 0,
|
||||||
|
SwapTotal: 0,
|
||||||
|
Arch: "",
|
||||||
|
Virtualization: "",
|
||||||
|
BootTime: 0,
|
||||||
|
IP: "1.1.1.1",
|
||||||
|
CountryCode: "",
|
||||||
|
Version: "",
|
||||||
|
},
|
||||||
|
State: &HostState{
|
||||||
|
CPU: 0,
|
||||||
|
MemUsed: 0,
|
||||||
|
SwapUsed: 8888,
|
||||||
|
DiskUsed: 0,
|
||||||
|
NetInTransfer: 0,
|
||||||
|
NetOutTransfer: 0,
|
||||||
|
NetInSpeed: 0,
|
||||||
|
NetOutSpeed: 0,
|
||||||
|
Uptime: 0,
|
||||||
|
Load1: 0,
|
||||||
|
Load5: 0,
|
||||||
|
Load15: 0,
|
||||||
|
TcpConnCount: 0,
|
||||||
|
UdpConnCount: 0,
|
||||||
|
ProcessCount: 0,
|
||||||
|
},
|
||||||
LastActive: time.Time{},
|
LastActive: time.Time{},
|
||||||
TaskClose: nil,
|
TaskClose: nil,
|
||||||
TaskStream: nil,
|
TaskStream: nil,
|
||||||
@ -139,16 +168,26 @@ func TestNotification(t *testing.T) {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
url: "https://example.com/?m=#NEZHA#",
|
url: "https://example.com/?m=#NEZHA#",
|
||||||
body: `{"Server":"#SERVER#"}`,
|
body: `{"Server":"#SERVER.NAME#","ServerIP":"#SERVER.IP#","ServerSWAP":#SERVER.SWAP#}`,
|
||||||
reqMethod: NotificationRequestMethodPOST,
|
reqMethod: NotificationRequestMethodPOST,
|
||||||
header: `{"asd":"dsa11"}`,
|
header: `{"asd":"dsa11"}`,
|
||||||
reqType: NotificationRequestTypeJSON,
|
reqType: NotificationRequestTypeJSON,
|
||||||
expectURL: "https://example.com/?m=" + msg,
|
expectURL: "https://example.com/?m=" + msg,
|
||||||
expectMethod: http.MethodPost,
|
expectMethod: http.MethodPost,
|
||||||
expectContentType: reqTypeJSON,
|
expectContentType: reqTypeJSON,
|
||||||
expectBody: `{"Server":"ServerName"}`,
|
expectBody: `{"Server":"ServerName","ServerIP":"1.1.1.1","ServerSWAP":8888}`,
|
||||||
expectHeader: map[string]string{"asd": "dsa11"},
|
expectHeader: map[string]string{"asd": "dsa11"},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
url: "https://example.com/?m=#NEZHA#",
|
||||||
|
body: `{"#NEZHA#":"#NEZHA#","Server":"#SERVER.NAME#","ServerIP":"#SERVER.IP#","ServerSWAP":"#SERVER.SWAP#"}`,
|
||||||
|
reqMethod: NotificationRequestMethodPOST,
|
||||||
|
reqType: NotificationRequestTypeForm,
|
||||||
|
expectURL: "https://example.com/?m=" + msg,
|
||||||
|
expectMethod: http.MethodPost,
|
||||||
|
expectContentType: reqTypeForm,
|
||||||
|
expectBody: "%23NEZHA%23=" + msg + "&Server=ServerName&ServerIP=1.1.1.1&ServerSWAP=8888",
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, c := range cases {
|
for _, c := range cases {
|
||||||
|
@ -29,10 +29,10 @@ func (s *NezhaHandler) ReportTask(c context.Context, r *pb.TaskResult) (*pb.Rece
|
|||||||
singleton.ServerLock.RLock()
|
singleton.ServerLock.RLock()
|
||||||
defer singleton.ServerLock.RUnlock()
|
defer singleton.ServerLock.RUnlock()
|
||||||
if cr.PushSuccessful && r.GetSuccessful() {
|
if cr.PushSuccessful && r.GetSuccessful() {
|
||||||
singleton.SendNotification(cr.NotificationTag, fmt.Sprintf("[任务成功] %s ,服务器:%s,日志:\n%s", cr.Name, singleton.ServerList[clientID].Name, r.GetData()), false)
|
singleton.SendNotification(cr.NotificationTag, fmt.Sprintf("$%d$[任务成功] %s ,服务器:%s,日志:\n%s", singleton.ServerList[clientID].ID, cr.Name, singleton.ServerList[clientID].Name, r.GetData()), false)
|
||||||
}
|
}
|
||||||
if !r.GetSuccessful() {
|
if !r.GetSuccessful() {
|
||||||
singleton.SendNotification(cr.NotificationTag, fmt.Sprintf("[任务失败] %s ,服务器:%s,日志:\n%s", cr.Name, singleton.ServerList[clientID].Name, r.GetData()), false)
|
singleton.SendNotification(cr.NotificationTag, fmt.Sprintf("$%d$[任务失败] %s ,服务器:%s,日志:\n%s", singleton.ServerList[clientID].ID, cr.Name, singleton.ServerList[clientID].Name, r.GetData()), false)
|
||||||
}
|
}
|
||||||
singleton.DB.Model(cr).Updates(model.Cron{
|
singleton.DB.Model(cr).Updates(model.Cron{
|
||||||
LastExecutedAt: time.Now().Add(time.Second * -1 * time.Duration(r.GetDelay())),
|
LastExecutedAt: time.Now().Add(time.Second * -1 * time.Duration(r.GetDelay())),
|
||||||
|
@ -149,11 +149,11 @@ func checkStatus() {
|
|||||||
max, passed := alert.Check(alertsStore[alert.ID][server.ID])
|
max, passed := alert.Check(alertsStore[alert.ID][server.ID])
|
||||||
if !passed {
|
if !passed {
|
||||||
alertsPrevState[alert.ID][server.ID] = _RuleCheckFail
|
alertsPrevState[alert.ID][server.ID] = _RuleCheckFail
|
||||||
message := fmt.Sprintf("[主机故障] %s(%s) 规则:%s", server.Name, IPDesensitize(server.Host.IP), alert.Name)
|
message := fmt.Sprintf("$%d$[主机故障] %s(%s) 规则:%s", server.ID, server.Name, IPDesensitize(server.Host.IP), alert.Name)
|
||||||
go SendNotification(alert.NotificationTag, message, true)
|
go SendNotification(alert.NotificationTag, message, true)
|
||||||
} else {
|
} else {
|
||||||
if alertsPrevState[alert.ID][server.ID] == _RuleCheckFail {
|
if alertsPrevState[alert.ID][server.ID] == _RuleCheckFail {
|
||||||
message := fmt.Sprintf("[主机恢复] %s(%s) 规则:%s", server.Name, IPDesensitize(server.Host.IP), alert.Name)
|
message := fmt.Sprintf("$%d$[主机恢复] %s(%s) 规则:%s", server.ID, server.Name, IPDesensitize(server.Host.IP), alert.Name)
|
||||||
go SendNotification(alert.NotificationTag, message, true)
|
go SendNotification(alert.NotificationTag, message, true)
|
||||||
}
|
}
|
||||||
alertsPrevState[alert.ID][server.ID] = _RuleCheckPass
|
alertsPrevState[alert.ID][server.ID] = _RuleCheckPass
|
||||||
|
Loading…
Reference in New Issue
Block a user