2021-07-15 04:26:51 +02:00
|
|
|
package memory
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2024-05-10 04:56:16 +02:00
|
|
|
"github.com/TwiN/gatus/v5/config/endpoint"
|
2021-07-15 04:26:51 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2024-08-12 04:40:19 +02:00
|
|
|
uptimeCleanUpThreshold = 32 * 24
|
|
|
|
uptimeRetention = 30 * 24 * time.Hour
|
2021-07-15 04:26:51 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// processUptimeAfterResult processes the result by extracting the relevant from the result and recalculating the uptime
|
|
|
|
// if necessary
|
2024-05-10 04:56:16 +02:00
|
|
|
func processUptimeAfterResult(uptime *endpoint.Uptime, result *endpoint.Result) {
|
2021-07-15 04:26:51 +02:00
|
|
|
if uptime.HourlyStatistics == nil {
|
2024-05-10 04:56:16 +02:00
|
|
|
uptime.HourlyStatistics = make(map[int64]*endpoint.HourlyUptimeStatistics)
|
2021-07-15 04:26:51 +02:00
|
|
|
}
|
|
|
|
unixTimestampFlooredAtHour := result.Timestamp.Truncate(time.Hour).Unix()
|
|
|
|
hourlyStats, _ := uptime.HourlyStatistics[unixTimestampFlooredAtHour]
|
|
|
|
if hourlyStats == nil {
|
2024-05-10 04:56:16 +02:00
|
|
|
hourlyStats = &endpoint.HourlyUptimeStatistics{}
|
2021-07-15 04:26:51 +02:00
|
|
|
uptime.HourlyStatistics[unixTimestampFlooredAtHour] = hourlyStats
|
|
|
|
}
|
|
|
|
if result.Success {
|
|
|
|
hourlyStats.SuccessfulExecutions++
|
|
|
|
}
|
|
|
|
hourlyStats.TotalExecutions++
|
|
|
|
hourlyStats.TotalExecutionsResponseTime += uint64(result.Duration.Milliseconds())
|
|
|
|
// Clean up only when we're starting to have too many useless keys
|
|
|
|
// Note that this is only triggered when there are more entries than there should be after
|
2024-08-12 04:40:19 +02:00
|
|
|
// 32 days, despite the fact that we are deleting everything that's older than 30 days.
|
|
|
|
// This is to prevent re-iterating on every `processUptimeAfterResult` as soon as the uptime has been logged for 30 days.
|
|
|
|
if len(uptime.HourlyStatistics) > uptimeCleanUpThreshold {
|
|
|
|
sevenDaysAgo := time.Now().Add(-(uptimeRetention + time.Hour)).Unix()
|
2021-07-15 04:26:51 +02:00
|
|
|
for hourlyUnixTimestamp := range uptime.HourlyStatistics {
|
|
|
|
if sevenDaysAgo > hourlyUnixTimestamp {
|
|
|
|
delete(uptime.HourlyStatistics, hourlyUnixTimestamp)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|