Documentation ¶
Overview ¶
Package core contains the main functionality of Statup. This includes everything for Services, Hits, Failures, Users, service checking mechanisms, databases, and notifiers in the notifier package
More info on: https://github.com/hunterlong/statup
Index ¶
- Variables
- func CheckHash(password, hash string) bool
- func CloseDB()
- func CountFailures() uint64
- func CountUsers() int64
- func DatabaseMaintence()
- func Dbtimestamp(group string, column string) string
- func DefaultPort(db string) int64
- func DeleteAllSince(table string, date time.Time)
- func DeleteConfig() error
- func ExportChartsJs() string
- func ExportSettings() ([]byte, error)
- func GetLocalIP() string
- func InitApp()
- func InsertLargeSampleData() error
- func InsertNotifierDB() error
- func InsertSampleData() error
- func InsertSampleHits() error
- func SampleData() error
- func SelectServicer(id int64) types.ServiceInterface
- func Services() []types.ServiceInterface
- type Checkin
- func (c *Checkin) AfterFind() (err error)
- func (c *Checkin) AllFailures() []*types.Failure
- func (c *Checkin) AllHits() []*types.CheckinHit
- func (c *Checkin) BeforeCreate() (err error)
- func (c *Checkin) Create() (int64, error)
- func (c *Checkin) CreateFailure() (int64, error)
- func (c *Checkin) Delete() error
- func (c *Checkin) Expected() time.Duration
- func (c *Checkin) Grace() time.Duration
- func (c *Checkin) Last() *CheckinHit
- func (c *Checkin) Link() string
- func (c *Checkin) Period() time.Duration
- func (c *Checkin) RecheckCheckinFailure(guard chan struct{})
- func (c *Checkin) Routine()
- func (c *Checkin) Service() *Service
- func (c *Checkin) String() string
- func (c *Checkin) Update() (int64, error)
- type CheckinHit
- type Core
- func (c *Core) AfterFind() (err error)
- func (c Core) AllOnline() bool
- func (c Core) BaseSASS() string
- func (c *Core) Count24HFailures() uint64
- func (c *Core) CountOnline() int
- func (c Core) CurrentTime() string
- func (c Core) Messages() []*Message
- func (c Core) MobileSASS() string
- func (c Core) SassVars() string
- func (c *Core) SelectAllServices(start bool) ([]*Service, error)
- func (c *Core) ServicesCount() int
- func (c *Core) ToCore() *types.Core
- func (c Core) UsingAssets() bool
- type DateScan
- type DateScanObj
- type DbConfig
- func (db *DbConfig) Connect(retry bool, location string) error
- func (c *DbConfig) CreateCore() *Core
- func (db *DbConfig) CreateDatabase() error
- func (db *DbConfig) DropDatabase() error
- func (db *DbConfig) InsertCore() (*Core, error)
- func (db *DbConfig) MigrateDatabase() error
- func (db *DbConfig) Save() (*DbConfig, error)
- func (db *DbConfig) Update() error
- type ErrorResponse
- type ExportData
- type Hit
- type Message
- type PluginJSON
- type PluginRepos
- type Service
- func (s *Service) ActiveMessages() []*Message
- func (s *Service) AfterFind() (err error)
- func (s *Service) AllFailures() []*failure
- func (s *Service) AvgTime() float64
- func (s *Service) AvgUptime(ago time.Time) string
- func (s *Service) AvgUptime24() string
- func (s *Service) BeforeCreate() (err error)
- func (s *Service) Check(record bool)
- func (s *Service) CheckQueue(record bool)
- func (s *Service) CheckinProcess()
- func (s *Service) Checkins() []*Checkin
- func (s *Service) CountHits() (int64, error)
- func (s *Service) Create(check bool) (int64, error)
- func (s *Service) CreateFailure(fail types.FailureInterface) (int64, error)
- func (s *Service) CreateHit(h *types.Hit) (int64, error)
- func (s *Service) Delete() error
- func (s *Service) DeleteFailures()
- func (s *Service) Downtime() time.Duration
- func (s *Service) DowntimeText() string
- func (s *Service) Hits() ([]*types.Hit, error)
- func (s *Service) HitsBetween(t1, t2 time.Time, group string, column string) *gorm.DB
- func (s *Service) LimitedCheckinFailures(amount int64) []*failure
- func (s *Service) LimitedCheckins() []*Checkin
- func (s *Service) LimitedFailures(amount int64) []*failure
- func (s *Service) LimitedHits() ([]*types.Hit, error)
- func (s *Service) Messages() []*Message
- func (s *Service) Online24() float32
- func (s *Service) OnlineSince(ago time.Time) float32
- func (s *Service) Select() *types.Service
- func (s *Service) SmallText() string
- func (s *Service) Sum() (float64, error)
- func (s *Service) ToJSON() string
- func (s *Service) TotalFailures() (uint64, error)
- func (s *Service) TotalFailures24() (uint64, error)
- func (s *Service) TotalFailuresSince(ago time.Time) (uint64, error)
- func (s *Service) TotalHits() (uint64, error)
- func (s *Service) TotalHitsSince(ago time.Time) (uint64, error)
- func (s *Service) TotalUptime() string
- func (s *Service) Update(restart bool) error
- func (s *Service) UpdateSingle(attr ...interface{}) error
- type ServiceOrder
- type User
Constants ¶
This section is empty.
Variables ¶
var ( Configs *DbConfig // Configs holds all of the config.yml and database info CoreApp *Core // CoreApp is a global variable that contains many elements SetupMode bool // SetupMode will be true if Statup does not have a database connection VERSION string // VERSION is set on build automatically by setting a -ldflag )
var ( // DbSession stores the Statup database session DbSession *gorm.DB DbModels []interface{} )
Functions ¶
func CloseDB ¶ added in v0.79.1
func CloseDB()
CloseDB will close the database connection if available
func CountFailures ¶
func CountFailures() uint64
CountFailures returns the total count of failures for all services
func DatabaseMaintence ¶
func DatabaseMaintence()
DatabaseMaintence will automatically delete old records from 'failures' and 'hits' this function is currently set to delete records 7+ days old every 60 minutes
func Dbtimestamp ¶ added in v0.79.1
Dbtimestamp will return a SQL query for grouping by date
func DefaultPort ¶ added in v0.79.1
DefaultPort accepts a database type and returns its default port
func DeleteAllSince ¶
DeleteAllSince will delete a specific table's records based on a time.
func ExportChartsJs ¶ added in v0.79.1
func ExportChartsJs() string
ExportChartsJs renders the charts for the index page
func ExportSettings ¶ added in v0.79.9
func GetLocalIP ¶ added in v0.79.9
func GetLocalIP() string
GetLocalIP returns the non loopback local IP of the host
func InsertLargeSampleData ¶ added in v0.79.1
func InsertLargeSampleData() error
InsertLargeSampleData will create the example/dummy services for testing the Statup server
func InsertNotifierDB ¶ added in v0.79.1
func InsertNotifierDB() error
InsertNotifierDB inject the Statup database instance to the Notifier package
func InsertSampleData ¶ added in v0.79.1
func InsertSampleData() error
InsertSampleData will create the example/dummy services for a brand new Statup installation
func InsertSampleHits ¶ added in v0.79.1
func InsertSampleHits() error
InsertSampleHits will create a couple new hits for the sample services
func SampleData ¶ added in v0.79.1
func SampleData() error
SampleData runs all the sample data for a new Statup installation
func SelectServicer ¶ added in v0.79.7
func SelectServicer(id int64) types.ServiceInterface
SelectServicer returns a types.ServiceInterface from in memory
func Services ¶ added in v0.79.1
func Services() []types.ServiceInterface
Types ¶
type Checkin ¶
func AllCheckins ¶ added in v0.79.9
func AllCheckins() []*Checkin
AllCheckins returns all checkin in system
func ReturnCheckin ¶ added in v0.79.1
ReturnCheckin converts *types.Checking to *core.Checkin
func SelectCheckin ¶ added in v0.79.1
SelectCheckin will find a Checkin based on the API supplied
func SelectCheckinId ¶ added in v0.79.1
SelectCheckin will find a Checkin based on the API supplied
func (*Checkin) AllFailures ¶ added in v0.79.9
Hits returns all of the CheckinHits for a given Checkin
func (*Checkin) AllHits ¶ added in v0.79.9
func (c *Checkin) AllHits() []*types.CheckinHit
AllHits returns all of the CheckinHits for a given Checkin
func (*Checkin) BeforeCreate ¶ added in v0.79.1
BeforeCreate for Checkin will set CreatedAt to UTC
func (*Checkin) CreateFailure ¶
func (*Checkin) Expected ¶ added in v0.79.1
Expected returns the duration of when the serviec should receive a Checkin
func (*Checkin) Grace ¶ added in v0.79.1
Grace will return the duration of the Checkin Grace Period (after service hasn't responded, wait a bit for a response)
func (*Checkin) Last ¶ added in v0.79.1
func (c *Checkin) Last() *CheckinHit
Last returns the last checkinHit for a Checkin
func (*Checkin) RecheckCheckinFailure ¶
func (c *Checkin) RecheckCheckinFailure(guard chan struct{})
RecheckCheckinFailure will check if a Service Checkin has been reported yet
type CheckinHit ¶ added in v0.79.9
type CheckinHit struct {
*types.CheckinHit
}
func ReturnCheckinHit ¶ added in v0.79.1
func ReturnCheckinHit(c *types.CheckinHit) *CheckinHit
ReturnCheckinHit converts *types.checkinHit to *core.checkinHit
func (*CheckinHit) AfterFind ¶ added in v0.79.9
func (c *CheckinHit) AfterFind() (err error)
AfterFind for checkinHit will set the timezone
func (*CheckinHit) Ago ¶ added in v0.79.9
func (c *CheckinHit) Ago() string
Ago returns the duration of time between now and the last successful checkinHit
func (*CheckinHit) BeforeCreate ¶ added in v0.79.9
func (c *CheckinHit) BeforeCreate() (err error)
BeforeCreate for checkinHit will set CreatedAt to UTC
func (*CheckinHit) Create ¶ added in v0.79.9
func (c *CheckinHit) Create() (int64, error)
Create will create a new successful checkinHit
type Core ¶
func SelectCore ¶
SelectCore will return the CoreApp global variable and the settings/configs for Statup
func UpdateCore ¶ added in v0.79.1
UpdateCore will update the CoreApp variable inside of the 'core' table in database
func (Core) BaseSASS ¶
BaseSASS is the base design , this opens the file /assets/scss/base.scss to be edited in Theme
func (*Core) Count24HFailures ¶ added in v0.79.1
Count24HFailures returns the amount of failures for a service within the last 24 hours
func (Core) CurrentTime ¶ added in v0.79.1
CurrentTime will return the current local time
func (Core) MobileSASS ¶ added in v0.28.5
MobileSASS is the -webkit responsive custom css designs. This opens the file /assets/scss/mobile.scss to be edited in Theme
func (*Core) SelectAllServices ¶ added in v0.79.1
SelectAllServices returns a slice of *core.Service to be store on []*core.Services, should only be called once on startup.
func (*Core) ServicesCount ¶ added in v0.79.1
ServicesCount returns the amount of services inside the []*core.Services slice
func (Core) UsingAssets ¶
UsingAssets will return true if /assets folder is present
type DateScanObj ¶ added in v0.79.1
type DateScanObj struct {
Array []DateScan `json:"data"`
}
DateScanObj struct is for creating the charts.js graph JSON array
func GraphDataRaw ¶ added in v0.79.1
func GraphDataRaw(service types.ServiceInterface, start, end time.Time, group string, column string) *DateScanObj
GraphDataRaw will return all the hits between 2 times for a Service
func (*DateScanObj) ToString ¶ added in v0.79.1
func (d *DateScanObj) ToString() string
ToString will convert the DateScanObj into a JSON string for the charts to render
type DbConfig ¶
DbConfig stores the config.yml file for the statup configuration
func EnvToConfig ¶ added in v0.79.1
func EnvToConfig() *DbConfig
EnvToConfig converts environment variables to a DbConfig variable
func LoadConfigFile ¶ added in v0.79.1
LoadConfigFile will attempt to load the 'config.yml' file in a specific directory
func LoadUsingEnv ¶ added in v0.29.7
LoadUsingEnv will attempt to load database configs based on environment variables. If DB_CONN is set if will force this function.
func (*DbConfig) Connect ¶ added in v0.79.1
Connect will attempt to connect to the sqlite, postgres, or mysql database
func (*DbConfig) CreateCore ¶ added in v0.79.1
CreateCore will initialize the global variable 'CoreApp". This global variable contains most of Statup app.
func (*DbConfig) CreateDatabase ¶ added in v0.79.1
CreateDatabase will CREATE TABLES for each of the Statup elements
func (*DbConfig) DropDatabase ¶ added in v0.79.1
DropDatabase will DROP each table Statup created
func (*DbConfig) InsertCore ¶ added in v0.79.1
InsertCore create the single row for the Core settings in Statup
func (*DbConfig) MigrateDatabase ¶ added in v0.79.1
MigrateDatabase will migrate the database structure to current version. This function will NOT remove previous records, tables or columns from the database. If this function has an issue, it will ROLLBACK to the previous state.
type ErrorResponse ¶
type ErrorResponse struct {
Error string
}
ErrorResponse is used for HTTP errors to show to User
type ExportData ¶ added in v0.79.9
type ExportData struct { Core *types.Core `json:"core"` Services []types.ServiceInterface `json:"services"` Messages []*Message `json:"messages"` Checkins []*Checkin `json:"checkins"` Users []*User `json:"users"` Notifiers []types.AllNotifiers `json:"notifiers"` }
type Hit ¶
func (*Hit) BeforeCreate ¶ added in v0.79.1
BeforeCreate for Hit will set CreatedAt to UTC
type Message ¶ added in v0.79.4
func ReturnMessage ¶ added in v0.79.4
ReturnMessage will convert *types.Message to *core.Message
func SelectMessage ¶ added in v0.79.4
SelectMessage returns a Message based on the ID passed
func SelectMessages ¶ added in v0.79.4
SelectMessages returns all messages
func SelectServiceMessages ¶ added in v0.79.4
SelectServiceMessages returns all messages for a service
func (*Message) BeforeCreate ¶ added in v0.79.9
BeforeCreate for Message will set CreatedAt to UTC
func (*Message) Create ¶ added in v0.79.4
Create will create a Message and insert it into the database
type PluginJSON ¶
type PluginJSON types.PluginJSON
type PluginRepos ¶
type PluginRepos types.PluginRepos
type Service ¶
func ReturnService ¶ added in v0.79.1
ReturnService will convert *types.Service to *core.Service
func SelectService ¶
SelectService returns a *core.Service from in memory
func (*Service) ActiveMessages ¶ added in v0.79.4
ActiveMessages returns all Messages for a Service
func (*Service) AllFailures ¶ added in v0.79.1
func (s *Service) AllFailures() []*failure
AllFailures will return all failures attached to a service
func (*Service) AvgTime ¶
AvgTime will return the average amount of time for a service to response back successfully
func (*Service) AvgUptime24 ¶ added in v0.79.1
AvgUptime24 returns a service's average online status for last 24 hours
func (*Service) BeforeCreate ¶ added in v0.79.1
BeforeCreate for Service will set CreatedAt to UTC
func (*Service) CheckQueue ¶
CheckQueue is the main go routine for checking a service
func (*Service) CheckinProcess ¶ added in v0.79.1
func (s *Service) CheckinProcess()
CheckinProcess runs the checkin routine for each checkin attached to service
func (*Service) CreateFailure ¶
func (s *Service) CreateFailure(fail types.FailureInterface) (int64, error)
CreateFailure will create a new failure record for a service
func (*Service) CreateHit ¶
CreateHit will create a new 'hit' record in the database for a successful/online service
func (*Service) Delete ¶
Delete will remove a service from the database, it will also end the service checking go routine
func (*Service) DeleteFailures ¶
func (s *Service) DeleteFailures()
DeleteFailures will delete all failures for a service
func (*Service) Downtime ¶ added in v0.79.1
Downtime returns the amount of time of a offline service
func (*Service) DowntimeText ¶ added in v0.79.1
DowntimeText will return the amount of downtime for a service based on the duration
service.DowntimeText() // Service has been offline for 15 minutes
func (*Service) HitsBetween ¶ added in v0.79.1
HitsBetween returns the gorm database query for a collection of service hits between a time range
func (*Service) LimitedCheckinFailures ¶ added in v0.79.91
LimitedFailures will return the last amount of failures from a service
func (*Service) LimitedCheckins ¶ added in v0.79.1
LimitedCheckins will return a slice of Checkins for a Service
func (*Service) LimitedFailures ¶
LimitedFailures will return the last amount of failures from a service
func (*Service) LimitedHits ¶
LimitedHits returns the last 1024 successful/online 'hit' records for a service
func (*Service) OnlineSince ¶ added in v0.79.1
OnlineSince accepts a time since parameter to return the percent of a service's uptime.
func (*Service) SmallText ¶ added in v0.27.9
SmallText returns a short description about a services status
service.SmallText() // Online since Monday 3:04:05PM, Jan _2 2006
func (*Service) TotalFailures ¶
TotalFailures returns the total amount of failures for a service
func (*Service) TotalFailures24 ¶ added in v0.79.1
TotalFailures24 returns the amount of failures for a service within the last 24 hours
func (*Service) TotalFailuresSince ¶ added in v0.79.1
TotalFailuresSince returns the total amount of failures for a service since a specific time/date
func (*Service) TotalHitsSince ¶ added in v0.79.1
TotalHitsSince returns the total amount of hits based on a specific time/date
func (*Service) TotalUptime ¶
TotalUptime returns the total uptime percent of a service
func (*Service) Update ¶
Update will update a service in the database, the service's checking routine can be restarted by passing true
func (*Service) UpdateSingle ¶ added in v0.79.1
UpdateSingle will update a single column for a service
type ServiceOrder ¶ added in v0.79.1
type ServiceOrder []types.ServiceInterface
ServiceOrder will reorder the services based on 'order_id' (Order)
func (ServiceOrder) Len ¶ added in v0.79.1
func (c ServiceOrder) Len() int
Sort interface for resroting the Services in order
func (ServiceOrder) Less ¶ added in v0.79.1
func (c ServiceOrder) Less(i, j int) bool
func (ServiceOrder) Swap ¶ added in v0.79.1
func (c ServiceOrder) Swap(i, j int)
type User ¶
func AuthUser ¶
AuthUser will return the User and a boolean if authentication was correct. AuthUser accepts username, and password as a string
func ReturnUser ¶ added in v0.79.1
ReturnUser returns *core.User based off a *types.User
func SelectUser ¶
SelectUser returns the User based on the User's ID.
func SelectUsername ¶
SelectUsername returns the User based on the User's username
func (*User) BeforeCreate ¶ added in v0.79.9
BeforeCreate for User will set CreatedAt to UTC
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package notifier contains the main functionality for the Statup Notification system Example Notifier Below is an example of a Notifier with multiple Form values to custom your inputs.
|
Package notifier contains the main functionality for the Statup Notification system Example Notifier Below is an example of a Notifier with multiple Form values to custom your inputs. |