functions/Resume-WEFSubscription.ps1

function Resume-WEFSubscription {
    <#
        .Synopsis
            Resume-WEFSubscription
 
        .DESCRIPTION
            Retry a Windows Eventlog Forwarding subscription
 
        .PARAMETER InputObject
            Pipeline catching object for Get-WEFSubscription
 
        .PARAMETER ComputerName
            The computer(s) to connect to.
            Supports PSSession objects, will reuse sessions.
 
            Available aliases: "host", "hostname", "Computer", "DNSHostName"
 
        .PARAMETER Session
            PSSession(s) to connect to.
 
        .PARAMETER Name
            Name of the subscription to remove.
            Only needed when InputObject is not used.
            Must be specified when piping in a computername or a session.
 
            Available aliases: "DisplayName", "SubscriptionID", "Idendity"
 
        .PARAMETER Credential
            The credentials to use on remote calls.
 
        .PARAMETER PassThru
            Output the subscription object
 
        .PARAMETER WhatIf
 
            If this switch is enabled, no actions are performed but informational messages will be displayed that explain what would happen if the command were to run.
 
        .PARAMETER Confirm
 
            If this switch is enabled, you will be prompted for confirmation before executing any operations that change state.
 
        .EXAMPLE
            PS C:\> Resume-WEFSubscription -Name "Subscription1"
 
            Resume the subscription "Subscription1"
 
        .EXAMPLE
            PS C:\> Get-WEFSubscription -Name "Subscription1" | Resume-WEFSubscription
 
            Resume "Subscription1" by using the pipeline.
 
        .PARAMETER PassThru
 
            If this switch is enabled, the function will return the working object to the pipeline for further processing
 
        .NOTES
            Author: Andreas Bellstedt
 
        .LINK
            https://github.com/AndiBellstedt/WindowsEventForwarding
    #>

    [Diagnostics.CodeAnalysis.SuppressMessageAttribute("PSShouldProcess", "")]
    [CmdletBinding( DefaultParameterSetName = 'ComputerName',
        SupportsShouldProcess = $true,
        ConfirmImpact = 'medium')]
    Param(
        [Parameter(ValueFromPipeline = $true, Position = 0, ParameterSetName = "InputObject")]
        [WEF.Subscription[]]
        $InputObject,

        [Parameter(ValueFromPipeline = $false, Position = 0, Mandatory = $false, ParameterSetName = "ComputerName")]
        [Parameter(ValueFromPipeline = $false, Position = 0, Mandatory = $false, ParameterSetName = "Session")]
        [Alias("DisplayName", "SubscriptionID", "Idendity")]
        [ValidateNotNullOrEmpty()]
        [String[]]
        $Name,

        [Parameter(ValueFromPipeline = $true, Position = 1, Mandatory = $false, ParameterSetName = "ComputerName")]
        [Alias("host", "hostname", "Computer", "DNSHostName")]
        [PSFComputer[]]
        $ComputerName = $env:COMPUTERNAME,

        [Parameter(ParameterSetName = "Session")]
        [System.Management.Automation.Runspaces.PSSession[]]
        $Session,

        [PSCredential]
        $Credential,

        [Switch]
        $PassThru
    )

    Begin {
        # If session parameter is used -> transfer it to ComputerName,
        # The class "PSFComputer" from PSFramework can handle it. This simplifies the handling in the further process block
        if ($Session) { $ComputerName = $Session }
    }

    Process {
        try { [Console]::OutputEncoding = [System.Text.Encoding]::UTF8 } catch { Write-PSFMessage -Level Significant -Message "Exception while setting UTF8 OutputEncoding. Continue script." -ErrorRecord $_ }
        Write-PSFMessage -Level Debug -Message "ParameterNameSet: $($PsCmdlet.ParameterSetName)"

        #region query specified subscription when not piped in
        if ($PsCmdlet.ParameterSetName -ne "InputObject") {
            # when not inputobject --> query for existing object to modify
            Write-PSFMessage -Level Verbose -Message "Gathering $ComputerName for subscription $Name"
            try {
                $paramGetWEFSubscription = @{
                    Name         = $Name
                    ComputerName = $ComputerName
                    ErrorAction  = "Stop"
                }
                if ($Credential) { $paramGetWEFSubscription.Add("Credential", $Credential) }
                $InputObject = Get-WEFSubscription @paramGetWEFSubscription
                Remove-Variable paramGetWEFSubscription -Force
            }
            catch {
                Stop-PSFFunction -Message "Error finding subscription '$name' on computer $computer" -ErrorRecord $_ -EnableException $true
            }
            if (-not $InputObject) {
                $message = "Subscription $Name not found"
                if ($ComputerName) { $message = $message + " on " + $ComputerName }
                Stop-PSFFunction -Message $message  -ErrorRecord $_ -EnableException $true
            }
        }
        #endregion query specified subscription when not piped in

        foreach ($subscription in $InputObject) {
            Write-PSFMessage -Level Verbose -Message "Processing '$($subscription.Name)' on '$($subscription.ComputerName)'" -Target $subscription.ComputerName

            #region Resume subscription from system
            # Retry existing subscription. Execute wecutil to retry subscription with redirecting error output
            if ($pscmdlet.ShouldProcess("Subscription: $($subscription.Name) on computer '$($subscription.ComputerName)'", "Resume")) {
                Write-PSFMessage -Level Verbose -Message "Resume subscription '$($subscription.Name)' on computer '$($subscription.ComputerName)'" -Target $subscription.ComputerName

                $invokeParams = @{
                    ComputerName  = $subscription.ComputerName
                    ErrorAction   = "Stop"
                    ErrorVariable = "ErrorReturn"
                    ArgumentList  = @(
                        $subscription.Name
                    )
                }
                if ($Credential) { $invokeParams.Add("Credential", $Credential)}

                try {
                    $null = Invoke-PSFCommand @invokeParams -ScriptBlock {
                        try { [Console]::OutputEncoding = [System.Text.Encoding]::UTF8 } catch { Write-Information -MessageData "Exception while setting UTF8 OutputEncoding. Continue script." }
                        . "$env:windir\system32\wecutil.exe" "retry-subscription" "$($args[0])" *>&1
                    }
                    if ($ErrorReturn) { Write-Error "" -ErrorAction Stop}
                }
                catch {
                    $ErrorReturnWEC = $ErrorReturn | Where-Object { $_.InvocationInfo.MyCommand.Name -like 'wecutil.exe' } | select-object -Unique
                    if ($ErrorReturnWEC) {
                        $ErrorMsg = [string]::Join(" ", ($ErrorReturnWEC.Exception.Message.Replace("`r`n", " ") | select-object -Unique))
                    }
                    else {
                        $ErrorMsg = [string]::Join(" ", ($ErrorReturn.Exception.Message | select-object -Unique))
                    }

                    Stop-PSFFunction -Message "Error resuming subscription '$($subscription.Name)' on computer '$($subscription.ComputerName)'! $($ErrorMsg)" -ErrorRecord $_
                }

                if ($PassThru) {
                    Write-PSFMessage -Level Verbose -Message "Passthru specified, output deleted object '$($subscription.Name)' on '$ComputerName'"
                    $subscription
                }
            }
            #endregion Resume subscription
        }
    }

    End {
    }
}