Skip to content

Commit

Permalink
fix: Fix a context data capture when the Microsoft.Extensions.Logging…
Browse files Browse the repository at this point in the history
… console logger is used. (#2261) (#2315)
  • Loading branch information
lowell-trimble authored Mar 8, 2024
1 parent 81abc5c commit f8422d6
Showing 1 changed file with 7 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -81,14 +81,13 @@ private static Dictionary<string, object> GetContextData(MEL.ILogger logger, IAg
var getLoggersArrayFunc = _getLoggersArray ??= VisibilityBypasser.Instance.GeneratePropertyAccessor<dynamic>(logger.GetType(), "ScopeLoggers");
var loggers = getLoggersArrayFunc(logger);

// Get the first ScopeLogger in the array (logger.ScopeLoggers[0])
// If there is more than one scope logger, they've all received the same data, so the first
// one should be fine
object firstLogger = loggers.GetValue(0);

// Get the scope provider from that logger (logger.ScopeLoggers[0].ExternalScopeProvider)
var scopeProviderPI = _scopeProviderPropertyInfo ??= firstLogger.GetType().GetProperty("ExternalScopeProvider");
var scopeProvider = scopeProviderPI.GetValue(firstLogger) as IExternalScopeProvider;
// Get the last ScopeLogger in the array (logger.ScopeLoggers[loggers.Length-1])
// If there is more than one scope logger, the last logger is the one with the ExternalScopeProvider set
object lastLogger = loggers.GetValue(loggers.Length-1);

// Get the scope provider from that logger (logger.ScopeLoggers[loggers.Length-1].ExternalScopeProvider)
var scopeProviderPI = _scopeProviderPropertyInfo ??= lastLogger.GetType().GetProperty("ExternalScopeProvider");
var scopeProvider = scopeProviderPI.GetValue(lastLogger) as IExternalScopeProvider;

// Get the context data
var harvestedKvps = new Dictionary<string, object>();
Expand Down

0 comments on commit f8422d6

Please sign in to comment.