From 10108445b3fe78ab201491f518e824a38f30e299 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?L=C3=A1szl=C3=B3=20V=C3=A1rady?= Date: Fri, 26 Jul 2024 16:48:26 +0200 Subject: [PATCH] syslog-ng-ctl: workaround invalid escaping in syslog-ng/AxoSyslog metrics MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: László Várady --- pkg/syslog-ng-ctl/stats_prometheus.go | 33 +++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/pkg/syslog-ng-ctl/stats_prometheus.go b/pkg/syslog-ng-ctl/stats_prometheus.go index e46bac1..67d9a67 100644 --- a/pkg/syslog-ng-ctl/stats_prometheus.go +++ b/pkg/syslog-ng-ctl/stats_prometheus.go @@ -154,6 +154,38 @@ func transformEventDelayMetric(delayMetric *io_prometheus_client.MetricFamily, d delayMetric.Type = io_prometheus_client.MetricType_GAUGE.Enum() } +// Workaround for a bug in older syslog-ng/AxoSyslog versions where the output of STATS PROMETHEUS was overescaped. +// Escapes \ as \\ everywhere except for the allowed sequences: \\, \n, \" +func sanitizeBuggyFormat(output string) string { + var fixedOutput strings.Builder + + length := len(output) + for i := 0; i < length; i++ { + c := output[i] + + if c != '\\' { + fixedOutput.WriteByte(c) + continue + } + + if i+1 >= length { + fixedOutput.WriteString(`\\`) + break + } + + if next := output[i+1]; next == '\\' || next == 'n' || next == '"' { + fixedOutput.WriteByte(c) + fixedOutput.WriteByte(next) + i++ + continue + } + + fixedOutput.WriteString(`\\`) + } + + return fixedOutput.String() +} + func StatsPrometheus(ctx context.Context, cc ControlChannel, lastMetricQueryTime *time.Time) ([]*io_prometheus_client.MetricFamily, error) { rsp, err := cc.SendCommand(ctx, "STATS PROMETHEUS") if err != nil { @@ -169,6 +201,7 @@ func StatsPrometheus(ctx context.Context, cc ControlChannel, lastMetricQueryTime return maps.Values(mfs), err } + rsp = sanitizeBuggyFormat(rsp) mfs, err = new(expfmt.TextParser).TextToMetricFamilies(strings.NewReader(rsp)) var delayMetric *io_prometheus_client.MetricFamily