fix alerting
This commit is contained in:
		
							parent
							
								
									85ea0e2b06
								
							
						
					
					
						commit
						35af808b17
					
				|  | @ -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) | ||||||
|  |  | ||||||
|  | @ -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 | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue