fix alerting

This commit is contained in:
Joerg Lehmann 2019-07-12 19:50:05 +02:00
parent 85ea0e2b06
commit 35af808b17
2 changed files with 8 additions and 4 deletions

View File

@ -33,7 +33,6 @@ type MessageProperties struct {
type Message struct { type Message struct {
Prop MessageProperties `json:"DevEUI_uplink"` Prop MessageProperties `json:"DevEUI_uplink"`
} }
type payload_128 struct { type payload_128 struct {
Version uint8 Version uint8
Vbat uint8 Vbat uint8
@ -87,6 +86,7 @@ type payload_1 struct {
var file *os.File var file *os.File
var alertMap map[string]string var alertMap map[string]string
var alertLogMap map[string]string
func DecodePayload(s string, deveui string, devaddr string, lrrlat float32, lrrlon float32, write2file bool) { func DecodePayload(s string, deveui string, devaddr string, lrrlat float32, lrrlon float32, write2file bool) {
var ba []byte var ba []byte
@ -165,6 +165,10 @@ func DecodePayload(s string, deveui string, devaddr string, lrrlat float32, lrrl
sendAlert(deveui,val) sendAlert(deveui,val)
delete(alertMap,deveui) delete(alertMap,deveui)
} }
if val2, ok2 := alertLogMap[deveui]; ok2 {
WriteStringToFile(val2)
delete(alertLogMap,deveui)
}
} }
func WriteDatapoint(mytime int64, deveui string, devaddr string, v uint8, h uint8, p uint8, w uint16, w1 int32, w2 int32, t int16, lrrlat float32, lrrlon float32) { func WriteDatapoint(mytime int64, deveui string, devaddr string, v uint8, h uint8, p uint8, w uint16, w1 int32, w2 int32, t int16, lrrlat float32, lrrlon float32) {
@ -193,10 +197,9 @@ func WriteDatapoint(mytime int64, deveui string, devaddr string, v uint8, h uint
w_loss := getMaxValue(deveui) - w_gram; w_loss := getMaxValue(deveui) - w_gram;
if (w_loss > 500) { if (w_loss > 500) {
// Schwarmalarm! // Schwarmalarm!
s = fmt.Sprintf("alert,deveui=%s reason=\"swarmalarm\",w=%di,w_loss=%di %d\n",deveui,w_gram,w_loss,mytime*60*1000*1000*1000) alertLogMap[deveui] = fmt.Sprintf("alert,deveui=%s reason=\"swarmalarm\",w=%di,w_loss=%di %d\n",deveui,w_gram,w_loss,mytime*60*1000*1000*1000)
location, _ := time.LoadLocation("Europe/Zurich") location, _ := time.LoadLocation("Europe/Zurich")
alertMap[deveui] = fmt.Sprintf("*** Schwarmalarm ***\n%s\n%s\nGewichtsverlust: %d g",getDevAlias(deveui),time.Unix(mytime*60,0).In(location).Format("02.01.2006 15:04"),w_loss) alertMap[deveui] = fmt.Sprintf("*** Schwarmalarm ***\n%s\n%s\nGewichtsverlust: %d g",getDevAlias(deveui),time.Unix(mytime*60,0).In(location).Format("02.01.2006 15:04"),w_loss)
WriteStringToFile(s)
} }
} }
@ -220,6 +223,7 @@ func main() {
// Init alertMap // Init alertMap
alertMap = make(map[string]string) alertMap = make(map[string]string)
alertLogMap = make(map[string]string)
// Open Output File // Open Output File
f, err := os.OpenFile(outputfile,os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0644) f, err := os.OpenFile(outputfile,os.O_CREATE|os.O_APPEND|os.O_WRONLY, 0644)

View File

@ -1,3 +1,3 @@
#!/bin/bash #!/bin/bash
awk '{$3=strftime("%Y-%m-%d %H:%M:%S", substr($3,1,10)); print $0}' lorahandler.log awk '{$3=strftime("%Y-%m-%d %H:%M:%S", substr($NF,1,10)); print $0}' lorahandler.log