2024-02-27 11:04:05 +00:00
|
|
|
package models
|
|
|
|
|
|
|
|
import (
|
2024-02-29 22:42:56 +00:00
|
|
|
"database/sql/driver"
|
|
|
|
"fmt"
|
2024-02-27 11:04:05 +00:00
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
2024-02-29 22:42:56 +00:00
|
|
|
type Time struct {
|
|
|
|
Time time.Time
|
|
|
|
}
|
|
|
|
|
|
|
|
// rfc3339Milli is like time.RFC3339Nano, but with millisecond precision, and fractional seconds do not have trailing
|
|
|
|
// zeros removed.
|
|
|
|
const rfc3339Milli = "2006-01-02T15:04:05.000Z07:00"
|
|
|
|
|
|
|
|
// Value satisfies driver.Valuer interface.
|
|
|
|
func (t *Time) Value() (driver.Value, error) {
|
|
|
|
return t.Time.UTC().Format(rfc3339Milli), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Scan satisfies sql.Scanner interface.
|
|
|
|
func (t *Time) Scan(src any) error {
|
|
|
|
if src == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
s, ok := src.(string)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("error scanning time, got %+v", src)
|
|
|
|
}
|
|
|
|
|
|
|
|
parsedT, err := time.Parse(rfc3339Milli, s)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Time = parsedT.UTC()
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-03-01 09:53:36 +00:00
|
|
|
type OAuth2State struct {
|
|
|
|
State string `db:"state"`
|
|
|
|
ExpiresAt *Time `db:"expires_at"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type MonitorStatus string
|
|
|
|
|
|
|
|
const (
|
|
|
|
MonitorSuccess MonitorStatus = "SUCCESS"
|
|
|
|
MonitorFailure MonitorStatus = "FAILURE"
|
|
|
|
MonitorError MonitorStatus = "ERROR"
|
|
|
|
MonitorUnknown MonitorStatus = "UNKNOWN"
|
|
|
|
)
|
|
|
|
|
2024-02-27 11:04:05 +00:00
|
|
|
type Monitor struct {
|
2024-03-01 09:53:36 +00:00
|
|
|
CreatedAt *Time `db:"created_at"`
|
|
|
|
UpdatedAt *Time `db:"updated_at"`
|
2024-02-27 11:04:05 +00:00
|
|
|
|
2024-03-03 14:28:25 +00:00
|
|
|
Id string `db:"id"`
|
|
|
|
Name string `db:"name"`
|
|
|
|
Group string `db:"group"`
|
2024-02-27 11:04:05 +00:00
|
|
|
|
|
|
|
Schedule string `db:"schedule"`
|
|
|
|
Script string `db:"script"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type MonitorWithWorkerGroups struct {
|
|
|
|
Monitor
|
|
|
|
|
|
|
|
// List of worker group names
|
|
|
|
WorkerGroups []string
|
|
|
|
}
|
|
|
|
|
|
|
|
type MonitorHistory struct {
|
2024-03-01 09:53:36 +00:00
|
|
|
CreatedAt *Time `db:"created_at"`
|
2024-02-29 22:42:56 +00:00
|
|
|
|
|
|
|
MonitorId string `db:"monitor_id"`
|
|
|
|
Status MonitorStatus `db:"status"`
|
|
|
|
Note string `db:"note"`
|
2024-02-27 11:04:05 +00:00
|
|
|
|
2024-02-29 22:42:56 +00:00
|
|
|
WorkerGroupId string `db:"worker_group_id"`
|
|
|
|
WorkerGroupName string `db:"worker_group_name"`
|
2024-02-27 11:04:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type WorkerGroup struct {
|
2024-03-01 09:53:36 +00:00
|
|
|
CreatedAt *Time `db:"created_at"`
|
|
|
|
UpdatedAt *Time `db:"updated_at"`
|
2024-02-27 11:04:05 +00:00
|
|
|
|
2024-02-29 22:42:56 +00:00
|
|
|
Id string `db:"id"`
|
2024-02-27 11:04:05 +00:00
|
|
|
Name string `db:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type WorkerGroupWithMonitors struct {
|
|
|
|
WorkerGroup
|
|
|
|
|
|
|
|
// List of worker group names
|
|
|
|
Monitors []string
|
|
|
|
}
|