15 instantiations of LogBufferingFilterRule
Microsoft.AspNetCore.Diagnostics.Middleware (1)
Buffering\PerIncomingRequestLoggingBuilderExtensions.cs (1)
100options.Rules.Add(new LogBufferingFilterRule(logLevel: logLevel));
Microsoft.AspNetCore.Diagnostics.Middleware.Tests (13)
Buffering\PerIncomingRequestLoggingBuilderExtensionsTests.cs (9)
57new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 58new(logLevel: LogLevel.Information), 77new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 78new(logLevel: LogLevel.Information), 83options.Rules.Add(new LogBufferingFilterRule(categoryName: "Program.MyLogger", 85options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Information)); 99new(categoryName: "Program.MyLogger", logLevel: LogLevel.Information, eventId: 1, eventName: "number one"), 100new(logLevel : LogLevel.Information), 104new(logLevel: LogLevel.Information),
Buffering\PerRequestLogBufferingOptionsCustomValidatorTests.cs (1)
21new LogBufferingFilterRule(categoryName: "**")
Logging\AcceptanceTests.cs (3)
867options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug)); 916options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug)); 917options.Rules.Add(new LogBufferingFilterRule(logLevel: LogLevel.Debug, categoryName: "logatrequest"));
Microsoft.Extensions.Telemetry (1)
Buffering\GlobalBufferLoggingBuilderExtensions.cs (1)
86.Configure(options => options.Rules.Add(new LogBufferingFilterRule(logLevel: logLevel)));
38 references to LogBufferingFilterRule
Microsoft.AspNetCore.Diagnostics.Middleware (5)
Buffering\IncomingRequestLogBuffer.cs (1)
29private readonly LogBufferingFilterRule[] _filterRules;
Buffering\PerRequestLogBufferingConfigureOptions.cs (1)
43foreach (LogBufferingFilterRule rule in parsedOptions.Rules)
Buffering\PerRequestLogBufferingOptions.cs (2)
62/// Gets or sets the collection of <see cref="LogBufferingFilterRule"/> used for filtering log messages for the purpose of further buffering. 72public IList<LogBufferingFilterRule> Rules { get; set; } = [];
Buffering\PerRequestLogBufferingOptionsCustomValidator.cs (1)
18foreach (LogBufferingFilterRule rule in options.Rules)
Microsoft.AspNetCore.Diagnostics.Middleware.Tests (5)
Buffering\PerIncomingRequestLoggingBuilderExtensionsTests.cs (4)
55List<LogBufferingFilterRule> expectedData = 75List<LogBufferingFilterRule> expectedData = 97List<LogBufferingFilterRule> initialData = 102List<LogBufferingFilterRule> updatedData =
Buffering\PerRequestLogBufferingOptionsCustomValidatorTests.cs (1)
19Rules = new List<LogBufferingFilterRule>
Microsoft.Extensions.Telemetry (28)
Buffering\GlobalBuffer.cs (1)
20internal LogBufferingFilterRule[] LastKnownGoodFilterRules;
Buffering\GlobalLogBufferingConfigureOptions.cs (1)
43foreach (LogBufferingFilterRule rule in parsedOptions.Rules)
Buffering\GlobalLogBufferingOptions.cs (2)
61/// Gets or sets the collection of <see cref="LogBufferingFilterRule"/> used for filtering log messages for the purpose of further buffering. 70public IList<LogBufferingFilterRule> Rules { get; set; } = [];
Buffering\GlobalLogBufferingOptionsCustomValidator.cs (1)
17foreach (LogBufferingFilterRule rule in options.Rules)
Buffering\LogBufferingFilterRule.cs (1)
21/// Initializes a new instance of the <see cref="LogBufferingFilterRule"/> class.
Buffering\LogBufferingFilterRuleSelector.cs (22)
24private static readonly ObjectPool<List<LogBufferingFilterRule>> _rulePool = 25PoolFactory.CreateListPool<LogBufferingFilterRule>(); 27private readonly ObjectPool<List<LogBufferingFilterRule>> _cachedRulePool = 28PoolFactory.CreateListPool<LogBufferingFilterRule>(); 29private readonly ConcurrentDictionary<(LogLevel, EventId), List<LogBufferingFilterRule>> _ruleCache = new(); 31public static LogBufferingFilterRule[] SelectByCategory(IList<LogBufferingFilterRule> rules, string category) 33List<LogBufferingFilterRule> rulesOfCategory = _rulePool.Get(); 37foreach (LogBufferingFilterRule rule in rules) 55foreach (((LogLevel, EventId) key, List<LogBufferingFilterRule> value) in _ruleCache) 63public LogBufferingFilterRule? Select( 64IList<LogBufferingFilterRule> rules, 70List<LogBufferingFilterRule> ruleCandidates = _ruleCache.GetOrAdd((logLevel, eventId), _ => 72List<LogBufferingFilterRule> candidates = _cachedRulePool.Get(); 73foreach (LogBufferingFilterRule rule in rules) 85LogBufferingFilterRule? currentBest = null; 86foreach (LogBufferingFilterRule ruleCandidate in ruleCandidates) 97private static bool IsAttributesMatch(LogBufferingFilterRule rule, IReadOnlyList<KeyValuePair<string, object?>>? attributes) 114private static bool IsBetter(LogBufferingFilterRule? currentBest, LogBufferingFilterRule ruleCandidate) 133private static bool IsMatch(LogBufferingFilterRule rule, string category) 166private static bool IsMatch(LogBufferingFilterRule rule, LogLevel logLevel, EventId eventId)