fixes
This commit is contained in:
		
							parent
							
								
									bc8f02e0a9
								
							
						
					
					
						commit
						ca051cd1cc
					
				
					 10 changed files with 21 additions and 17 deletions
				
			
		|  | @ -5,7 +5,7 @@ Cross platform command line application to run health checks against sensor stat | ||||||
| This tool lets you automatically check if senseBoxes are still runnning correctly, | This tool lets you automatically check if senseBoxes are still runnning correctly, | ||||||
| and when that's not the case, notifies you. | and when that's not the case, notifies you. | ||||||
| Currently, email notifications are implemented, but other transports can be added easily. | Currently, email notifications are implemented, but other transports can be added easily. | ||||||
| Implemented health checks are [described below](#possible-values-for-defaulthealthchecksevents), and new ones can be added just as easily (given some knowledge of programming). | Implemented health checks are [described below](#available-healthchecks), and new ones can be added just as easily (given some knowledge of programming). | ||||||
| 
 | 
 | ||||||
| The tool has multiple modes of operation: | The tool has multiple modes of operation: | ||||||
| 
 | 
 | ||||||
|  | @ -61,7 +61,7 @@ Contributions are welcome! | ||||||
| Check out the following locations for plugging in new functionality: | Check out the following locations for plugging in new functionality: | ||||||
| 
 | 
 | ||||||
| - new notification transports: [core/notifiers.go](core/notifiers.go) | - new notification transports: [core/notifiers.go](core/notifiers.go) | ||||||
| - new health checks: [core/healthcheck*.go](core/healtchecks.go) | - new health checks: [core/healthcheck*.go](core/healthchecks.go) | ||||||
| - new commands: [cmd/](cmd/) | - new commands: [cmd/](cmd/) | ||||||
| 
 | 
 | ||||||
| Before committing and submitting a pull request, please run `go fmt ./ cmd/ core/`. | Before committing and submitting a pull request, please run `go fmt ./ cmd/ core/`. | ||||||
|  |  | ||||||
|  | @ -55,11 +55,11 @@ var debugNotificationsCmd = &cobra.Command{ | ||||||
| 
 | 
 | ||||||
| 			host, _ := os.Hostname() | 			host, _ := os.Hostname() | ||||||
| 			err = n.Submit(core.Notification{ | 			err = n.Submit(core.Notification{ | ||||||
| 				Subject: "Test notification from opeSenseMap notifier", | 				Subject: "Test notification from openSenseMap notifier", | ||||||
| 				Body:    fmt.Sprintf("Your notification set up on %s is working fine!", host), | 				Body:    fmt.Sprintf("Your notification set up on %s is working fine!", host), | ||||||
| 			}) | 			}) | ||||||
| 			if err != nil { | 			if err != nil { | ||||||
| 				notLog.Warnf("could not submit test notification for %s notifier!", transport) | 				notLog.Warnf("could not submit test notification for %s notifier: %s", transport, err) | ||||||
| 				continue | 				continue | ||||||
| 			} | 			} | ||||||
| 			notLog.Info("Test notification (successfully?) submitted, check the specified inbox") | 			notLog.Info("Test notification (successfully?) submitted, check the specified inbox") | ||||||
|  | @ -4,9 +4,10 @@ import ( | ||||||
| 	"os" | 	"os" | ||||||
| 	"strings" | 	"strings" | ||||||
| 
 | 
 | ||||||
| 	"github.com/noerw/osem_notify/utils" |  | ||||||
| 	log "github.com/sirupsen/logrus" | 	log "github.com/sirupsen/logrus" | ||||||
| 	"github.com/spf13/viper" | 	"github.com/spf13/viper" | ||||||
|  | 
 | ||||||
|  | 	"github.com/noerw/osem_notify/utils" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // initConfig reads in config file and ENV variables if set. | // initConfig reads in config file and ENV variables if set. | ||||||
|  |  | ||||||
|  | @ -42,7 +42,9 @@ func (results BoxCheckResults) Log() { | ||||||
| 				countErr++ | 				countErr++ | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		if countErr == 0 { | 		if len(boxResults) == 0 { | ||||||
|  | 			boxLog.Infof("%s: no checks defined", box.Name) | ||||||
|  | 		} else if countErr == 0 { | ||||||
| 			boxLog.Infof("%s: all is fine!", box.Name) | 			boxLog.Infof("%s: all is fine!", box.Name) | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -5,8 +5,13 @@ import ( | ||||||
| 	"strconv" | 	"strconv" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | const ( | ||||||
|  | 	nameMin = "measurement_min" | ||||||
|  | 	nameMax = "measurement_max" | ||||||
|  | ) | ||||||
|  | 
 | ||||||
| var checkMeasurementMin = checkType{ | var checkMeasurementMin = checkType{ | ||||||
| 	name: "measurement_min", | 	name: nameMin, | ||||||
| 	toString: func(r CheckResult) string { | 	toString: func(r CheckResult) string { | ||||||
| 		return fmt.Sprintf("Sensor %s (%s) reads low value of %s", r.TargetName, r.Target, r.Value) | 		return fmt.Sprintf("Sensor %s (%s) reads low value of %s", r.TargetName, r.Target, r.Value) | ||||||
| 	}, | 	}, | ||||||
|  | @ -14,7 +19,7 @@ var checkMeasurementMin = checkType{ | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| var checkMeasurementMax = checkType{ | var checkMeasurementMax = checkType{ | ||||||
| 	name: "measurement_min", | 	name: nameMax, | ||||||
| 	toString: func(r CheckResult) string { | 	toString: func(r CheckResult) string { | ||||||
| 		return fmt.Sprintf("Sensor %s (%s) reads high value of %s", r.TargetName, r.Target, r.Value) | 		return fmt.Sprintf("Sensor %s (%s) reads high value of %s", r.TargetName, r.Target, r.Value) | ||||||
| 	}, | 	}, | ||||||
|  | @ -41,8 +46,8 @@ func validateMeasurementMinMax(e NotifyEvent, s Sensor, b Box) (CheckResult, err | ||||||
| 		return result, err | 		return result, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if e.Type == eventMeasurementValMax && val > thresh || | 	if e.Type == nameMax && val > thresh || | ||||||
| 		e.Type == eventMeasurementValMin && val < thresh { | 		e.Type == nameMin && val < thresh { | ||||||
| 		result.Status = CheckErr | 		result.Status = CheckErr | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -9,13 +9,9 @@ import ( | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const ( | const ( | ||||||
| 	CheckOk                   = "OK" | 	CheckOk        = "OK" | ||||||
| 	CheckErr                  = "FAILED" | 	CheckErr       = "FAILED" | ||||||
| 	eventMeasurementAge       = "measurement_age" | 	eventTargetAll = "all" // if event.Target is this value, all sensors will be checked | ||||||
| 	eventMeasurementValMin    = "measurement_min" |  | ||||||
| 	eventMeasurementValMax    = "measurement_max" |  | ||||||
| 	eventMeasurementValFaulty = "measurement_faulty" |  | ||||||
| 	eventTargetAll            = "all" // if event.Target is this value, all sensors will be checked |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| type checkType = struct { | type checkType = struct { | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue