statping/core/checkin.go

156 lines
3.5 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-22 06:56:44 +00:00
import (
"fmt"
"github.com/ararog/timeago"
2018-06-30 00:57:05 +00:00
"github.com/hunterlong/statup/types"
"github.com/hunterlong/statup/utils"
2018-06-22 06:56:44 +00:00
"time"
)
type Checkin struct {
*types.Checkin
}
2018-06-30 00:57:05 +00:00
2018-10-03 10:47:32 +00:00
type CheckinHit struct {
*types.CheckinHit
}
2018-06-30 00:57:05 +00:00
func (c *Checkin) String() string {
2018-10-02 07:26:49 +00:00
return c.ApiKey
2018-06-30 00:57:05 +00:00
}
func ReturnCheckin(s *types.Checkin) *Checkin {
return &Checkin{Checkin: s}
}
2018-10-03 10:47:32 +00:00
func ReturnCheckinHit(h *types.CheckinHit) *CheckinHit {
return &CheckinHit{CheckinHit: h}
}
func SelectCheckin(api string) *Checkin {
var checkin Checkin
checkinDB().Where("api_key = ?", api).First(&checkin)
return &checkin
}
2018-10-05 04:28:38 +00:00
func (u *Checkin) Period() time.Duration {
2018-10-04 08:18:55 +00:00
duration, _ := time.ParseDuration(fmt.Sprintf("%vs", u.Interval))
return duration
}
2018-10-05 04:28:38 +00:00
func (u *Checkin) Grace() time.Duration {
2018-10-04 08:18:55 +00:00
duration, _ := time.ParseDuration(fmt.Sprintf("%vs", u.GracePeriod))
return duration
}
2018-10-05 04:28:38 +00:00
func (u *Checkin) Expected() time.Duration {
2018-10-04 08:18:55 +00:00
last := u.Last().CreatedAt
now := time.Now()
lastDir := now.Sub(last)
sub := time.Duration(u.Period() - lastDir)
return sub
}
2018-10-05 04:28:38 +00:00
func (u *Checkin) Last() CheckinHit {
2018-10-04 08:18:55 +00:00
var hit CheckinHit
checkinHitsDB().Where("checkin = ?", u.Id).Last(&hit)
return hit
2018-06-22 06:56:44 +00:00
}
2018-10-03 10:47:32 +00:00
func (u *Checkin) Hits() []CheckinHit {
var checkins []CheckinHit
2018-10-04 08:18:55 +00:00
checkinHitsDB().Where("checkin = ?", u.Id).Order("id DESC").Find(&checkins)
2018-10-03 10:47:32 +00:00
return checkins
}
2018-10-06 03:35:53 +00:00
func (u *Checkin) Create() (int64, error) {
u.ApiKey = utils.RandomString(7)
row := checkinDB().Create(&u)
if row.Error != nil {
utils.Log(2, row.Error)
return 0, row.Error
2018-10-04 08:18:55 +00:00
}
2018-10-06 03:35:53 +00:00
return u.Id, row.Error
}
func (u *Checkin) Update() (int64, error) {
row := checkinDB().Update(&u)
2018-10-05 04:28:38 +00:00
if row.Error != nil {
utils.Log(2, row.Error)
return 0, row.Error
2018-06-22 06:56:44 +00:00
}
return u.Id, row.Error
2018-06-22 06:56:44 +00:00
}
2018-10-03 10:47:32 +00:00
func (u *CheckinHit) Create() (int64, error) {
2018-10-04 08:18:55 +00:00
if u.CreatedAt.IsZero() {
u.CreatedAt = time.Now()
}
2018-10-03 10:47:32 +00:00
row := checkinHitsDB().Create(u)
2018-10-05 06:04:26 +00:00
if row.Error != nil {
2018-10-03 10:47:32 +00:00
utils.Log(2, row.Error)
return 0, row.Error
}
return u.Id, row.Error
}
2018-06-22 06:56:44 +00:00
func SelectCheckinApi(api string) *Checkin {
var checkin *Checkin
checkinDB().Where("api = ?", api).Find(&checkin)
2018-06-22 06:56:44 +00:00
return checkin
}
2018-10-02 07:26:49 +00:00
func (c *Checkin) CreateHit() (int64, error) {
c.CreatedAt = time.Now()
row := checkinDB().Create(c)
2018-10-05 06:04:26 +00:00
if row.Error != nil {
2018-10-02 07:26:49 +00:00
utils.Log(2, row.Error)
return 0, row.Error
}
return c.Id, row.Error
2018-06-22 06:56:44 +00:00
}
func (c *Checkin) RecheckCheckinFailure(guard chan struct{}) {
2018-10-02 07:26:49 +00:00
between := time.Now().Sub(time.Now()).Seconds()
2018-06-22 06:56:44 +00:00
if between > float64(c.Interval) {
fmt.Println("rechecking every 15 seconds!")
c.CreateFailure()
time.Sleep(15 * time.Second)
guard <- struct{}{}
c.RecheckCheckinFailure(guard)
} else {
fmt.Println("i recovered!!")
}
<-guard
}
func (f *Checkin) CreateFailure() {
}
func (f *Checkin) Ago() string {
2018-10-02 07:26:49 +00:00
got, _ := timeago.TimeAgoWithTime(time.Now(), time.Now())
2018-06-22 06:56:44 +00:00
return got
}
2018-10-03 10:47:32 +00:00
func (f *CheckinHit) Ago() string {
got, _ := timeago.TimeAgoWithTime(time.Now(), time.Now())
return got
}