From 74feac29542ccfa9eda0bebdc2a42b83328bc5cb Mon Sep 17 00:00:00 2001 From: Lenny Consuegra Date: Tue, 5 Dec 2023 11:38:48 +0100 Subject: [PATCH] feat: add new custom metric ipa_replication --- ipahealthcheck_exporter.go | 38 +++++++++++++++++++++++++++++++++----- 1 file changed, 33 insertions(+), 5 deletions(-) diff --git a/ipahealthcheck_exporter.go b/ipahealthcheck_exporter.go index 6355e0a..6631c39 100644 --- a/ipahealthcheck_exporter.go +++ b/ipahealthcheck_exporter.go @@ -44,6 +44,12 @@ var ( []string{"ipahealthcheck", "result"}, nil, ) + ipahealthcheckReplicationDesc = prometheus.NewDesc( + "ipa_replication", + "Replication heatlh (1: success, 0: error)", + []string{"ipahealthcheck", "result", "message"}, nil, + ) + ipahealthcheckCertExpirationDesc = prometheus.NewDesc( "ipa_cert_expiration", "Expiration date of the certificates in warning or error state (unix timestamp)", @@ -59,10 +65,6 @@ var ( scrape: true, metricsDesc: ipahealthcheckReplicationCheckDesc, }, - "ReplicationCheck": { - scrape: true, - metricsDesc: ipahealthcheckReplicationCheckDesc, - }, "DogtagCertsConnectivityCheck": { scrape: true, metricsDesc: ipahealthcheckDogtagCheckDesc, @@ -101,6 +103,7 @@ func (ic ipahealthcheckCollector) Describe(ch chan<- *prometheus.Desc) { ch <- ipahealthcheckServiceStateDesc ch <- ipahealthcheckDogtagCheckDesc ch <- ipahealthcheckReplicationCheckDesc + ch <- ipahealthcheckReplicationDesc ch <- ipahealthcheckCertExpirationDesc } @@ -167,7 +170,7 @@ func (ic ipahealthcheckCollector) Collect(ch chan<- prometheus.Metric) { if scrapedChecks[check.Check].scrape { if verbose { - log.Infof("scrape=true -> add metric : %v", check) + log.Infof("scraped check -> add metric : %v", check.Check) } if check.Result == "SUCCESS" { @@ -177,8 +180,33 @@ func (ic ipahealthcheckCollector) Collect(ch chan<- prometheus.Metric) { } } + if check.Check == "ReplicationCheck" { + message := "nil" + + if verbose { + log.Infof("custom check -> add metric : %v", check.Check) + } + + if check.Kw["msg"] != nil { + if verbose { + log.Infof("msg detected in check -> add to the metric as label : %v", check.Kw["msg"]) + } + message = check.Kw["msg"].(string) + } + + if check.Result == "SUCCESS" { + ch <- prometheus.MustNewConstMetric(ipahealthcheckReplicationDesc, prometheus.GaugeValue, 1.0, check.Check, strings.ToLower(check.Result), message) + } else { + ch <- prometheus.MustNewConstMetric(ipahealthcheckReplicationDesc, prometheus.GaugeValue, 0.0, check.Check, strings.ToLower(check.Result), message) + } + } + if check.Source == "ipahealthcheck.ipa.certs" && check.Check == "IPACertmongerExpirationCheck" { + if verbose { + log.Infof("custom check -> add metric : %v", check.Check) + } + if check.Result == "WARNING" || check.Result == "ERROR" { timestamp, err := time.Parse("20060102150405Z", check.Kw["expiration_date"].(string))