-
Notifications
You must be signed in to change notification settings - Fork 145
/
get_queue_metrics.go
67 lines (50 loc) · 1.83 KB
/
get_queue_metrics.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package tenants
import (
"fmt"
"strings"
"github.com/labstack/echo/v4"
"github.com/hatchet-dev/hatchet/api/v1/server/oas/apierrors"
"github.com/hatchet-dev/hatchet/api/v1/server/oas/gen"
"github.com/hatchet-dev/hatchet/pkg/repository"
"github.com/hatchet-dev/hatchet/pkg/repository/prisma/db"
)
func (t *TenantService) TenantGetQueueMetrics(ctx echo.Context, request gen.TenantGetQueueMetricsRequestObject) (gen.TenantGetQueueMetricsResponseObject, error) {
tenant := ctx.Get("tenant").(*db.TenantModel)
opts := repository.GetQueueMetricsOpts{}
if request.Params.AdditionalMetadata != nil {
additionalMetadata := make(map[string]interface{}, len(*request.Params.AdditionalMetadata))
for _, v := range *request.Params.AdditionalMetadata {
splitValue := strings.Split(fmt.Sprintf("%v", v), ":")
if len(splitValue) == 2 {
additionalMetadata[splitValue[0]] = splitValue[1]
} else {
return gen.TenantGetQueueMetrics400JSONResponse(apierrors.NewAPIErrors("Additional metadata filters must be in the format key:value.")), nil
}
}
opts.AdditionalMetadata = additionalMetadata
}
if request.Params.Workflows != nil {
opts.WorkflowIds = *request.Params.Workflows
}
metrics, err := t.config.APIRepository.Tenant().GetQueueMetrics(tenant.ID, &opts)
if err != nil {
return nil, err
}
respWorkflowMap := make(map[string]gen.QueueMetrics, len(metrics.ByWorkflowId))
for k, v := range metrics.ByWorkflowId {
respWorkflowMap[k] = gen.QueueMetrics{
NumPending: v.Pending,
NumQueued: v.PendingAssignment,
NumRunning: v.Running,
}
}
resp := gen.TenantQueueMetrics{
Total: &gen.QueueMetrics{
NumPending: metrics.Total.Pending,
NumQueued: metrics.Total.PendingAssignment,
NumRunning: metrics.Total.Running,
},
Workflow: &respWorkflowMap,
}
return gen.TenantGetQueueMetrics200JSONResponse(resp), nil
}