Main | Contact | Blog | Documentation

PowerShell Framework

The project dedicated to empowering your PowerShell scripting.

Logging Provider: Eventlog

Back to: Logging

What are Logging Providers?

Logging to EventLog

Description

Logs messages to the Windows Eventlog. By default, it will log to the Application log as PSFramework, defaulting back to “Application” as source if unavailable.

For more easily associatable logging, it is strongly recommended to use a dedicated source per task. Sources that do not exist yet will automatically be created if able to (this would usually require running as admin).

Stats

Name eventlog
Version 2
ConfigurationRoot PSFramework.Logging.EventLog
Supports Data True
Installation Not Required

Properties

Properties are used to control the behavior of the Provider. They can be specified using Set-PSFLoggingProvider or provided using the Configuration system.

Name Default Value Description
LogName Application Name of the log to write to. Log will NOT be created if it does not yet exist
Souce PSFramework The source under which to write. Will be created if needed and able to.
UseFallback True If the source cannot be created, should the provider fall back to using the source “Application”? Fails if not logging to the Applciation log.
Category 1000 What category number to use. No technical effect, but could be used to differentiate between scripts if you do not wish to create multiple sources..
InfoID 1000 Event ID under which an information message would be written to log.
WarningID 2000 Event ID under which an warning message would be written to log.
ErrorID 666 Event ID under which an error message would be written to log.
ErrorTag error Tag a message must have in order to be categorized as an Error when it comes to logging to eventlog.
TimeFormat ‘yyyy-MM-dd HH:mm:ss.fff’ The time format to use for timestamps
NumericTagAsID False When set to True, purely numeric tags (e.g. ‘123’) are used to determine the EventID if present.
TagToID Null A hashtable mapping tag on a message to an event ID.

Notes

Event Properties

The message fields written to the event can be retrieved from the event properties. They are written in the following order:

Logging ID

The Logging ID is a unique ID that is generated when the Logging Instance gets initialized. As part of that initialization, it will generate an eventlog information entry with event ID 999, signaling its start.

This enables you to clearly identify individual runs of a given task, even if on each iteration it write under the same source or category.

Data and its pitfalls

This Logging Provider supports the Data field. On Write-PSFMessage there is a parameter called -Data. It accepts a hashtable of additional values that may be consumed by a Logging Provider if it will.

The eventlog provider tries to do so:

As additional properties - orderwise under LoggingID - each entry in such a hashtable will be included in a format like this:

Data| <key> : <value> 

Due to limitations in the eventlog system, there is a maximum length of 31839 characters. Datasets that are longer will get truncated.

Specifying the EventID with the message

By Data Field

The Windows eventlog has theoretically the ability to classify different messages with event IDs, making it easier to filter by / monitor for specific IDs, rather than having to inspect the message more deeply.

The problem with that from a PSFramework logging perspective is that messages are not specific to a given logging provider, thus there is no parameter for an event ID. The solution for that is the flexible -Data parameter on Write-PSFMessage. With that we can check for a specific key and select the EventID from that.

We look for the key 'EventLog.ID':

Write-PSFmessage -Message "Hello" -Data @{ 'EventLog.ID' = 1234 }

This also means, that the 'EventLog.ID' key in the Data hashtable will not be included in the data field as all other entries in Data are (as described in the section above)

By numeric tag

When configuring the logging provider, you can provide a setting that will cause the instance to consider tags that are purely numeric to mean the event ID:

$paramSetPSFLoggingProvider = @{
    Name           = 'eventlog'
    InstanceName   = 'MyTask'
    Enabled        = $true
    NumericTagAsID = $true
    Wait         = $true
}
Set-PSFLoggingProvider @paramSetPSFLoggingProvider

With that, you can now provide the ID with the message via the tag field:

# Eventlog entry with ID 123
Write-PSFMessage -Message 'Something happened' -Tag 123

Mapping any tag to an ID

A second option allows you to specify an ID for any given tag (but in return means, you cannot read from the message call what ID is being assigned):

$paramSetPSFLoggingProvider = @{
    Name         = 'eventlog'
    InstanceName = 'MyTask'
    Enabled      = $true
    TagToID      = @{
        start = 1
        end = 2
    }
    Wait         = $true
}
Set-PSFLoggingProvider @paramSetPSFLoggingProvider

With that, you can now provide the ID with the message via the tag field:

# Eventlog entry with ID 1
Write-PSFMessage -Message 'Something happened' -Tag start

Back to: Logging