From 01e980f708a7bcc831d1a89834897dc3fdd9ea45 Mon Sep 17 00:00:00 2001 From: jincod Date: Sun, 23 Aug 2020 13:04:24 +0500 Subject: [PATCH 1/2] added default log-label provider --- .../LogLabelProvider.cs | 2 ++ .../Labels/DefaultLogLabelProvider.cs | 14 ++++++++ .../Labels/ILogLabelProvider.cs | 1 + src/Serilog.Sinks.Loki/LokiBatchFormatter.cs | 32 +++++++++++++------ src/Serilog.Sinks.Loki/LokiSinkExtensions.cs | 2 +- .../Infrastructure/TestLabelProvider.cs | 2 ++ 6 files changed, 42 insertions(+), 11 deletions(-) create mode 100644 src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs diff --git a/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs b/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs index 358d38c..03f1fde 100644 --- a/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs +++ b/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs @@ -13,5 +13,7 @@ public IList GetLabels() new LokiLabel("namespace", "prod") }; } + + public bool PropertiesAsLabels { get; set; } = false; } } \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs b/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs new file mode 100644 index 0000000..e9da292 --- /dev/null +++ b/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs @@ -0,0 +1,14 @@ +using System.Collections.Generic; + +namespace Serilog.Sinks.Loki.Labels +{ + class DefaultLogLabelProvider : ILogLabelProvider + { + public IList GetLabels() + { + return new List(); + } + + public bool PropertiesAsLabels { get; set; } = true; + } +} \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs b/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs index ad5535e..23ba201 100644 --- a/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs +++ b/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs @@ -5,5 +5,6 @@ namespace Serilog.Sinks.Loki.Labels public interface ILogLabelProvider { IList GetLabels(); + bool PropertiesAsLabels { get; set; } } } \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs b/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs index d8b3b09..d976274 100644 --- a/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs +++ b/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs @@ -14,15 +14,17 @@ namespace Serilog.Sinks.Loki internal class LokiBatchFormatter : IBatchFormatter { private readonly IList _globalLabels; + private readonly bool _propertiesAsLabels; public LokiBatchFormatter() { _globalLabels = new List(); } - public LokiBatchFormatter(IList globalLabels) + public LokiBatchFormatter(ILogLabelProvider logLabelProvider) { - _globalLabels = globalLabels; + _globalLabels = logLabelProvider.GetLabels(); + _propertiesAsLabels = logLabelProvider.PropertiesAsLabels; } public void Format(IEnumerable logEvents, ITextFormatter formatter, TextWriter output) @@ -46,14 +48,6 @@ public void Format(IEnumerable logEvents, ITextFormatter formatter, Te foreach (LokiLabel globalLabel in _globalLabels) stream.Labels.Add(new LokiLabel(globalLabel.Key, globalLabel.Value)); - foreach (KeyValuePair property in logEvent.Properties) - // Some enrichers pass strings with quotes surrounding the values inside the string, - // which results in redundant quotes after serialization and a "bad request" response. - // To avoid this, remove all quotes from the value. - // We also remove any \r\n newlines and replace with \n new lines to prevent "bad request" responses - // We also remove backslashes and replace with forward slashes, Loki doesn't like those either - stream.Labels.Add(new LokiLabel(property.Key, property.Value.ToString().Replace("\"", "").Replace("\r\n", "\n").Replace("\\", "/"))); - var time = logEvent.Timestamp.ToString("o"); var sb = new StringBuilder(); @@ -69,6 +63,24 @@ public void Format(IEnumerable logEvents, ITextFormatter formatter, Te } } + foreach (KeyValuePair property in logEvent.Properties) + { + // Some enrichers pass strings with quotes surrounding the values inside the string, + // which results in redundant quotes after serialization and a "bad request" response. + // To avoid this, remove all quotes from the value. + // We also remove any \r\n newlines and replace with \n new lines to prevent "bad request" responses + // We also remove backslashes and replace with forward slashes, Loki doesn't like those either + var propertyValue = property.Value.ToString().Replace("\"", "").Replace("\r\n", "\n").Replace("\\", "/"); + if (_propertiesAsLabels) + { + stream.Labels.Add(new LokiLabel(property.Key, propertyValue)); + } + else + { + sb.Append($" {property.Key}={propertyValue}"); + } + } + // Loki doesn't like \r\n for new line, and we can't guarantee the message doesn't have any // in it, so we replace \r\n with \n on the final message // We also flip backslashes to forward slashes, Loki doesn't like those either. diff --git a/src/Serilog.Sinks.Loki/LokiSinkExtensions.cs b/src/Serilog.Sinks.Loki/LokiSinkExtensions.cs index 2baf2cb..f690f74 100644 --- a/src/Serilog.Sinks.Loki/LokiSinkExtensions.cs +++ b/src/Serilog.Sinks.Loki/LokiSinkExtensions.cs @@ -11,7 +11,7 @@ public static LoggerConfiguration LokiHttp(this LoggerSinkConfiguration sinkConf private static LoggerConfiguration LokiHttpImpl(this LoggerSinkConfiguration sinkConfiguration, LokiCredentials credentials, ILogLabelProvider logLabelProvider, IHttpClient httpClient) { - var formatter = logLabelProvider != null ? new LokiBatchFormatter(logLabelProvider.GetLabels()) : new LokiBatchFormatter(); + var formatter = new LokiBatchFormatter(logLabelProvider ?? new DefaultLogLabelProvider()); var client = httpClient ?? new LokiHttpClient(); if (client is LokiHttpClient c) diff --git a/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs b/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs index 052de86..2f88e18 100644 --- a/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs +++ b/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs @@ -12,5 +12,7 @@ public IList GetLabels() new LokiLabel("app", "tests") }; } + + public bool PropertiesAsLabels { get; set; } = false; } } \ No newline at end of file From c7eaa523f41ae1aa6dcd71ad339280c5a1bf31fd Mon Sep 17 00:00:00 2001 From: jincod Date: Mon, 5 Oct 2020 23:44:41 +0500 Subject: [PATCH 2/2] updated API --- src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs | 5 ++++- src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs | 2 +- src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs | 2 +- src/Serilog.Sinks.Loki/LokiBatchFormatter.cs | 4 ++-- .../Infrastructure/TestLabelProvider.cs | 2 +- 5 files changed, 9 insertions(+), 6 deletions(-) diff --git a/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs b/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs index 03f1fde..9d95284 100644 --- a/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs +++ b/src/Serilog.Sinks.Loki.Example/LogLabelProvider.cs @@ -14,6 +14,9 @@ public IList GetLabels() }; } - public bool PropertiesAsLabels { get; set; } = false; + public IList PropertiesAsLabels { get; set; } = new List + { + "MyPropertyName" + }; } } \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs b/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs index e9da292..8b7e1cd 100644 --- a/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs +++ b/src/Serilog.Sinks.Loki/Labels/DefaultLogLabelProvider.cs @@ -9,6 +9,6 @@ public IList GetLabels() return new List(); } - public bool PropertiesAsLabels { get; set; } = true; + public IList PropertiesAsLabels { get; set; } = new List(); } } \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs b/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs index 23ba201..62cbbd6 100644 --- a/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs +++ b/src/Serilog.Sinks.Loki/Labels/ILogLabelProvider.cs @@ -5,6 +5,6 @@ namespace Serilog.Sinks.Loki.Labels public interface ILogLabelProvider { IList GetLabels(); - bool PropertiesAsLabels { get; set; } + IList PropertiesAsLabels { get; set; } } } \ No newline at end of file diff --git a/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs b/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs index d976274..4413497 100644 --- a/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs +++ b/src/Serilog.Sinks.Loki/LokiBatchFormatter.cs @@ -14,7 +14,7 @@ namespace Serilog.Sinks.Loki internal class LokiBatchFormatter : IBatchFormatter { private readonly IList _globalLabels; - private readonly bool _propertiesAsLabels; + private readonly IList _propertiesAsLabels; public LokiBatchFormatter() { @@ -71,7 +71,7 @@ public void Format(IEnumerable logEvents, ITextFormatter formatter, Te // We also remove any \r\n newlines and replace with \n new lines to prevent "bad request" responses // We also remove backslashes and replace with forward slashes, Loki doesn't like those either var propertyValue = property.Value.ToString().Replace("\"", "").Replace("\r\n", "\n").Replace("\\", "/"); - if (_propertiesAsLabels) + if (_propertiesAsLabels.Contains(property.Key, StringComparer.OrdinalIgnoreCase)) { stream.Labels.Add(new LokiLabel(property.Key, propertyValue)); } diff --git a/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs b/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs index 2f88e18..532aef6 100644 --- a/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs +++ b/test/Serilog.Sinks.Loki.Tests/Infrastructure/TestLabelProvider.cs @@ -13,6 +13,6 @@ public IList GetLabels() }; } - public bool PropertiesAsLabels { get; set; } = false; + public IList PropertiesAsLabels { get; set; } = new List(); } } \ No newline at end of file