Class GraphLogger
Logging portion of graph.
Inherited Members
Namespace: Microsoft.Graph.Communications.Common.Telemetry
Assembly: Microsoft.Graph.Communications.Common.dll
Syntax
public class GraphLogger : Disposable, IDisposable, IGraphLogger, IObservable<LogEvent>
Constructors
GraphLogger(String, IEnumerable<Object>, Boolean, ObfuscationConfiguration)
Initializes a new instance of the Graph
Declaration
public GraphLogger(string component = null, IEnumerable<object> properties = null, bool redirectToTrace = false, ObfuscationConfiguration obfuscationConfiguration = null)
Parameters
Type | Name | Description |
---|---|---|
String | component | The component in which log is createdThe component in which this logger is created. |
IEnumerable<Object> | properties | Common properties to be set on each event |
Boolean | redirectToTrace | if set to |
Obfuscation |
obfuscationConfiguration | The obfuscation configuration |
Fields
StartupLoggerNameSuffix
The startup logger name prefix
Declaration
public const string StartupLoggerNameSuffix = "_Startup"
Field Value
Type | Description |
---|---|
String |
Properties
Component
Gets or the component of logger.
Declaration
public string Component { get; }
Property Value
Type | Description |
---|---|
String |
CorrelationId
Gets or sets the correlation identifier. This is used to track correlation between multiple requests for one scenario.
Declaration
public Guid CorrelationId { get; set; }
Property Value
Type | Description |
---|---|
Guid |
DiagnosticLevel
Gets or sets the diagnostic level for the logger.
Declaration
public TraceLevel DiagnosticLevel { get; set; }
Property Value
Type | Description |
---|---|
Trace |
LogicalThreadId
Gets or sets the logical thread identifier. This id is used for tracking the flow of one request throughout the lifetime until it ends.
Declaration
public uint LogicalThreadId { get; set; }
Property Value
Type | Description |
---|---|
UInt32 |
ObfuscationConfiguration
Gets the obfuscation configuration.
Declaration
public ObfuscationConfiguration ObfuscationConfiguration { get; }
Property Value
Type | Description |
---|---|
Obfuscation |
Properties
Gets the common properties for each event.
Declaration
public IReadOnlyDictionary<Type, object> Properties { get; }
Property Value
Type | Description |
---|---|
IRead |
Methods
Dispose(Boolean)
Protected implementation of dispose. This will be triggered only once regardless if manually disposed or garbage collected.
Declaration
protected override void Dispose(bool disposing)
Parameters
Type | Name | Description |
---|---|---|
Boolean | disposing |
|
Overrides
Log(TraceLevel, String, String, Guid, Guid, LogEventType, IEnumerable<Object>, String, String, Int32)
Log messages classified as the provided trace level.
Declaration
public LogEvent Log(TraceLevel level, string message, string component = null, Guid correlationId = default(Guid), Guid requestId = default(Guid), LogEventType eventType = LogEventType.Trace, IEnumerable<object> properties = null, string memberName = null, string filePath = null, int lineNumber = 0)
Parameters
Type | Name | Description |
---|---|---|
Trace |
level | The trace level. |
String | message | A composite format string that includes one or more format items. |
String | component | The component in which log is created |
Guid | correlationId | The correlation identifier. |
Guid | requestId | The request identifier. |
Log |
eventType | Log event type |
IEnumerable<Object> | properties | Extra properties for the log event |
String | memberName | Calling function. |
String | filePath | File name where code is located. |
Int32 | lineNumber | Line number where code is located. |
Returns
Type | Description |
---|---|
Log |
Log Event object. |
Subscribe(IObserver<LogEvent>)
Create a subscription for logging events.
Declaration
public IDisposable Subscribe(IObserver<LogEvent> observer)
Parameters
Returns
Type | Description |
---|---|
IDisposable | A reference to an interface that allows observers to stop receiving notifications before the provider has finished sending them. |