statping/core/failures.go

154 lines
4.0 KiB
Go
Raw Normal View History

2018-08-16 06:22:20 +00:00
// Statup
// Copyright (C) 2018. Hunter Long and the project contributors
// Written by Hunter Long <info@socialeck.com> and the project contributors
//
// https://github.com/hunterlong/statup
//
// The licenses for most software and other practical works are designed
// to take away your freedom to share and change the works. By contrast,
// the GNU General Public License is intended to guarantee your freedom to
// share and change all versions of a program--to make sure it remains free
// software for all its users.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
2018-06-30 00:57:05 +00:00
package core
2018-06-10 01:31:13 +00:00
2018-06-11 00:20:42 +00:00
import (
2018-06-29 05:32:50 +00:00
"fmt"
2018-06-22 04:02:57 +00:00
"github.com/ararog/timeago"
2018-07-14 02:37:39 +00:00
"github.com/hunterlong/statup/types"
2018-06-30 00:57:05 +00:00
"github.com/hunterlong/statup/utils"
2018-06-29 05:32:50 +00:00
"strings"
2018-06-11 00:20:42 +00:00
"time"
)
2018-06-10 01:31:13 +00:00
type Failure struct {
*types.Failure
}
func (s *Service) CreateFailure(f *types.Failure) (int64, error) {
f.CreatedAt = time.Now()
f.Service = s.Id
s.Failures = append(s.Failures, f)
row := failuresDB().Create(f)
if row.Error != nil {
utils.Log(3, row.Error)
return 0, row.Error
2018-07-03 21:39:56 +00:00
}
return f.Id, row.Error
2018-06-15 04:30:10 +00:00
}
func (s *Service) AllFailures() []*types.Failure {
2018-07-14 02:37:39 +00:00
var fails []*types.Failure
col := failuresDB().Where("service = ?", s.Id).Order("id desc")
err := col.Find(&fails)
if err.Error != nil {
2018-07-03 21:39:56 +00:00
utils.Log(3, fmt.Sprintf("Issue getting failures for service %v, %v", s.Name, err))
return nil
2018-07-03 21:39:56 +00:00
}
2018-06-23 00:10:37 +00:00
return fails
2018-06-10 01:31:13 +00:00
}
2018-08-21 06:54:39 +00:00
func (u *Service) DeleteFailures() {
err := DbSession.Exec(`DELETE FROM failures WHERE service = ?`, u.Id)
if err.Error != nil {
2018-08-23 07:28:48 +00:00
utils.Log(3, fmt.Sprintf("failed to delete all failures: %v", err))
2018-06-22 04:02:57 +00:00
}
2018-08-21 06:54:39 +00:00
u.Failures = nil
2018-06-22 04:02:57 +00:00
}
2018-08-19 00:37:00 +00:00
func (s *Service) LimitedFailures() []*Failure {
2018-07-17 09:18:20 +00:00
var failArr []*Failure
col := failuresDB().Where("service = ?", s.Id).Order("id desc").Limit(10)
col.Find(&failArr)
2018-07-17 09:18:20 +00:00
return failArr
2018-06-19 04:48:25 +00:00
}
func reverseFailures(input []*Failure) []*Failure {
2018-06-24 11:51:07 +00:00
if len(input) == 0 {
return input
}
return append(reverseFailures(input[1:]), input[0])
}
func (f *Failure) Ago() string {
2018-06-22 04:02:57 +00:00
got, _ := timeago.TimeAgoWithTime(time.Now(), f.CreatedAt)
return got
}
func (f *Failure) Delete() error {
db := failuresDB().Delete(f)
return db.Error
2018-06-19 00:01:03 +00:00
}
2018-06-24 06:17:31 +00:00
func CountFailures() uint64 {
var count uint64
err := failuresDB().Count(&count)
if err.Error != nil {
utils.Log(2, err.Error)
2018-06-24 06:17:31 +00:00
return 0
}
return count
}
func (s *Service) TotalFailures24() (uint64, error) {
ago := time.Now().Add(-24 * time.Hour)
return s.TotalFailuresSince(ago)
2018-06-11 00:20:42 +00:00
}
2018-08-19 00:37:00 +00:00
func (s *Service) TotalFailures() (uint64, error) {
var count uint64
rows := failuresDB().Where("service = ?", s.Id)
err := rows.Count(count)
return count, err.Error
2018-06-10 01:31:13 +00:00
}
2018-06-10 03:44:47 +00:00
func (s *Service) TotalFailuresSince(ago time.Time) (uint64, error) {
var count uint64
rows := failuresDB().Where("service = ? AND created_at > ?", s.Id, ago.Format("2006-01-02 15:04:05"))
err := rows.Count(&count)
return count, err.Error
2018-06-10 03:44:47 +00:00
}
2018-06-29 05:32:50 +00:00
func (f *Failure) ParseError() string {
err := strings.Contains(f.Issue, "connection reset by peer")
if err {
return fmt.Sprintf("Connection Reset")
}
err = strings.Contains(f.Issue, "operation timed out")
2018-06-29 05:32:50 +00:00
if err {
return fmt.Sprintf("HTTP Request Timed Out")
}
err = strings.Contains(f.Issue, "x509: certificate is valid")
if err {
return fmt.Sprintf("SSL Certificate invalid")
}
err = strings.Contains(f.Issue, "Client.Timeout exceeded while awaiting headers")
if err {
return fmt.Sprintf("Connection Timed Out")
}
2018-06-29 05:32:50 +00:00
err = strings.Contains(f.Issue, "no such host")
if err {
return fmt.Sprintf("Domain is offline or not found")
}
err = strings.Contains(f.Issue, "HTTP Status Code")
if err {
return fmt.Sprintf("Incorrect HTTP Status Code")
}
2018-06-30 00:57:05 +00:00
err = strings.Contains(f.Issue, "connection refused")
if err {
return fmt.Sprintf("Connection Failed")
}
err = strings.Contains(f.Issue, "can't assign requested address")
if err {
return fmt.Sprintf("Unable to Request Address")
}
err = strings.Contains(f.Issue, "no route to host")
if err {
return fmt.Sprintf("Domain is offline or not found")
}
2018-06-29 05:32:50 +00:00
return f.Issue
}