Public/Get-MachineConnectionStatus.ps1

function Get-MachineConnectionStatus {
    <#
    .SYNOPSIS
        Returns the connection status of one or more machines.
 
    .DESCRIPTION
        This function returns the connection status of one or more machines. It takes an array of MachineResource objects as input and retrieves the connection status for each machine. Optionally, it can include the machine name in the output.
 
    .EXAMPLE
        PS C:\> Get-MachineConnectionStatus -Machine $machines -IncludeMachineName
        Returns the connection status of the specified machines and includes the machine name in the output.
 
    .INPUTS
        - Machine: An array of MachineResource objects representing the machines to check the connection status for.
 
    .OUTPUTS
        The function outputs the connection status of each machine as a MachineConnectionStatus object. If the -IncludeMachineName switch is used, the output includes the machine name as well.
 
    .NOTES
        This function requires a connection to the Octopus server. If no connection is available, an error is thrown.
    #>

    [CmdletBinding()]
    param (
        [Parameter(Mandatory = $true,
            Position = 0,
            ValueFromPipeline = $true,
            ValueFromPipelineByPropertyName = $true,
            ValueFromRemainingArguments = $false,
            ParameterSetName = 'Parameter Set 1')]
        [MachineTransformation()]
        [Octopus.Client.Model.MachineResource[]]
        $Machine,
        # Switch to add machine name to output
        [Parameter(Mandatory = $false,
            Position = 1,
            ValueFromPipelineByPropertyName = $true,
            ParameterSetName = 'Parameter Set 1')]
        [switch]
        $IncludeMachineName
    )

    begin {
        try {
            ValidateConnection
        }
        catch {
            $PSCmdlet.ThrowTerminatingError($_)
        }
    }

    process {
        foreach ($_machine in $Machine) {
            $machineConnectionStatus = $repo._repository.Machines.GetConnectionStatus($_machine)
            if ($IncludeMachineName) {
                $machineConnectionStatus | Add-Member -MemberType NoteProperty -Name MachineName -Value $_machine.Name
            }
            $machineConnectionStatus
        }
    }

    end {}
}