mirror of
https://github.com/crowdsecurity/crowdsec.git
synced 2025-05-11 12:25:53 +02:00
* refact pkg/database: context propagation (part) * more context propagation (usagemetrics) * propagate errors when updating metrics
71 lines
1.9 KiB
Go
71 lines
1.9 KiB
Go
package database
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/crowdsecurity/crowdsec/pkg/database/ent"
|
|
"github.com/crowdsecurity/crowdsec/pkg/database/ent/metric"
|
|
)
|
|
|
|
func (c *Client) CreateMetric(ctx context.Context, generatedType metric.GeneratedType, generatedBy string, receivedAt time.Time, payload string) (*ent.Metric, error) {
|
|
metric, err := c.Ent.Metric.
|
|
Create().
|
|
SetGeneratedType(generatedType).
|
|
SetGeneratedBy(generatedBy).
|
|
SetReceivedAt(receivedAt).
|
|
SetPayload(payload).
|
|
Save(ctx)
|
|
if err != nil {
|
|
c.Log.Warningf("CreateMetric: %s", err)
|
|
return nil, fmt.Errorf("storing metrics snapshot for '%s' at %s: %w", generatedBy, receivedAt, InsertFail)
|
|
}
|
|
|
|
return metric, nil
|
|
}
|
|
|
|
func (c *Client) GetLPUsageMetricsByMachineID(machineId string) ([]*ent.Metric, error) {
|
|
metrics, err := c.Ent.Metric.Query().
|
|
Where(
|
|
metric.GeneratedTypeEQ(metric.GeneratedTypeLP),
|
|
metric.GeneratedByEQ(machineId),
|
|
metric.PushedAtIsNil(),
|
|
).
|
|
All(c.CTX)
|
|
if err != nil {
|
|
c.Log.Warningf("GetLPUsageMetricsByOrigin: %s", err)
|
|
return nil, fmt.Errorf("getting LP usage metrics by origin %s: %w", machineId, err)
|
|
}
|
|
|
|
return metrics, nil
|
|
}
|
|
|
|
func (c *Client) GetBouncerUsageMetricsByName(bouncerName string) ([]*ent.Metric, error) {
|
|
metrics, err := c.Ent.Metric.Query().
|
|
Where(
|
|
metric.GeneratedTypeEQ(metric.GeneratedTypeRC),
|
|
metric.GeneratedByEQ(bouncerName),
|
|
metric.PushedAtIsNil(),
|
|
).
|
|
All(c.CTX)
|
|
if err != nil {
|
|
c.Log.Warningf("GetBouncerUsageMetricsByName: %s", err)
|
|
return nil, fmt.Errorf("getting bouncer usage metrics by name %s: %w", bouncerName, err)
|
|
}
|
|
|
|
return metrics, nil
|
|
}
|
|
|
|
func (c *Client) MarkUsageMetricsAsSent(ids []int) error {
|
|
_, err := c.Ent.Metric.Update().
|
|
Where(metric.IDIn(ids...)).
|
|
SetPushedAt(time.Now().UTC()).
|
|
Save(c.CTX)
|
|
if err != nil {
|
|
c.Log.Warningf("MarkUsageMetricsAsSent: %s", err)
|
|
return fmt.Errorf("marking usage metrics as sent: %w", err)
|
|
}
|
|
|
|
return nil
|
|
}
|