functions/Write-FatalLog.ps1

function Write-FatalLog {
    <#
    .SYNOPSIS
        Writes Fatal log message
    .DESCRIPTION
        Write a log event with the Fatal 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-FatalLog 'Fatal log message'
    .EXAMPLE
        PS> Write-FatalLog -MessageTemplate 'Processed {@Position} in {Elapsed:000} ms.' -PropertyValues $position, $elapsedMs
    .EXAMPLE
        PS> Write-FatalLog 'Fatal 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.Fatal($MessageTemplate)

            if(-not (Test-Logger)){
                Write-Error -Message $MessageTemplate
            }
        }
        'MessageTemplateWithProperties'{
            [Serilog.Log]::Logger.Fatal($MessageTemplate, $PropertyValues)

            if(-not (Test-Logger)){
                Write-Error -Message (Get-CollapsedMessage -MessageTemplate $MessageTemplate -PropertyValues $PropertyValues)
            }
        }
        'Exception'{
            [Serilog.Log]::Logger.Fatal($Exception, $MessageTemplate)

            if(-not (Test-Logger)){
                Write-Error -Exception $Exception -Message $MessageTemplate
            }
        }
        'ExceptionWithProperties'{
            [Serilog.Log]::Logger.Fatal($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
    }
}