mirror of
https://github.com/mentos1386/zdravko.git
synced 2024-11-22 15:53:45 +00:00
80 lines
2.1 KiB
Go
80 lines
2.1 KiB
Go
package services
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/jmoiron/sqlx"
|
|
"github.com/mentos1386/zdravko/database/models"
|
|
)
|
|
|
|
type TargetHistory struct {
|
|
*models.TargetHistory
|
|
TargetName string `db:"target_name"`
|
|
WorkerGroupName string `db:"worker_group_name"`
|
|
CheckName string `db:"check_name"`
|
|
}
|
|
|
|
type TargetHistoryDateRange string
|
|
|
|
const (
|
|
TargetHistoryDateRange60Days TargetHistoryDateRange = "60_DAYS"
|
|
TargetHistoryDateRange48Hours TargetHistoryDateRange = "48_HOURS"
|
|
TargetHistoryDateRange60Minutes TargetHistoryDateRange = "60_MINUTES"
|
|
)
|
|
|
|
func GetTargetHistoryForTarget(ctx context.Context, db *sqlx.DB, targetId string, dateRange TargetHistoryDateRange) ([]*TargetHistory, error) {
|
|
dateRangeFilter := ""
|
|
switch dateRange {
|
|
case TargetHistoryDateRange60Days:
|
|
dateRangeFilter = "AND strftime('%Y-%m-%dT%H:%M:%fZ', th.created_at) >= datetime('now', 'localtime', '-60 days')"
|
|
case TargetHistoryDateRange48Hours:
|
|
dateRangeFilter = "AND strftime('%Y-%m-%dT%H:%M:%fZ', th.created_at) >= datetime('now', 'localtime', '-48 hours')"
|
|
case TargetHistoryDateRange60Minutes:
|
|
dateRangeFilter = "AND strftime('%Y-%m-%dT%H:%M:%fZ', th.created_at) >= datetime('now', 'localtime', '-60 minutes')"
|
|
}
|
|
|
|
var targetHistory []*TargetHistory
|
|
err := db.SelectContext(
|
|
ctx,
|
|
&targetHistory,
|
|
fmt.Sprintf(`
|
|
SELECT
|
|
th.*,
|
|
t.name AS target_name,
|
|
wg.name AS worker_group_name,
|
|
c.name AS check_name
|
|
FROM target_histories th
|
|
LEFT JOIN targets t ON th.target_id = t.id
|
|
LEFT JOIN worker_groups wg ON th.worker_group_id = wg.id
|
|
LEFT JOIN checks c ON th.check_id = c.id
|
|
WHERE
|
|
th.target_id = $1
|
|
%s
|
|
ORDER BY th.created_at DESC
|
|
`, dateRangeFilter),
|
|
targetId,
|
|
)
|
|
return targetHistory, err
|
|
}
|
|
|
|
func AddHistoryForTarget(ctx context.Context, db *sqlx.DB, history *models.TargetHistory) error {
|
|
_, err := db.NamedExecContext(ctx,
|
|
`
|
|
INSERT INTO target_histories (
|
|
target_id,
|
|
worker_group_id,
|
|
check_id,
|
|
status,
|
|
note
|
|
) VALUES (
|
|
:target_id,
|
|
:worker_group_id,
|
|
:check_id,
|
|
:status,
|
|
:note
|
|
)`,
|
|
history,
|
|
)
|
|
return err
|
|
}
|