forked from kyma-project/control-plane
/
metrics.go
25 lines (22 loc) · 1.55 KB
/
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
package metrics
import (
"github.com/kyma-project/control-plane/components/kyma-environment-broker/internal/event"
"github.com/kyma-project/control-plane/components/kyma-environment-broker/internal/process"
"github.com/prometheus/client_golang/prometheus"
)
func RegisterAll(sub event.Subscriber, operationStatsGetter OperationsStatsGetter, instanceStatsGetter InstancesStatsGetter) {
opResultCollector := NewOperationResultCollector()
opDurationCollector := NewOperationDurationCollector()
stepResultCollector := NewStepResultCollector()
prometheus.MustRegister(opResultCollector, opDurationCollector, stepResultCollector)
prometheus.MustRegister(NewOperationsCollector(operationStatsGetter))
prometheus.MustRegister(NewInstancesCollector(instanceStatsGetter))
sub.Subscribe(process.ProvisioningStepProcessed{}, opResultCollector.OnProvisioningStepProcessed)
sub.Subscribe(process.DeprovisioningStepProcessed{}, opResultCollector.OnDeprovisioningStepProcessed)
sub.Subscribe(process.UpgradeKymaStepProcessed{}, opResultCollector.OnUpgradeKymaStepProcessed)
sub.Subscribe(process.UpgradeClusterStepProcessed{}, opResultCollector.OnUpgradeClusterStepProcessed)
sub.Subscribe(process.ProvisioningStepProcessed{}, opDurationCollector.OnProvisioningStepProcessed)
sub.Subscribe(process.DeprovisioningStepProcessed{}, opDurationCollector.OnDeprovisioningStepProcessed)
sub.Subscribe(process.ProvisioningStepProcessed{}, stepResultCollector.OnProvisioningStepProcessed)
sub.Subscribe(process.DeprovisioningStepProcessed{}, stepResultCollector.OnDeprovisioningStepProcessed)
}