functions/Write-ErrorLog.ps1
function Write-ErrorLog { <# .SYNOPSIS Writes Error log message .DESCRIPTION Write a log event with the Error 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-ErrorLog 'Error log message' .EXAMPLE PS> Write-ErrorLog -MessageTemplate 'Processed {@Position} in {Elapsed:000} ms.' -PropertyValues $position, $elapsedMs .EXAMPLE PS> Write-ErrorLog '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.Error($MessageTemplate) if (-not (Test-Logger)) { Write-Error -Message $MessageTemplate } } 'MessageTemplateWithProperties' { [Serilog.Log]::Logger.Error($MessageTemplate, $PropertyValues) if (-not (Test-Logger)) { Write-Error -Message (Get-CollapsedMessage -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues) } } 'Exception' { [Serilog.Log]::Logger.Error($Exception, $MessageTemplate) if (-not (Test-Logger)) { Write-Error -Exception $Exception -Message $MessageTemplate } } 'ExceptionWithProperties' { [Serilog.Log]::Logger.Error($Exception, $MessageTemplate, $PropertyValues) if (-not (Test-Logger)) { Write-Error -Exception $Exception -Message (Get-CollapsedMessage -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues) } } } if ($PassThru) { Get-CollapsedMessage -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues } } |