functions/Write-DebugLog.ps1
function Write-DebugLog { <# .SYNOPSIS Writes Debug log message .DESCRIPTION Write a log event with the Debug level. .PARAMETER MessageTemplate Message template describing the event. .PARAMETER Exception Exception related to the event. .PARAMETER PropertyValues Objects positionally formatted into the message template. .PARAMETER PassThru Outputs MessageTemplate populated with PropertyValues into pipeline .INPUTS MessageTemplate - Message template describing the event. .OUTPUTS None or MessageTemplate populated with PropertyValues into pipeline if PassThru specified .EXAMPLE PS> Write-DebugLog 'Debug log message' .EXAMPLE PS> Write-DebugLog -MessageTemplate 'Processed {@Position} in {Elapsed:000} ms.' -PropertyValues $position, $elapsedMs .EXAMPLE PS> Write-DebugLog 'Error occured' -Exception ([System.Exception]::new('Some exception')) #> [Cmdletbinding(DefaultParameterSetName = 'MessageTemplate')] param( [Parameter(Mandatory = $true, Position = 0, ValueFromPipeline = $true, ParameterSetName = 'MessageTemplate')] [Parameter(Mandatory = $true, Position = 0, ValueFromPipeline = $true, ParameterSetName = 'MessageTemplateWithProperties')] [Parameter(Mandatory = $true, Position = 0, ValueFromPipeline = $true, ParameterSetName = 'Exception')] [Parameter(Mandatory = $true, Position = 0, ValueFromPipeline = $true, ParameterSetName = 'ExceptionWithProperties')] [string]$MessageTemplate, [Parameter(Mandatory = $true, ParameterSetName = 'Exception')] [Parameter(Mandatory = $true, ParameterSetName = 'ExceptionWithProperties')] [System.Exception]$Exception, [Parameter(Mandatory = $true, ParameterSetName = 'ExceptionWithProperties')] [Parameter(Mandatory = $true, ParameterSetName = 'MessageTemplateWithProperties')] [object[]]$PropertyValues, [Parameter(Mandatory = $false)] [switch]$PassThru ) switch ($PsCmdlet.ParameterSetName) { 'MessageTemplate' { [Serilog.Log]::Logger.Debug($MessageTemplate) if (-not (Test-Logger)) { Write-DebugEx -MessageTemplate $MessageTemplate } } 'MessageTemplateWithProperties' { [Serilog.Log]::Logger.Debug($MessageTemplate, $PropertyValues) if (-not (Test-Logger)) { Write-DebugEx -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues } } 'Exception' { [Serilog.Log]::Logger.Debug($Exception, $MessageTemplate) if (-not (Test-Logger)) { Write-DebugEx -MessageTemplate "$MessageTemplate `n $Exception" } } 'ExceptionWithProperties' { [Serilog.Log]::Logger.Debug($Exception, $MessageTemplate, $PropertyValues) if (-not (Test-Logger)) { Write-DebugEx -MessageTemplate "$MessageTemplate `n $Exception" -PropertyValues $PropertyValues } } } if ($PassThru) { Get-CollapsedMessage -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues } } |