Decompiled source of Serilog v4.0.100
BepInEx/core/Serilog/netstandard2.0/Serilog.dll
Decompiled 5 months ago
The result has been truncated due to the large size, download it to view full contents!
using System; using System.Collections; using System.Collections.Generic; using System.Collections.ObjectModel; using System.ComponentModel; using System.Diagnostics; using System.Diagnostics.CodeAnalysis; using System.Globalization; using System.IO; using System.Linq; using System.Reflection; using System.Runtime.CompilerServices; using System.Runtime.Versioning; using System.Text; using System.Text.RegularExpressions; using System.Threading; using System.Threading.Channels; using System.Threading.Tasks; using JetBrains.Annotations; using Microsoft.CodeAnalysis; using Serilog.Capturing; using Serilog.Configuration; using Serilog.Context; using Serilog.Core; using Serilog.Core.Enrichers; using Serilog.Core.Filters; using Serilog.Core.Pipeline; using Serilog.Core.Sinks; using Serilog.Core.Sinks.Batching; using Serilog.Data; using Serilog.Debugging; using Serilog.Events; using Serilog.Formatting.Json; using Serilog.Parsing; using Serilog.Policies; using Serilog.Rendering; using Serilog.Settings.KeyValuePairs; [assembly: CompilationRelaxations(8)] [assembly: RuntimeCompatibility(WrapNonExceptionThrows = true)] [assembly: Debuggable(DebuggableAttribute.DebuggingModes.IgnoreSymbolStoreSequencePoints)] [assembly: CLSCompliant(true)] [assembly: InternalsVisibleTo("Serilog.Tests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100fb8d13fd344a1c6fe0fe83ef33c1080bf30690765bc6eb0df26ebfdf8f21670c64265b30db09f73a0dea5b3db4c9d18dbf6d5a25af5ce9016f281014d79dc3b4201ac646c451830fc7e61a2dfd633d34c39f87b81894191652df5ac63cc40c77f3542f702bda692e6e8a9158353df189007a49da0f3cfd55eb250066b19485ec")] [assembly: InternalsVisibleTo("Serilog.PerformanceTests, PublicKey=0024000004800000940000000602000000240000525341310004000001000100fb8d13fd344a1c6fe0fe83ef33c1080bf30690765bc6eb0df26ebfdf8f21670c64265b30db09f73a0dea5b3db4c9d18dbf6d5a25af5ce9016f281014d79dc3b4201ac646c451830fc7e61a2dfd633d34c39f87b81894191652df5ac63cc40c77f3542f702bda692e6e8a9158353df189007a49da0f3cfd55eb250066b19485ec")] [assembly: TargetFramework(".NETStandard,Version=v2.0", FrameworkDisplayName = ".NET Standard 2.0")] [assembly: AssemblyCompany("Serilog Contributors")] [assembly: AssemblyConfiguration("Release")] [assembly: AssemblyCopyright("Copyright © 2013-24 Serilog Contributors")] [assembly: AssemblyDescription("Simple .NET logging with fully-structured events")] [assembly: AssemblyFileVersion("4.0.0.0")] [assembly: AssemblyInformationalVersion("4.0.1-main-06648159+066481599efcc5e26a862e6bd1bd1002fc74355e")] [assembly: AssemblyProduct("Serilog")] [assembly: AssemblyTitle("Serilog")] [assembly: AssemblyMetadata("RepositoryUrl", "https://github.com/serilog/serilog.git")] [assembly: AssemblyVersion("4.0.0.0")] [module: RefSafetyRules(11)] namespace Microsoft.CodeAnalysis { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class EmbeddedAttribute : Attribute { } } namespace System.Runtime.CompilerServices { [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] internal sealed class IsReadOnlyAttribute : Attribute { } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, AllowMultiple = false, Inherited = false)] internal sealed class NullableAttribute : Attribute { public readonly byte[] NullableFlags; public NullableAttribute(byte P_0) { NullableFlags = new byte[1] { P_0 }; } public NullableAttribute(byte[] P_0) { NullableFlags = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Interface | AttributeTargets.Delegate, AllowMultiple = false, Inherited = false)] internal sealed class NullableContextAttribute : Attribute { public readonly byte Flag; public NullableContextAttribute(byte P_0) { Flag = P_0; } } [CompilerGenerated] [Microsoft.CodeAnalysis.Embedded] [AttributeUsage(AttributeTargets.Module, AllowMultiple = false, Inherited = false)] internal sealed class RefSafetyRulesAttribute : Attribute { public readonly int Version; public RefSafetyRulesAttribute(int P_0) { Version = P_0; } } } internal static class Guard { public static T AgainstNull<T>([NoEnumeration][NotNull] T? argument, [CallerArgumentExpression("argument")] string? paramName = null) where T : class { if (argument == null) { throw new ArgumentNullException(paramName); } return argument; } } namespace System { [ExcludeFromCodeCoverage] internal readonly struct Index : IEquatable<Index> { private static class ThrowHelper { [DoesNotReturn] public static void ThrowValueArgumentOutOfRange_NeedNonNegNumException() { throw new ArgumentOutOfRangeException("value", "Non-negative number required."); } } private readonly int _value; public static Index Start => new Index(0); public static Index End => new Index(-1); public int Value { get { if (_value < 0) { return ~_value; } return _value; } } public bool IsFromEnd => _value < 0; [MethodImpl(MethodImplOptions.AggressiveInlining)] public Index(int value, bool fromEnd = false) { if (value < 0) { ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException(); } if (fromEnd) { _value = ~value; } else { _value = value; } } private Index(int value) { _value = value; } [MethodImpl(MethodImplOptions.AggressiveInlining)] public static Index FromStart(int value) { if (value < 0) { ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException(); } return new Index(value); } [MethodImpl(MethodImplOptions.AggressiveInlining)] public static Index FromEnd(int value) { if (value < 0) { ThrowHelper.ThrowValueArgumentOutOfRange_NeedNonNegNumException(); } return new Index(~value); } [MethodImpl(MethodImplOptions.AggressiveInlining)] public int GetOffset(int length) { int num = _value; if (IsFromEnd) { num += length + 1; } return num; } public override bool Equals([NotNullWhen(true)] object? value) { if (value is Index) { return _value == ((Index)value)._value; } return false; } public bool Equals(Index other) { return _value == other._value; } public override int GetHashCode() { return _value; } public static implicit operator Index(int value) { return FromStart(value); } public override string ToString() { if (IsFromEnd) { return ToStringFromEnd(); } return ((uint)Value).ToString(); } private string ToStringFromEnd() { return "^" + Value; } } [ExcludeFromCodeCoverage] internal readonly struct Range : IEquatable<Range> { private static class HashHelpers { public static int Combine(int h1, int h2) { return (((h1 << 5) | (h1 >>> 27)) + h1) ^ h2; } } private static class ThrowHelper { [DoesNotReturn] public static void ThrowArgumentOutOfRangeException() { throw new ArgumentOutOfRangeException("length"); } } public Index Start { get; } public Index End { get; } public static Range All => Index.Start..Index.End; public Range(Index start, Index end) { Start = start; End = end; } public override bool Equals([NotNullWhen(true)] object? value) { if (value is Range range && range.Start.Equals(Start)) { return range.End.Equals(End); } return false; } public bool Equals(Range other) { if (other.Start.Equals(Start)) { return other.End.Equals(End); } return false; } public override int GetHashCode() { return HashHelpers.Combine(Start.GetHashCode(), End.GetHashCode()); } public override string ToString() { return Start.ToString() + ".." + End; } public static Range StartAt(Index start) { return start..Index.End; } public static Range EndAt(Index end) { return Index.Start..end; } [MethodImpl(MethodImplOptions.AggressiveInlining)] public (int Offset, int Length) GetOffsetAndLength(int length) { Index start = Start; int num = ((!start.IsFromEnd) ? start.Value : (length - start.Value)); Index end = End; int num2 = ((!end.IsFromEnd) ? end.Value : (length - end.Value)); if ((uint)num2 > (uint)length || (uint)num > (uint)num2) { ThrowHelper.ThrowArgumentOutOfRangeException(); } return (num, num2 - num); } } } namespace System.Runtime.InteropServices { [AttributeUsage(AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class SuppressGCTransitionAttribute : Attribute { } [AttributeUsage(AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class UnmanagedCallersOnlyAttribute : Attribute { public Type[]? CallConvs; public string? EntryPoint; } } namespace System.Runtime.CompilerServices2 { [AttributeUsage(AttributeTargets.Struct, AllowMultiple = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class InlineArrayAttribute : Attribute { public int Length { get; } public InlineArrayAttribute(int length) { Length = length; } } } namespace System.Runtime.Versioning { [AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class RequiresPreviewFeaturesAttribute : Attribute { public string? Message { get; } public string? Url { get; set; } public RequiresPreviewFeaturesAttribute() { } public RequiresPreviewFeaturesAttribute(string? message) { Message = message; } } [AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class ObsoletedOSPlatformAttribute : Attribute { public string? Message { get; } public string? Url { get; set; } public ObsoletedOSPlatformAttribute(string platformName) { } public ObsoletedOSPlatformAttribute(string platformName, string? message) { Message = message; } } [AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class SupportedOSPlatformAttribute : Attribute { public SupportedOSPlatformAttribute(string platformName) { } } [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class SupportedOSPlatformGuardAttribute : Attribute { public SupportedOSPlatformGuardAttribute(string platformName) { } } [AttributeUsage(AttributeTargets.Assembly, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class TargetPlatformAttribute : Attribute { public TargetPlatformAttribute(string platformName) { } } [AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class UnsupportedOSPlatformAttribute : Attribute { public string? Message { get; } public UnsupportedOSPlatformAttribute(string platformName) { } public UnsupportedOSPlatformAttribute(string platformName, string? message) { Message = message; } } [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class UnsupportedOSPlatformGuardAttribute : Attribute { public UnsupportedOSPlatformGuardAttribute(string platformName) { } } } namespace System.Runtime.CompilerServices { [AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class CallerArgumentExpressionAttribute : Attribute { public string ParameterName { get; } public CallerArgumentExpressionAttribute(string parameterName) { ParameterName = parameterName; } } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Interface, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class CollectionBuilderAttribute : Attribute { public Type BuilderType { get; } public string MethodName { get; } public CollectionBuilderAttribute(Type builderType, string methodName) { BuilderType = builderType; MethodName = methodName; } } [AttributeUsage(AttributeTargets.All, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class CompilerFeatureRequiredAttribute : Attribute { public const string RefStructs = "RefStructs"; public const string RequiredMembers = "RequiredMembers"; public string FeatureName { get; } public bool IsOptional { get; set; } public CompilerFeatureRequiredAttribute(string featureName) { FeatureName = featureName; } } [AttributeUsage(AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class InterpolatedStringHandlerArgumentAttribute : Attribute { public string[] Arguments { get; } public InterpolatedStringHandlerArgumentAttribute(string argument) { Arguments = new string[1] { argument }; } public InterpolatedStringHandlerArgumentAttribute(params string[] arguments) { Arguments = arguments; } } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class InterpolatedStringHandlerAttribute : Attribute { } [EditorBrowsable(EditorBrowsableState.Never)] [ExcludeFromCodeCoverage] internal static class IsExternalInit { } [AttributeUsage(AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class ModuleInitializerAttribute : Attribute { } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Property | AttributeTargets.Field, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class RequiredMemberAttribute : Attribute { } [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] [EditorBrowsable(EditorBrowsableState.Never)] [ExcludeFromCodeCoverage] internal sealed class RequiresLocationAttribute : Attribute { } [AttributeUsage(AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Event | AttributeTargets.Interface, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class SkipLocalsInitAttribute : Attribute { } [AttributeUsage(AttributeTargets.Assembly, Inherited = false, AllowMultiple = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class DisableRuntimeMarshallingAttribute : Attribute { } [AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class UnsafeAccessorAttribute : Attribute { public UnsafeAccessorKind Kind { get; } public string? Name { get; set; } public UnsafeAccessorAttribute(UnsafeAccessorKind kind) { Kind = kind; } } internal enum UnsafeAccessorKind { Constructor, Method, StaticMethod, Field, StaticField } } namespace System.Diagnostics { [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Constructor | AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class StackTraceHiddenAttribute : Attribute { } } namespace System.Diagnostics.CodeAnalysis { [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class AllowNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class DisallowNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class DoesNotReturnAttribute : Attribute { } [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class DoesNotReturnIfAttribute : Attribute { public bool ParameterValue { get; } public DoesNotReturnIfAttribute(bool parameterValue) { ParameterValue = parameterValue; } } [AttributeUsage(AttributeTargets.Assembly | AttributeTargets.Module | AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Enum | AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Event | AttributeTargets.Interface | AttributeTargets.Delegate, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class ExperimentalAttribute : Attribute { public string DiagnosticId { get; } public string? UrlFormat { get; set; } public ExperimentalAttribute(string diagnosticId) { DiagnosticId = diagnosticId; } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class MaybeNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class MaybeNullWhenAttribute : Attribute { public bool ReturnValue { get; } public MaybeNullWhenAttribute(bool returnValue) { ReturnValue = returnValue; } } [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)] [ExcludeFromCodeCoverage] internal sealed class MemberNotNullAttribute : Attribute { public string[] Members { get; } public MemberNotNullAttribute(string member) { Members = new string[1] { member }; } public MemberNotNullAttribute(params string[] members) { Members = members; } } [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property, Inherited = false, AllowMultiple = true)] [ExcludeFromCodeCoverage] internal sealed class MemberNotNullWhenAttribute : Attribute { public bool ReturnValue { get; } public string[] Members { get; } public MemberNotNullWhenAttribute(bool returnValue, string member) { ReturnValue = returnValue; Members = new string[1] { member }; } public MemberNotNullWhenAttribute(bool returnValue, params string[] members) { ReturnValue = returnValue; Members = members; } } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter | AttributeTargets.ReturnValue, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class NotNullAttribute : Attribute { } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Parameter | AttributeTargets.ReturnValue, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class NotNullIfNotNullAttribute : Attribute { public string ParameterName { get; } public NotNullIfNotNullAttribute(string parameterName) { ParameterName = parameterName; } } [AttributeUsage(AttributeTargets.Parameter, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class NotNullWhenAttribute : Attribute { public bool ReturnValue { get; } public NotNullWhenAttribute(bool returnValue) { ReturnValue = returnValue; } } [AttributeUsage(AttributeTargets.Constructor, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class SetsRequiredMembersAttribute : Attribute { } [AttributeUsage(AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class StringSyntaxAttribute : Attribute { public const string CompositeFormat = "CompositeFormat"; public const string DateOnlyFormat = "DateOnlyFormat"; public const string DateTimeFormat = "DateTimeFormat"; public const string EnumFormat = "EnumFormat"; public const string GuidFormat = "GuidFormat"; public const string Json = "Json"; public const string NumericFormat = "NumericFormat"; public const string Regex = "Regex"; public const string TimeOnlyFormat = "TimeOnlyFormat"; public const string TimeSpanFormat = "TimeSpanFormat"; public const string Uri = "Uri"; public const string Xml = "Xml"; public string Syntax { get; } public object?[] Arguments { get; } public StringSyntaxAttribute(string syntax) { Syntax = syntax; Arguments = new object[0]; } public StringSyntaxAttribute(string syntax, params object?[] arguments) { Syntax = syntax; Arguments = arguments; } } [AttributeUsage(AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Parameter, AllowMultiple = false, Inherited = false)] [ExcludeFromCodeCoverage] internal sealed class UnscopedRefAttribute : Attribute { } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Struct | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Field | AttributeTargets.Interface | AttributeTargets.Parameter | AttributeTargets.ReturnValue | AttributeTargets.GenericParameter, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class DynamicallyAccessedMembersAttribute : Attribute { public DynamicallyAccessedMemberTypes MemberTypes { get; } public DynamicallyAccessedMembersAttribute(DynamicallyAccessedMemberTypes memberTypes) { MemberTypes = memberTypes; } } [Flags] internal enum DynamicallyAccessedMemberTypes { None = 0, PublicParameterlessConstructor = 1, PublicConstructors = 3, NonPublicConstructors = 4, PublicMethods = 8, NonPublicMethods = 0x10, PublicFields = 0x20, NonPublicFields = 0x40, PublicNestedTypes = 0x80, NonPublicNestedTypes = 0x100, PublicProperties = 0x200, NonPublicProperties = 0x400, PublicEvents = 0x800, NonPublicEvents = 0x1000, Interfaces = 0x2000, All = -1 } [AttributeUsage(AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Field, AllowMultiple = true, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class DynamicDependencyAttribute : Attribute { public string? MemberSignature { get; } public DynamicallyAccessedMemberTypes MemberTypes { get; } public Type? Type { get; } public string? TypeName { get; } public string? AssemblyName { get; } public string? Condition { get; set; } public DynamicDependencyAttribute(string memberSignature) { MemberSignature = memberSignature; } public DynamicDependencyAttribute(string memberSignature, Type type) { MemberSignature = memberSignature; Type = type; } public DynamicDependencyAttribute(string memberSignature, string typeName, string assemblyName) { MemberSignature = memberSignature; TypeName = typeName; AssemblyName = assemblyName; } public DynamicDependencyAttribute(DynamicallyAccessedMemberTypes memberTypes, Type type) { MemberTypes = memberTypes; Type = type; } public DynamicDependencyAttribute(DynamicallyAccessedMemberTypes memberTypes, string typeName, string assemblyName) { MemberTypes = memberTypes; TypeName = typeName; AssemblyName = assemblyName; } } [AttributeUsage(AttributeTargets.Constructor | AttributeTargets.Method | AttributeTargets.Property | AttributeTargets.Event, Inherited = false, AllowMultiple = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class RequiresAssemblyFilesAttribute : Attribute { public string? Message { get; } public string? Url { get; set; } public RequiresAssemblyFilesAttribute() { } public RequiresAssemblyFilesAttribute(string message) { Message = message; } } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Constructor | AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class RequiresDynamicCodeAttribute : Attribute { public string Message { get; } public string? Url { get; set; } public RequiresDynamicCodeAttribute(string message) { Message = message; } } [AttributeUsage(AttributeTargets.Class | AttributeTargets.Constructor | AttributeTargets.Method, Inherited = false)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class RequiresUnreferencedCodeAttribute : Attribute { public string Message { get; } public string? Url { get; set; } public RequiresUnreferencedCodeAttribute(string message) { Message = message; } } [AttributeUsage(AttributeTargets.All, Inherited = false, AllowMultiple = true)] [ExcludeFromCodeCoverage] [Conditional("MULTI_TARGETING_SUPPORT_ATTRIBUTES")] internal sealed class UnconditionalSuppressMessageAttribute : Attribute { public string Category { get; } public string CheckId { get; } public string? Scope { get; set; } public string? Target { get; set; } public string? MessageId { get; set; } public string? Justification { get; set; } public UnconditionalSuppressMessageAttribute(string category, string checkId) { Category = category; CheckId = checkId; } } } namespace JetBrains.Annotations { [AttributeUsage(AttributeTargets.Parameter)] internal sealed class NoEnumerationAttribute : Attribute { } } namespace Serilog { public interface ILogger { ILogger ForContext(ILogEventEnricher enricher); ILogger ForContext(IEnumerable<ILogEventEnricher> enrichers); ILogger ForContext(string propertyName, object? value, bool destructureObjects = false); ILogger ForContext<TSource>(); ILogger ForContext(Type source); void Write(LogEvent logEvent); [MessageTemplateFormatMethod("messageTemplate")] void Write(LogEventLevel level, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Write<T>(LogEventLevel level, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Write<T0, T1>(LogEventLevel level, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Write<T0, T1, T2>(LogEventLevel level, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Write(LogEventLevel level, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Write(LogEventLevel level, Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Write<T>(LogEventLevel level, Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Write<T0, T1>(LogEventLevel level, Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Write<T0, T1, T2>(LogEventLevel level, Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Write(LogEventLevel level, Exception? exception, string messageTemplate, params object?[]? propertyValues); bool IsEnabled(LogEventLevel level); [MessageTemplateFormatMethod("messageTemplate")] void Verbose(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Verbose(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Verbose(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Verbose<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Verbose(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Debug(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Debug(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Debug(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Debug<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Debug(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Information(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Information<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Information<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Information<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Information(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Information(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Information<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Information<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Information<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Information(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Warning(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Warning(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Warning(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Warning<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Warning(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Error(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Error<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Error<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Error<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Error(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Error(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Error<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Error<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Error<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Error(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Fatal(string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T>(string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Fatal(string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] void Fatal(Exception? exception, string messageTemplate); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T>(Exception? exception, string messageTemplate, T propertyValue); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1); [MessageTemplateFormatMethod("messageTemplate")] void Fatal<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2); [MessageTemplateFormatMethod("messageTemplate")] void Fatal(Exception? exception, string messageTemplate, params object?[]? propertyValues); [MessageTemplateFormatMethod("messageTemplate")] bool BindMessageTemplate(string messageTemplate, object?[]? propertyValues, [NotNullWhen(true)] out MessageTemplate? parsedTemplate, [NotNullWhen(true)] out IEnumerable<LogEventProperty>? boundProperties); bool BindProperty(string? propertyName, object? value, bool destructureObjects, [NotNullWhen(true)] out LogEventProperty? property); } public static class Log { private static ILogger _logger = Serilog.Core.Logger.None; public static ILogger Logger { get { return _logger; } set { _logger = Guard.AgainstNull(value, "value"); } } public static void CloseAndFlush() { (Interlocked.Exchange(ref _logger, Serilog.Core.Logger.None) as IDisposable)?.Dispose(); } public static ILogger ForContext(ILogEventEnricher enricher) { return Logger.ForContext(enricher); } public static ILogger ForContext(ILogEventEnricher[] enrichers) { return Logger.ForContext(enrichers); } public static ILogger ForContext(string propertyName, object? value, bool destructureObjects = false) { return Logger.ForContext(propertyName, value, destructureObjects); } public static ILogger ForContext<TSource>() { return Logger.ForContext<TSource>(); } public static ILogger ForContext(Type source) { return Logger.ForContext(source); } public static void Write(LogEvent logEvent) { Logger.Write(logEvent); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write(LogEventLevel level, string messageTemplate) { Logger.Write(level, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T>(LogEventLevel level, string messageTemplate, T propertyValue) { Logger.Write(level, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T0, T1>(LogEventLevel level, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Logger.Write(level, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T0, T1, T2>(LogEventLevel level, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Logger.Write(level, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write(LogEventLevel level, string messageTemplate, params object?[]? propertyValues) { Logger.Write(level, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write(LogEventLevel level, Exception? exception, string messageTemplate) { Logger.Write(level, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T>(LogEventLevel level, Exception? exception, string messageTemplate, T propertyValue) { Logger.Write(level, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T0, T1>(LogEventLevel level, Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Logger.Write(level, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write<T0, T1, T2>(LogEventLevel level, Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Logger.Write(level, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Write(LogEventLevel level, Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Write(level, exception, messageTemplate, propertyValues); } public static bool IsEnabled(LogEventLevel level) { return Logger.IsEnabled(level); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose(string messageTemplate) { Write(LogEventLevel.Verbose, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Verbose, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Verbose, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Verbose, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose(string messageTemplate, params object?[]? propertyValues) { Logger.Verbose(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose(Exception? exception, string messageTemplate) { Write(LogEventLevel.Verbose, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Verbose, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Verbose, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Verbose, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Verbose(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Verbose(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug(string messageTemplate) { Write(LogEventLevel.Debug, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Debug, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Debug, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Debug, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug(string messageTemplate, params object?[]? propertyValues) { Logger.Debug(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug(Exception? exception, string messageTemplate) { Write(LogEventLevel.Debug, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Debug, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Debug, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Debug, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Debug(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Debug(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information(string messageTemplate) { Write(LogEventLevel.Information, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Information, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Information, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Information, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information(string messageTemplate, params object?[]? propertyValues) { Logger.Information(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information(Exception? exception, string messageTemplate) { Write(LogEventLevel.Information, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Information, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Information, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Information, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Information(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Information(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning(string messageTemplate) { Write(LogEventLevel.Warning, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Warning, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Warning, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Warning, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning(string messageTemplate, params object?[]? propertyValues) { Logger.Warning(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning(Exception? exception, string messageTemplate) { Write(LogEventLevel.Warning, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Warning, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Warning, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Warning, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Warning(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Warning(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error(string messageTemplate) { Write(LogEventLevel.Error, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Error, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Error, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Error, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error(string messageTemplate, params object?[]? propertyValues) { Logger.Error(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error(Exception? exception, string messageTemplate) { Write(LogEventLevel.Error, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Error, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Error, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Error, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Error(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Error(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal(string messageTemplate) { Write(LogEventLevel.Fatal, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T>(string messageTemplate, T propertyValue) { Write(LogEventLevel.Fatal, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T0, T1>(string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Fatal, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T0, T1, T2>(string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Fatal, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal(string messageTemplate, params object?[]? propertyValues) { Logger.Fatal(messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal(Exception? exception, string messageTemplate) { Write(LogEventLevel.Fatal, exception, messageTemplate); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T>(Exception? exception, string messageTemplate, T propertyValue) { Write(LogEventLevel.Fatal, exception, messageTemplate, propertyValue); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T0, T1>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1) { Write(LogEventLevel.Fatal, exception, messageTemplate, propertyValue0, propertyValue1); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal<T0, T1, T2>(Exception? exception, string messageTemplate, T0 propertyValue0, T1 propertyValue1, T2 propertyValue2) { Write(LogEventLevel.Fatal, exception, messageTemplate, propertyValue0, propertyValue1, propertyValue2); } [MessageTemplateFormatMethod("messageTemplate")] public static void Fatal(Exception? exception, string messageTemplate, params object?[]? propertyValues) { Logger.Fatal(exception, messageTemplate, propertyValues); } [MessageTemplateFormatMethod("messageTemplate")] public static bool BindMessageTemplate(string messageTemplate, object?[] propertyValues, [NotNullWhen(true)] out MessageTemplate? parsedTemplate, [NotNullWhen(true)] out IEnumerable<LogEventProperty>? boundProperties) { return Logger.BindMessageTemplate(messageTemplate, propertyValues, out parsedTemplate, out boundProperties); } public static bool BindProperty(string propertyName, object? value, bool destructureObjects, [NotNullWhen(true)] out LogEventProperty? property) { return Logger.BindProperty(propertyName, value, destructureObjects, out property); } } public class LoggerConfiguration { private readonly List<ILogEventSink> _logEventSinks = new List<ILogEventSink>(); private readonly List<ILogEventSink> _auditSinks = new List<ILogEventSink>(); private readonly List<ILogEventEnricher> _enrichers = new List<ILogEventEnricher>(); private readonly List<ILogEventFilter> _filters = new List<ILogEventFilter>(); private readonly List<Type> _additionalScalarTypes = new List<Type>(); private readonly HashSet<Type> _additionalDictionaryTypes = new HashSet<Type>(); private readonly List<IDestructuringPolicy> _additionalDestructuringPolicies = new List<IDestructuringPolicy>(); private readonly Dictionary<string, LoggingLevelSwitch> _overrides = new Dictionary<string, LoggingLevelSwitch>(); private LogEventLevel _minimumLevel = LogEventLevel.Information; private LoggingLevelSwitch? _levelSwitch; private int _maximumDestructuringDepth = 10; private int _maximumStringLength = int.MaxValue; private int _maximumCollectionCount = int.MaxValue; private bool _loggerCreated; public LoggerSinkConfiguration WriteTo { get; internal set; } public LoggerAuditSinkConfiguration AuditTo => new LoggerAuditSinkConfiguration(this, delegate(ILogEventSink s) { _auditSinks.Add(s); }); public LoggerMinimumLevelConfiguration MinimumLevel => new LoggerMinimumLevelConfiguration(this, delegate(LogEventLevel l) { _minimumLevel = l; _levelSwitch = null; }, delegate(LoggingLevelSwitch sw) { _levelSwitch = sw; }, delegate(string s, LoggingLevelSwitch lls) { _overrides[s] = lls; }); public LoggerEnrichmentConfiguration Enrich { get; internal set; } public LoggerFilterConfiguration Filter => new LoggerFilterConfiguration(this, delegate(ILogEventFilter f) { _filters.Add(f); }); public LoggerDestructuringConfiguration Destructure => new LoggerDestructuringConfiguration(this, _additionalScalarTypes.Add, delegate(Type type) { _additionalDictionaryTypes.Add(type); }, _additionalDestructuringPolicies.Add, delegate(int depth) { _maximumDestructuringDepth = depth; }, delegate(int length) { _maximumStringLength = length; }, delegate(int count) { _maximumCollectionCount = count; }); public LoggerSettingsConfiguration ReadFrom => new LoggerSettingsConfiguration(this); public LoggerConfiguration() { WriteTo = new LoggerSinkConfiguration(this, delegate(ILogEventSink s) { _logEventSinks.Add(s); }); Enrich = new LoggerEnrichmentConfiguration(this, delegate(ILogEventEnricher e) { _enrichers.Add(e); }); } public Logger CreateLogger() { if (_loggerCreated) { throw new InvalidOperationException("CreateLogger() was previously called and can only be called once."); } _loggerCreated = true; ILogEventSink logEventSink = null; if (_logEventSinks.Count > 0) { logEventSink = new SafeAggregateSink(_logEventSinks); } bool flag = _auditSinks.Any(); if (flag) { IEnumerable<ILogEventSink> sinks; if (logEventSink != null) { sinks = new ILogEventSink[1] { logEventSink }.Concat(_auditSinks); } else { IEnumerable<ILogEventSink> auditSinks = _auditSinks; sinks = auditSinks; } logEventSink = new AggregateSink(sinks); } if (logEventSink == null) { logEventSink = new SafeAggregateSink(Array.Empty<ILogEventSink>()); } if (_filters.Any()) { logEventSink = new FilteringSink(logEventSink, _filters, flag); } MessageTemplateProcessor messageTemplateProcessor = new MessageTemplateProcessor(new PropertyValueConverter(_maximumDestructuringDepth, _maximumStringLength, _maximumCollectionCount, _additionalScalarTypes, _additionalDictionaryTypes, _additionalDestructuringPolicies, flag)); ILogEventEnricher enricher = _enrichers.Count switch { 0 => new EmptyEnricher(), 1 => _enrichers[0], _ => new SafeAggregateEnricher(_enrichers), }; LevelOverrideMap overrideMap = null; if (_overrides.Count != 0) { overrideMap = new LevelOverrideMap(_overrides, _minimumLevel, _levelSwitch); } ILogEventSink[] disposableSinks = (from s in _logEventSinks.Concat(_auditSinks) where s is IDisposable select s).ToArray(); return new Logger(messageTemplateProcessor, (_levelSwitch == null) ? _minimumLevel : LogEventLevel.Verbose, _levelSwitch, logEventSink, enricher, Dispose, overrideMap); void Dispose() { ILogEventSink[] array = disposableSinks; for (int i = 0; i < array.Length; i++) { (array[i] as IDisposable)?.Dispose(); } } } } public static class LoggerExtensions { public static ILogger ForContext<TValue>(this ILogger logger, LogEventLevel level, string propertyName, TValue value, bool destructureObjects = false) { Guard.AgainstNull(logger, "logger"); if (!logger.IsEnabled(level)) { return logger; } return logger.ForContext(propertyName, value, destructureObjects); } } } namespace Serilog.Settings.KeyValuePairs { internal static class CallableConfigurationMethodFinder { internal static IList<MethodInfo> FindConfigurationMethods(IEnumerable<Assembly> configurationAssemblies, Type configType) { Type configType2 = configType; List<MethodInfo> list = (from m in configurationAssemblies.SelectMany((Assembly a) => a.ExportedTypes.Where((Type t) => t.IsSealed && t.IsAbstract && !t.IsNested)).SelectMany((Type t) => t.GetMethods(BindingFlags.Static | BindingFlags.Public)) where m.IsDefined(typeof(ExtensionAttribute), inherit: false) && m.GetParameters()[0].ParameterType == configType2 select m).ToList(); if (configType2 == typeof(LoggerSinkConfiguration)) { list.AddRange(SurrogateConfigurationMethods.WriteTo); } if (configType2 == typeof(LoggerAuditSinkConfiguration)) { list.AddRange(SurrogateConfigurationMethods.AuditTo); } if (configType2 == typeof(LoggerEnrichmentConfiguration)) { list.AddRange(SurrogateConfigurationMethods.Enrich); } if (configType2 == typeof(LoggerDestructuringConfiguration)) { list.AddRange(SurrogateConfigurationMethods.Destructure); } if (configType2 == typeof(LoggerFilterConfiguration)) { list.AddRange(SurrogateConfigurationMethods.Filter); } return list; } } internal class KeyValuePairSettings : ILoggerSettings { internal class ConfigurationMethodCall { public string MethodName { get; } public string ArgumentName { get; } public string Value { get; } public ConfigurationMethodCall(string methodName, string argumentName, string value) { MethodName = methodName; ArgumentName = argumentName; Value = value; } } private const string UsingDirective = "using"; private const string LevelSwitchDirective = "level-switch"; private const string AuditToDirective = "audit-to"; private const string WriteToDirective = "write-to"; private const string MinimumLevelDirective = "minimum-level"; private const string MinimumLevelControlledByDirective = "minimum-level:controlled-by"; private const string EnrichWithDirective = "enrich"; private const string EnrichWithPropertyDirective = "enrich:with-property"; private const string FilterDirective = "filter"; private const string DestructureDirective = "destructure"; private const string UsingDirectiveFullFormPrefix = "using:"; private const string EnrichWithPropertyDirectivePrefix = "enrich:with-property:"; private const string MinimumLevelOverrideDirectivePrefix = "minimum-level:override:"; private const string CallableDirectiveRegex = "^(?<directive>audit-to|write-to|enrich|filter|destructure):(?<method>[A-Za-z0-9]*)(\\.(?<argument>[A-Za-z0-9]*)){0,1}$"; private const string LevelSwitchDeclarationDirectiveRegex = "^level-switch:(?<switchName>.*)$"; private const string LevelSwitchNameRegex = "^\\$[A-Za-z]+[A-Za-z0-9]*$"; private static readonly string[] _supportedDirectives = new string[10] { "using", "level-switch", "audit-to", "write-to", "minimum-level", "minimum-level:controlled-by", "enrich:with-property", "enrich", "filter", "destructure" }; private static readonly Dictionary<string, Type> CallableDirectiveReceiverTypes = new Dictionary<string, Type> { ["audit-to"] = typeof(LoggerAuditSinkConfiguration), ["write-to"] = typeof(LoggerSinkConfiguration), ["enrich"] = typeof(LoggerEnrichmentConfiguration), ["filter"] = typeof(LoggerFilterConfiguration), ["destructure"] = typeof(LoggerDestructuringConfiguration) }; private static readonly Dictionary<Type, Func<LoggerConfiguration, object>> CallableDirectiveReceivers = new Dictionary<Type, Func<LoggerConfiguration, object>> { [typeof(LoggerAuditSinkConfiguration)] = (LoggerConfiguration lc) => lc.AuditTo, [typeof(LoggerSinkConfiguration)] = (LoggerConfiguration lc) => lc.WriteTo, [typeof(LoggerEnrichmentConfiguration)] = (LoggerConfiguration lc) => lc.Enrich, [typeof(LoggerFilterConfiguration)] = (LoggerConfiguration lc) => lc.Filter, [typeof(LoggerDestructuringConfiguration)] = (LoggerConfiguration lc) => lc.Destructure }; private readonly IReadOnlyDictionary<string, string> _settings; public KeyValuePairSettings(IReadOnlyDictionary<string, string> settings) { _settings = Guard.AgainstNull(settings, "settings"); } public void Configure(LoggerConfiguration loggerConfiguration) { Guard.AgainstNull(loggerConfiguration, "loggerConfiguration"); Dictionary<string, string> dictionary = _settings.Where<KeyValuePair<string, string>>((KeyValuePair<string, string> kvp) => _supportedDirectives.Any(kvp.Key.StartsWith)).ToDictionary((KeyValuePair<string, string> kvp) => kvp.Key, (KeyValuePair<string, string> kvp) => kvp.Value); IReadOnlyDictionary<string, LoggingLevelSwitch> readOnlyDictionary = ParseNamedLevelSwitchDeclarationDirectives(dictionary); if (dictionary.TryGetValue("minimum-level", out var value) && Enum.TryParse<LogEventLevel>(value, out var result)) { loggerConfiguration.MinimumLevel.Is(result); } foreach (KeyValuePair<string, string> item in dictionary.Where((KeyValuePair<string, string> dir) => dir.Key.StartsWith("enrich:with-property:") && dir.Key.Length > "enrich:with-property:".Length)) { string name = item.Key.Substring("enrich:with-property:".Length); loggerConfiguration.Enrich.WithProperty(name, item.Value); } if (dictionary.TryGetValue("minimum-level:controlled-by", out var value2)) { LoggingLevelSwitch levelSwitch = LookUpSwitchByName(value2, readOnlyDictionary); loggerConfiguration.MinimumLevel.ControlledBy(levelSwitch); } foreach (KeyValuePair<string, string> item2 in dictionary.Where((KeyValuePair<string, string> dir) => dir.Key.StartsWith("minimum-level:override:") && dir.Key.Length > "minimum-level:override:".Length)) { string source = item2.Key.Substring("minimum-level:override:".Length); if (Enum.TryParse<LogEventLevel>(item2.Value, out var result2)) { loggerConfiguration.MinimumLevel.Override(source, result2); continue; } LoggingLevelSwitch levelSwitch2 = LookUpSwitchByName(item2.Value, readOnlyDictionary); loggerConfiguration.MinimumLevel.Override(source, levelSwitch2); } Regex matchCallables = new Regex("^(?<directive>audit-to|write-to|enrich|filter|destructure):(?<method>[A-Za-z0-9]*)(\\.(?<argument>[A-Za-z0-9]*)){0,1}$"); var source2 = (from <>h__TransparentIdentifier0 in dictionary.Where(delegate(KeyValuePair<string, string> wt) { Regex regex2 = matchCallables; KeyValuePair<string, string> keyValuePair2 = wt; return regex2.IsMatch(keyValuePair2.Key); }).Select(delegate(KeyValuePair<string, string> wt) { Regex regex = matchCallables; KeyValuePair<string, string> keyValuePair = wt; return new { wt = wt, match = regex.Match(keyValuePair.Key) }; }) select new { ReceiverType = CallableDirectiveReceiverTypes[<>h__TransparentIdentifier0.match.Groups["directive"].Value], Call = new ConfigurationMethodCall(<>h__TransparentIdentifier0.match.Groups["method"].Value, <>h__TransparentIdentifier0.match.Groups["argument"].Value, <>h__TransparentIdentifier0.wt.Value) }).ToList(); if (!source2.Any()) { return; } List<Assembly> configurationAssemblies = LoadConfigurationAssemblies(dictionary).ToList(); foreach (var item3 in from d in source2 group d by d.ReceiverType) { IList<MethodInfo> configurationMethods = CallableConfigurationMethodFinder.FindConfigurationMethods(configurationAssemblies, item3.Key); ApplyDirectives((from d in item3 select d.Call into call group call by call.MethodName).ToList(), configurationMethods, CallableDirectiveReceivers[item3.Key](loggerConfiguration), readOnlyDictionary); } } internal static bool IsValidSwitchName(string input) { return Regex.IsMatch(input, "^\\$[A-Za-z]+[A-Za-z0-9]*$"); } private static IReadOnlyDictionary<string, LoggingLevelSwitch> ParseNamedLevelSwitchDeclarationDirectives(IReadOnlyDictionary<string, string> directives) { Regex matchLevelSwitchDeclarations = new Regex("^level-switch:(?<switchName>.*)$"); var list = (from <>h__TransparentIdentifier0 in directives.Where<KeyValuePair<string, string>>(delegate(KeyValuePair<string, string> wt) { Regex regex2 = matchLevelSwitchDeclarations; KeyValuePair<string, string> keyValuePair2 = wt; return regex2.IsMatch(keyValuePair2.Key); }).Select(delegate(KeyValuePair<string, string> wt) { Regex regex = matchLevelSwitchDeclarations; KeyValuePair<string, string> keyValuePair = wt; return new { wt = wt, match = regex.Match(keyValuePair.Key) }; }) select new { SwitchName = <>h__TransparentIdentifier0.match.Groups["switchName"].Value, InitialSwitchLevel = <>h__TransparentIdentifier0.wt.Value }).ToList(); Dictionary<string, LoggingLevelSwitch> dictionary = new Dictionary<string, LoggingLevelSwitch>(); foreach (var item in list) { string switchName = item.SwitchName; string initialSwitchLevel = item.InitialSwitchLevel; if (!IsValidSwitchName(switchName)) { throw new FormatException("\"" + switchName + "\" is not a valid name for a Level Switch declaration. Level switch must be declared with a '$' sign, like \"level-switch:$switchName\""); } LoggingLevelSwitch value = ((!(initialSwitchLevel == string.Empty)) ? new LoggingLevelSwitch((LogEventLevel)Enum.Parse(typeof(LogEventLevel), initialSwitchLevel)) : new LoggingLevelSwitch()); dictionary.Add(switchName, value); } return dictionary; } private static LoggingLevelSwitch LookUpSwitchByName(string switchName, IReadOnlyDictionary<string, LoggingLevelSwitch> declaredLevelSwitches) { if (declaredLevelSwitches.TryGetValue(switchName, out LoggingLevelSwitch value)) { return value; } throw new InvalidOperationException("No LoggingLevelSwitch has been declared with name \"" + switchName + "\". You might be missing a key \"level-switch:" + switchName + "\""); } private static object ConvertOrLookupByName(string valueOrSwitchName, Type type, IReadOnlyDictionary<string, LoggingLevelSwitch> declaredSwitches) { if (type == typeof(LoggingLevelSwitch)) { return LookUpSwitchByName(valueOrSwitchName, declaredSwitches); } return SettingValueConversions.ConvertToType(valueOrSwitchName, type); } private static void ApplyDirectives(List<IGrouping<string, ConfigurationMethodCall>> directives, IList<MethodInfo> configurationMethods, object loggerConfigMethod, IReadOnlyDictionary<string, LoggingLevelSwitch> declaredSwitches) { IReadOnlyDictionary<string, LoggingLevelSwitch> declaredSwitches2 = declaredSwitches; foreach (IGrouping<string, ConfigurationMethodCall> directiveInfo in directives) { MethodInfo methodInfo = SelectConfigurationMethod(configurationMethods, directiveInfo.Key, directiveInfo); if (methodInfo == null) { SelfLog.WriteLine("Setting \"{0}\" could not be matched to an implementation in any of the loaded assemblies. To use settings from additional assemblies, specify them with the \"serilog:using\" key.", directiveInfo.Key); continue; } List<object> list = (from p in methodInfo.GetParameters().Skip(1) let directive = directiveInfo.FirstOrDefault((ConfigurationMethodCall s) => s.ArgumentName == p.Name) select SuppressConvertCall(directive, p)).ToList(); list.Insert(0, loggerConfigMethod); methodInfo.Invoke(null, list.ToArray()); } object? SuppressConvertCall(ConfigurationMethodCall? directive, ParameterInfo p) { if (directive != null) { return ConvertOrLookupByName(directive.Value, p.ParameterType, declaredSwitches2); } return p.DefaultValue; } } internal static MethodInfo? SelectConfigurationMethod(IEnumerable<MethodInfo> candidateMethods, string name, IEnumerable<ConfigurationMethodCall> suppliedArgumentValues) { string name2 = name; IEnumerable<ConfigurationMethodCall> suppliedArgumentValues2 = suppliedArgumentValues; return (from m in candidateMethods where m.Name == name2 && m.GetParameters().Skip(1).All((ParameterInfo p) => p.HasDefaultValue || suppliedArgumentValues2.Any((ConfigurationMethodCall s) => s.ArgumentName == p.Name)) orderby m.GetParameters().Count((ParameterInfo p) => suppliedArgumentValues2.Any((ConfigurationMethodCall s) => s.ArgumentName == p.Name)) descending select m).FirstOrDefault(); } internal static IEnumerable<Assembly> LoadConfigurationAssemblies(IReadOnlyDictionary<string, string> directives) { List<Assembly> list = new List<Assembly> { typeof(ILogger).Assembly }; foreach (KeyValuePair<string, string> item in directives.Where<KeyValuePair<string, string>>((KeyValuePair<string, string> d) => d.Key.Equals("using") || d.Key.StartsWith("using:"))) { if (string.IsNullOrWhiteSpace(item.Value)) { throw new InvalidOperationException("A zero-length or whitespace assembly name was supplied to a serilog:using configuration statement."); } AssemblyName assemblyRef = new AssemblyName(item.Value); list.Add(Assembly.Load(assemblyRef)); } return list.Distinct(); } } internal class SettingValueConversions { private static Regex StaticMemberAccessorRegex = new Regex("^(?<shortTypeName>[^:]+)::(?<memberName>[A-Za-z][A-Za-z0-9]*)(?<typeNameExtraQualifiers>[^:]*)$"); private static Dictionary<Type, Func<string, object>> ExtendedTypeConversions = new Dictionary<Type, Func<string, object>> { { typeof(Uri), (string s) => new Uri(s) }, { typeof(TimeSpan), (string s) => TimeSpan.Parse(s) }, { typeof(Type), (string s) => Type.GetType(s, throwOnError: true) } }; public static object? ConvertToType(string value, Type toType) { Type toType2 = toType; if (toType2.IsGenericType && toType2.GetGenericTypeDefinition() == typeof(Nullable<>)) { if (value == string.Empty) { return null; } toType2 = toType2.GenericTypeArguments[0]; } if (toType2.IsEnum) { return Enum.Parse(toType2, value); } Func<string, object> func = (from t in ExtendedTypeConversions where t.Key.IsAssignableFrom(toType2) select t.Value).FirstOrDefault(); if (func != null) { return func(value); } if ((toType2.IsInterface || toType2.IsAbstract) && !string.IsNullOrWhiteSpace(value)) { if (TryParseStaticMemberAccessor(value, out string accessorTypeName, out string memberName)) { Type type = Type.GetType(accessorTypeName, throwOnError: true); PropertyInfo propertyInfo = type.GetProperties(BindingFlags.Static | BindingFlags.Public).FirstOrDefault((PropertyInfo x) => x.Name == memberName && x.GetMethod != null); if (propertyInfo != null) { return propertyInfo.GetValue(null); } FieldInfo fieldInfo = type.GetFields(BindingFlags.Static | BindingFlags.Public).FirstOrDefault((FieldInfo x) => x.Name == memberName); if (fieldInfo != null) { return fieldInfo.GetValue(null); } throw new InvalidOperationException("Could not find a public static property or field with name `" + memberName + "` on type `" + accessorTypeName + "`"); } Type type2 = Type.GetType(value.Trim(), throwOnError: false); if (type2 != null) { ConstructorInfo? constructorInfo = type2.GetConstructors(BindingFlags.Instance | BindingFlags.Public).FirstOrDefault(delegate(ConstructorInfo ci) { ParameterInfo[] parameters2 = ci.GetParameters(); return parameters2.Length == 0 || parameters2.All((ParameterInfo pi) => pi.HasDefaultValue); }); if (constructorInfo == null) { throw new InvalidOperationException("A default constructor was not found on " + type2.FullName + "."); } object[] parameters = (from pi in constructorInfo.GetParameters() select pi.DefaultValue).ToArray(); return constructorInfo.Invoke(parameters); } } if (toType2.IsArray && toType2.GetArrayRank() == 1) { Type elementType = toType2.GetElementType(); if (string.IsNullOrEmpty(value)) { return Array.CreateInstance(elementType, 0); } string[] array = value.Split(new char[1] { ',' }); int num = array.Length; Array array2 = Array.CreateInstance(elementType, array.Length); for (int i = 0; i < num; i++) { object value2 = ConvertToType(array[i], elementType); array2.SetValue(value2, i); } return array2; } return Convert.ChangeType(value, toType2); } internal static bool TryParseStaticMemberAccessor(string input, [NotNullWhen(true)] out string? accessorTypeName, [NotNullWhen(true)] out string? memberName) { if (StaticMemberAccessorRegex.IsMatch(input)) { Match match = StaticMemberAccessorRegex.Match(input); string value = match.Groups["shortTypeName"].Value; string value2 = match.Groups["memberName"].Value; string value3 = match.Groups["typeNameExtraQualifiers"].Value; memberName = value2.Trim(); accessorTypeName = value.Trim() + value3.TrimEnd(Array.Empty<char>()); return true; } accessorTypeName = null; memberName = null; return false; } } internal static class SurrogateConfigurationMethods { private static readonly Dictionary<Type, MethodInfo[]> SurrogateMethodCandidates = (from m in typeof(SurrogateConfigurationMethods).GetTypeInfo().DeclaredMethods group m by m.GetParameters().First().ParameterType).ToDictionary((IGrouping<Type, MethodInfo> g) => g.Key, (IGrouping<Type, MethodInfo> g) => g.ToArray()); internal static readonly MethodInfo[] WriteTo = SurrogateMethodCandidates[typeof(LoggerSinkConfiguration)]; internal static readonly MethodInfo[] AuditTo = SurrogateMethodCandidates[typeof(LoggerAuditSinkConfiguration)]; internal static readonly MethodInfo[] Enrich = SurrogateMethodCandidates[typeof(LoggerEnrichmentConfiguration)]; internal static readonly MethodInfo[] Destructure = SurrogateMethodCandidates[typeof(LoggerDestructuringConfiguration)]; internal static readonly MethodInfo[] Filter = SurrogateMethodCandidates[typeof(LoggerFilterConfiguration)]; internal static LoggerConfiguration Sink(LoggerSinkConfiguration loggerSinkConfiguration, ILogEventSink sink, LogEventLevel restrictedToMinimumLevel = LogEventLevel.Verbose, LoggingLevelSwitch? levelSwitch = null) { return loggerSinkConfiguration.Sink(sink, restrictedToMinimumLevel, levelSwitch); } internal static LoggerConfiguration Sink(LoggerAuditSinkConfiguration auditSinkConfiguration, ILogEventSink sink, LogEventLevel restrictedToMinimumLevel = LogEventLevel.Verbose, LoggingLevelSwitch? levelSwitch = null) { return auditSinkConfiguration.Sink(sink, restrictedToMinimumLevel, levelSwitch); } internal static LoggerConfiguration With(LoggerEnrichmentConfiguration loggerEnrichmentConfiguration, ILogEventEnricher enricher) { return loggerEnrichmentConfiguration.With(enricher); } internal static LoggerConfiguration FromLogContext(LoggerEnrichmentConfiguration loggerEnrichmentConfiguration) { return loggerEnrichmentConfiguration.FromLogContext(); } internal static LoggerConfiguration With(LoggerDestructuringConfiguration loggerDestructuringConfiguration, IDestructuringPolicy policy) { return loggerDestructuringConfiguration.With(policy); } internal static LoggerConfiguration AsScalar(LoggerDestructuringConfiguration loggerDestructuringConfiguration, Type scalarType) { return loggerDestructuringConfiguration.AsScalar(scalarType); } internal static LoggerConfiguration ToMaximumCollectionCount(LoggerDestructuringConfiguration loggerDestructuringConfiguration, int maximumCollectionCount) { return loggerDestructuringConfiguration.ToMaximumCollectionCount(maximumCollectionCount); } internal static LoggerConfiguration ToMaximumDepth(LoggerDestructuringConfiguration loggerDestructuringConfiguration, int maximumDestructuringDepth) { return loggerDestructuringConfiguration.ToMaximumDepth(maximumDestructuringDepth); } internal static LoggerConfiguration ToMaximumStringLength(LoggerDestructuringConfiguration loggerDestructuringConfiguration, int maximumStringLength) { return loggerDestructuringConfiguration.ToMaximumStringLength(maximumStringLength); } internal static LoggerConfiguration With(LoggerFilterConfiguration loggerFilterConfiguration, ILogEventFilter filter) { return loggerFilterConfiguration.With(filter); } } } namespace Serilog.Rendering { internal static class Casing { public static string Format(string value, string? format = null) { if (!(format == "u")) { if (format == "w") { return value.ToLowerInvariant(); } return value; } return value.ToUpperInvariant(); } } internal static class MessageTemplateRenderer { private static readonly JsonValueFormatter JsonValueFormatter = new JsonValueFormatter("$type"); [MethodImpl(MethodImplOptions.AggressiveInlining)] public static void Render(MessageTemplate messageTemplate, IReadOnlyDictionary<string, LogEventPropertyValue> properties, TextWriter output, string? format = null, IFormatProvider? formatProvider = null) { bool isLiteral = false; bool isJson = false; if (format != null) { for (int i = 0; i < format.Length; i++) { if (format[i] == 'l') { isLiteral = true; } else if (format[i] == 'j') { isJson = true; } } } for (int j = 0; j < messageTemplate.TokenArray.Length; j++) { MessageTemplateToken messageTemplateToken = messageTemplate.TokenArray[j]; if (messageTemplateToken is TextToken tt) { RenderTextToken(tt, output); } else { RenderPropertyToken((PropertyToken)messageTemplateToken, properties, output, formatProvider, isLiteral, isJson); } } } public static void RenderTextToken(TextToken tt, TextWriter output) { output.Write(tt.Text); } public static void RenderPropertyToken(PropertyToken pt, IReadOnlyDictionary<string, LogEventPropertyValue> properties, TextWriter output, IFormatProvider? formatProvider, bool isLiteral, bool isJson) { if (!properties.TryGetValue(pt.PropertyName, out LogEventPropertyValue value)) { output.Write(pt.RawText); return; } if (!pt.Alignment.HasValue) { RenderValue(value, isLiteral, isJson, output, pt.Format, formatProvider); return; } using StringWriter stringWriter = ReusableStringWriter.GetOrCreate(); RenderValue(value, isLiteral, isJson, stringWriter, pt.Format, formatProvider); StringBuilder stringBuilder = stringWriter.GetStringBuilder(); if (stringBuilder.Length >= pt.Alignment.Value.Width) { output.Write(stringBuilder.ToString()); return; } string value2 = stringBuilder.ToString(); Alignment? alignment = pt.Alignment.Value; Padding.Apply(output, value2, in alignment); } private static void RenderValue(LogEventPropertyValue propertyValue, bool literal, bool json, TextWriter output, string? format, IFormatProvider? formatProvider) { if (literal && propertyValue is ScalarValue scalarValue && scalarValue.Value is string value) { output.Write(value); } else if (json && format == null) { JsonValueFormatter.Format(propertyValue, output); } else { propertyValue.Render(output, format, formatProvider); } } } internal static class Padding { private static readonly char[] PaddingChars = Enumerable.Repeat(' ', 80).ToArray(); public static void Apply(TextWriter output, string value, in Alignment? alignment) { if (!alignment.HasValue || value.Length >= alignment.Value.Width) { output.Write(value); return; } int num = alignment.Value.Width - value.Length; if (alignment.Value.Direction == AlignmentDirection.Left) { output.Write(value); } if (num <= PaddingChars.Length) { output.Write(PaddingChars, 0, num); } else { output.Write(new string(' ', num)); } if (alignment.Value.Direction == AlignmentDirection.Right) { output.Write(value); } } } internal class ReusableStringWriter : StringWriter { [ThreadStatic] private static ReusableStringWriter? _pooledWriter; internal const int StringBuilderCapacityThreshold = 32768; public static StringWriter GetOrCreate(IFormatProvider? formatProvider = null) { IFormatProvider objB = formatProvider ?? CultureInfo.CurrentCulture; ReusableStringWriter reusableStringWriter = _pooledWriter; _pooledWriter = null; if (reusableStringWriter == null || !object.Equals(reusableStringWriter.FormatProvider, objB)) { reusableStringWriter = new ReusableStringWriter(formatProvider); } return reusableStringWriter; } private ReusableStringWriter(IFormatProvider? formatProvider) : base(formatProvider ?? CultureInfo.CurrentCulture) { } protected override void Dispose(bool disposing) { if (!disposing) { base.Dispose(disposing); return; } StringBuilder stringBuilder = GetStringBuilder(); if (stringBuilder.Capacity > 32768) { base.Dispose(disposing); return; } stringBuilder.Clear(); _pooledWriter = this; } } } namespace Serilog.Policies { internal class ByteArrayScalarConversionPolicy : IScalarConversionPolicy { private const int MaximumByteArrayLength = 1024; public bool TryConvertToScalar(object value, [NotNullWhen(true)] out ScalarValue? result) { if (!(value is byte[] array)) { result = null; return false; } if (array.Length > 1024) { string value2 = string.Concat(string.Concat(from b in array.Take(16) select b.ToString("X2")), "... (", array.Length.ToString(), " bytes)"); result = new ScalarValue(value2); } else { result = new ScalarValue(string.Concat(array.Select((byte b) => b.ToString("X2")))); } return true; } } internal class DelegateDestructuringPolicy : IDestructuringPolicy { public bool TryDestructure(object value, ILogEventPropertyValueFactory propertyValueFactory, [NotNullWhen(true)] out LogEventPropertyValue? result) { if (value is Delegate @delegate) { result = new ScalarValue(@delegate.ToString()); return true; } result = null; return false; } } internal class EnumScalarConversionPolicy : IScalarConversionPolicy { public bool TryConvertToScalar(object value, [NotNullWhen(true)] out ScalarValue? result) { if (value is Enum) { result = new ScalarValue(value); return true; } result = null; return false; } } internal class PrimitiveScalarConversionPolicy : IScalarConversionPolicy { public bool TryConvertToScalar(object value, [NotNullWhen(true)] out ScalarValue? result) { if (value.GetType().IsPrimitive) { result = new ScalarValue(value); return true; } result = null; return false; } } internal class ProjectedDestructuringPolicy : IDestructuringPolicy { private readonly Func<Type, bool> _canApply; private readonly Func<object, object> _projection; public ProjectedDestructuringPolicy(Func<Type, bool> canApply, Func<object, object> projection) { _canApply = Guard.AgainstNull(canApply, "canApply"); _projection = Guard.AgainstNull(projection, "projection"); } public bool TryDestructure(object value, ILogEventPropertyValueFactory propertyValueFactory, [NotNullWhen(true)] out LogEventPropertyValue? result) { Guard.AgainstNull(value, "value"); if (!_canApply(value.GetType())) { result = null; return false; } object value2 = _projection(value); result = propertyValueFactory.CreatePropertyValue(value2, destructureObjects: true); return true; } } internal class ReflectionTypesScalarDestructuringPolicy : IDestructuringPolicy { public bool TryDestructure(object value, ILogEventPropertyValueFactory propertyValueFactory, [NotNullWhen(true)] out LogEventPropertyValue? result) { if ((value is Type || value is MemberInfo) ? true : false) { result = new ScalarValue(value); return true; } result = null; return false; } } internal class SimpleScalarConversionPolicy : IScalarConversionPolicy { private readonly HashSet<Type> _scalarTypes; public SimpleScalarConversionPolicy(IEnumerable<Type> scalarTypes) { HashSet<Type> hashSet = new HashSet<Type>(); foreach (Type scalarType in scalarTypes) { hashSet.Add(scalarType); } _scalarTypes = hashSet; } public bool TryConvertToScalar(object value, [NotNullWhen(true)] out ScalarValue? result) { if (_scalarTypes.Contains(value.GetType())) { result = new ScalarValue(value); return true; } result = null; return false; } } } namespace Serilog.Parsing { public readonly struct Alignment { public AlignmentDirection Direction { get; } public int Width { get; } public Alignment(AlignmentDirection direction, int width) { Direction = direction; Width = width; } } public enum AlignmentDirection { Left, Right } public enum Destructuring { Default, Stringify, Destructure } public class MessageTemplateParser : IMessageTemplateParser { private static readonly bool DefaultAcceptDottedPropertyNames = AppContext.TryGetSwitch("Serilog.Parsing.MessageTemplateParser.AcceptDottedPropertyNames", out var isEnabled) && isEnabled; private static readonly TextToken EmptyTextToken = new TextToken(""); private readonly bool _acceptDottedPropertyNames; public MessageTemplateParser() : this(DefaultAcceptDottedPropertyNames) { } internal MessageTemplateParser(bool acceptDottedPropertyNames) { _acceptDottedPropertyNames = acceptDottedPropertyNames; } public MessageTemplate Parse(string messageTemplate) { Guard.AgainstNull(messageTemplate, "messageTemplate"); return new MessageTemplate(messageTemplate, Tokenize(messageTemplate)); } private IEnumerable<MessageTemplateToken> Tokenize(string messageTemplate) { if (messageTemplate.Length == 0) { yield return EmptyTextToken; yield break; } int nextIndex = 0; do { int num = nextIndex; TextToken textToken = ParseTextToken(nextIndex, messageTemplate, out nextIndex); if (nextIndex > num) { yield return textToken; } if (nextIndex == messageTemplate.Length) { break; } int num2 = nextIndex; MessageTemplateToken messageTemplateToken = ParsePropertyToken(nextIndex, messageTemplate, out nextIndex); if (num2 < nextIndex) { yield return messageTemplateToken; } } while (nextIndex != messageTemplate.Length); } private MessageTemplateToken ParsePropertyToken(int startAt, string messageTemplate, out int next) { int num = startAt; startAt++; startAt = messageTemplate.IndexOf('}', startAt); if (startAt == -1) { next = messageTemplate.Length; return new TextToken(messageTemplate.Substring(num)); } next = startAt + 1; string text = messageTemplate.Substring(num, next - num); string text2 = text.Substring(1, next - (num + 2)); if (text2.Length == 0) { return new TextToken(text); } if (!TrySplitTagContent(text2, out string propertyNameAndDestructuring, out string format, out string alignment)) { return new TextToken(text); } string text3 = propertyNameAndDestructuring; Destructuring destructuring = Destructuring.Default; if (text3.Length != 0 && TryGetDestructuringHint(text3[0], out destructuring)) { text3 = text3.Substring(1); } if (text3.Length == 0) { return new TextToken(text); } foreach (char c in text3) { if (!IsValidInPropertyName(c)) { return new TextToken(text); } } if (format != null) { for (int j = 0; j < format.Length; j++) { if (!IsValidInFormat(format[j])) { return new TextToken(text); } } } Alignment? alignment2 = null; if (alignment != null) { if (alignment[0] == '+') { return new TextToken(text); } if (!int.TryParse(alignment, NumberStyles.AllowLeadingSign, CultureInfo.InvariantCulture, out var result)) { return new TextToken(text); } AlignmentDirection direction = ((alignment[0] != '-') ? AlignmentDirection.Right : AlignmentDirection.Left); alignment2 = new Alignment(direction, Math.Abs(result)); } return new PropertyToken(text3, text, format, in alignment2, destructuring); } private static bool TrySplitTagContent(string tagContent, [NotNullWhen(true)] out string? propertyNameAndDestructuring, out string? format, out string? alignment) { int num = tagContent.IndexOf(':'); int num2 = tagContent.IndexOf(','); if (num == -1 && num2 == -1) { propertyNameAndDestructuring = tagContent; format = null; alignment = null; return true; } if (num2 == -1 || (num != -1 && num2 > num)) { propertyNameAndDestructuring = tagContent.Substring(0, num); format = ((num == tagContent.Length - 1) ? null : tagContent.Substring(num + 1)); alignment = null; return true; } propertyNameAndDestructuring = tagContent.Substring(0, num2); if (num == -1) { if (num2 == tagContent.Length - 1) { alignment = (format = null); return false; } format = null; alignment = tagContent.Substring(num2 + 1); return true; } if (num2 == num - 1) { alignment = (format = null); return false; } alignment = tagContent.Substring(num2 + 1, num - num2 - 1); format = ((num == tagContent.Length - 1) ? null : tagContent.Substring(num + 1)); return true; } private bool IsValidInPropertyName(char c) { if (!char.IsLetterOrDigit(c) && c != '_') { if (_acceptDottedPropertyNames) { return c == '.'; } return false; } return true; } private static bool TryGetDestructuringHint(char c, out Destructuring destructuring) { switch (c) { case '@': destructuring = Destructuring.Destructure; return true; case '$': destructuring = Destructuring.Stringify; return true; default: destructuring = Destructuring.Default; return false; } } private static bool IsValidInFormat(char c) { return c != '}'; } private static TextToken ParseTextToken(int startAt, string messageTemplate, out int next) { int num = messageTemplate.IndexOfAny(new char[2] { '{', '}' }, startAt); if (num == -1) { next = messageTemplate.Length; return new TextToken(messageTemplate.Substring(startAt, messageTemplate.Length - startAt)); } char c = messageTemplate[num]; num++; StringBuilder stringBuilder; if (c == '{') { if (num >= messageTemplate.Length || messageTemplate[num] != '{') { next = num - 1; if (next != startAt) { return new TextToken(messageTemplate.Substring(startAt, num - 1 - startAt)); } return EmptyTextToken; } stringBuilder = new StringBuilder(messageTemplate, startAt, num - startAt, messageTemplate.Length - startAt); num++; } else { stringBuilder = new StringBuilder(messageTemplate, startAt, num - startAt, messageTemplate.Length - startAt); if (num < messageTemplate.Length && messageTemplate[num] == '}') { num++; } } while (num < messageTemplate.Length) { c = messageTemplate[num]; num++; if (c == '{') { if (num >= messageTemplate.Length || messageTemplate[num] != '{') { next = num - 1; return new TextToken(stringBuilder.ToString()); } stringBuilder.Append(c); num++; } else { stringBuilder.Append(c); if (c == '}' && num < messageTemplate.Length && messageTemplate[num] == '}') { num++; } } } next = num; return new TextToken(stringBuilder.ToString()); } } public abstract class MessageTemplateToken { public abstract int Length { get; } public abstract void Render(IReadOnlyDictionary<string, LogEventPropertyValue> properties, TextWriter output, IFormatProvider? formatProvider = null); } public sealed class PropertyToken : MessageTemplateToken { private readonly int? _position; public override int Length => RawText.Length; public string PropertyName { get; } public Destructuring Destructuring { get; } public string? Format { get; } public Alignment? Alignment { get; } public bool IsPositional => _position.HasValue; internal string RawText { get; } public PropertyToken(string propertyName, string rawText, string? format = null, in Alignment? alignment = null, Destructuring destructuring = Destructuring.Default) { PropertyName = Guard.AgainstNull(propertyName, "propertyName"); Format = format; Destructuring = destructuring; RawText = Guard.AgainstNull(rawText, "rawText"); Alignment = alignment; if (int.TryParse(PropertyName, NumberStyles.None, CultureInfo.InvariantCulture, out var result) && result >= 0) { _position = result; } } public override void Render(IReadOnlyDictionary<string, LogEventPropertyValue> properties, TextWriter output, IFormatProvider? formatProvider = null) { Guard.AgainstNull(properties, "properties"); Guard.AgainstNull(output, "output"); MessageTemplateRenderer.RenderPropertyToken(this, properties, output, formatProvider, isLiteral: false, isJson: false); } public bool TryGetPositionalValue(out int position) { if (!_position.HasValue) { position = 0; return false; } position = _position.Value; return true; } public override bool Equals(object? obj) { if (obj is PropertyToken propertyToken && propertyToken.Destructuring == Destructuring && propertyToken.Format == Format && propertyToken.PropertyName == PropertyName) { return propertyToken.RawText == RawText; } return false; } public override int GetHashCode() { return PropertyName.GetHashCode(); } public override string ToString() { return RawText; } } public sealed class TextToken : MessageTemplateToken { public override int Length => Text.Length; public string Text { get; } public TextToken(string text) { Text = Guard.AgainstNull(text, "text"); } public override void Render(IReadOnlyDictionary<string, LogEventPropertyValue> properties, TextWriter output, IFormatProvider? formatProvider = null) { Guard.AgainstNull(output, "output"); MessageTemplateRenderer.RenderTextToken(this, output); } public override bool Equals(object? obj) { if (obj is TextToken textToken) { return textToken.Text == Text; } return false; } public override int GetHashCode() { return Text.GetHashCode(); } public override string ToString() { return Text; } } } namespace Serilog.Formatting { public interface ITextFormatter { void Format(LogEvent logEvent, TextWriter output); } } namespace Serilog.Formatting.Json { public sealed class JsonFormatter : ITextFormatter { private readonly string _closingDelimiter; private readonly bool _renderMessage; private readonly IFormatProvider? _formatProvider; private readonly JsonValueFormatter _jsonValueFormatter = new JsonValueFormatter(); public JsonFormatter(string? closingDelimiter = null, bool renderMessage = false, IFormatProvider? formatProvider = null) { _closingDelimiter = closingDelimiter ?? Environment.NewLine; _renderMessage = renderMessage; _formatProvider = formatProvider; } public void Format(LogEvent logEvent, TextWriter output) { Guard.AgainstNull(logEvent, "logEvent"); Guard.AgainstNull(output, "output"); output.Write("{\"Timestamp\":\""); output.Write(logEvent.Timestamp.ToString("O")); output.Write("\",\"Level\":\""); output.Write(logEvent.Level); output.Write("\",\"MessageTemplate\":"); JsonValueFormatter.WriteQuotedJsonString(logEvent.MessageTemplate.Text, output); if (_renderMessage) { output.Write(",\"RenderedMessage\":"); JsonValueFormatter.WriteQuotedJsonString(logEvent.MessageTemplate.Render(logEvent.Properties), output); } if (logEvent.TraceId.HasValue) { output.Write(",\"TraceId\":"); JsonValueFormatter.WriteQuotedJsonString(logEvent.TraceId.ToString(), output); } if (logEvent.SpanId.HasValue) { output.Write(",\"SpanId\":"); JsonValueFormatter.WriteQuotedJsonString(logEvent.SpanId.ToString(), output); } if (logEvent.Exception != null) { output.Write(",\"Exception\":"); JsonValueFormatter.WriteQuotedJsonString(logEvent.Exception.ToString(), output); } if (logEvent.Properties.Count != 0) { output.Write(",\"Properties\":{"); char? c = null; foreach (KeyValuePair<string, LogEventPropertyValue> property in logEvent.Properties) { if (c.HasValue) { output.Write(c.Value); } else { c = ','; } JsonValueFormatter.WriteQuotedJsonString(property.Key, output); output.Write(':'); _jsonValueFormatter.Format(property.Value, output);