statping-ng/checker.go

95 lines
1.8 KiB
Go

package main
import (
"fmt"
"io/ioutil"
"net/http"
"regexp"
"time"
)
func CheckServices() {
services, _ = SelectAllServices()
for _, v := range services {
obj := v
go obj.StartCheckins()
go obj.CheckQueue()
}
}
func (s *Service) CheckQueue() {
s.Check()
if s.Interval < 1 {
s.Interval = 1
}
fmt.Printf(" Service: %v | Online: %v | Latency: %v\n", s.Name, s.Online, s.Latency)
time.Sleep(time.Duration(s.Interval) * time.Second)
s.CheckQueue()
}
func (s *Service) Check() *Service {
t1 := time.Now()
client := http.Client{
Timeout: 30 * time.Second,
}
response, err := client.Get(s.Domain)
t2 := time.Now()
s.Latency = t2.Sub(t1).Seconds()
if err != nil {
s.Failure(fmt.Sprintf("HTTP Error %v", err))
return s
}
defer response.Body.Close()
contents, _ := ioutil.ReadAll(response.Body)
if s.Expected != "" {
match, _ := regexp.MatchString(s.Expected, string(contents))
if !match {
s.LastResponse = string(contents)
s.LastStatusCode = response.StatusCode
s.Failure(fmt.Sprintf("HTTP Response Body did not match '%v'", s.Expected))
return s
}
}
if s.ExpectedStatus != response.StatusCode {
s.LastResponse = string(contents)
s.LastStatusCode = response.StatusCode
s.Failure(fmt.Sprintf("HTTP Status Code %v did not match %v", response.StatusCode, s.ExpectedStatus))
return s
}
s.LastResponse = string(contents)
s.LastStatusCode = response.StatusCode
s.Online = true
s.Record(response)
return s
}
type HitData struct {
Latency float64
}
func (s *Service) Record(response *http.Response) {
s.Online = true
s.LastOnline = time.Now()
data := HitData{
Latency: s.Latency,
}
s.CreateHit(data)
OnSuccess(s)
}
type FailureData struct {
Issue string
}
func (s *Service) Failure(issue string) {
s.Online = false
data := FailureData{
Issue: issue,
}
s.CreateFailure(data)
SendFailureEmail(s)
OnFailure(s)
}