exports/Invoke-SysManHandleMessage.ps1

<#
.Synopsis
Handles a message that has been associated to a user
.Description
Handles a message that has been associated to a user
.Link
https://docs.microsoft.com/en-us/powershell/module/sysman.webapi/invoke-sysmanhandlemessage
#>

function Invoke-SysManHandleMessage {
[OutputType('System.Boolean')]
[CmdletBinding(DefaultParameterSetName='Handle', PositionalBinding=$false, SupportsShouldProcess, ConfirmImpact='Medium')]
[SysMan.Powershell.Description('Handles a message that has been associated to a user')]
param(
    [Parameter(Mandatory, HelpMessage='The id of the message to handle')]
    [SysMan.Powershell.Category('Path')]
    [System.Int64]
    ${Id},

    [Parameter(ParameterSetName='Handle', ValueFromPipeline, HelpMessage='Handles a message')]
    [SysMan.Powershell.Category('Body')]
    [SysMan.Powershell.Models.IHandleMessageCommand]
    ${Cmd},

    [Parameter(HelpMessage='When specified, PassThru will force the cmdlet return a ''bool'' given that there isn''t a return type by default.')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${PassThru},

    [Parameter(ParameterSetName='HandleExpanded', HelpMessage='If the calculation of the message quittance should also be made in the context of the provided computer. If a value is provided')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${ComputerName},

    [Parameter(ParameterSetName='HandleExpanded', Mandatory, HelpMessage='The id of the message')]
    [SysMan.Powershell.Category('Body')]
    [System.Int64]
    ${MessageId},

    [Parameter(ParameterSetName='HandleExpanded', HelpMessage='If the message was of type Survey a message can be set. This value will be ignored if the message is not the "correct" type.')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${ResponseMessage},

    [Parameter(ParameterSetName='HandleExpanded', HelpMessage='If the message was of type Survey a satisfactory level can be set. This value will be ignored if the message is not the "correct" type.')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${SatisfactoryLevel},

    [Parameter(DontShow, HelpMessage='Wait for .NET debugger to attach')]
    [SysMan.Powershell.Category('Runtime')]
    [System.Management.Automation.SwitchParameter]
    ${Break},

    [Parameter(DontShow, HelpMessage='SendAsync Pipeline Steps to be appended to the front of the pipeline')]
    [ValidateNotNull()]
    [SysMan.Powershell.Category('Runtime')]
    [SysMan.Powershell.Runtime.SendAsyncStep[]]
    ${HttpPipelineAppend},

    [Parameter(DontShow, HelpMessage='SendAsync Pipeline Steps to be prepended to the front of the pipeline')]
    [ValidateNotNull()]
    [SysMan.Powershell.Category('Runtime')]
    [SysMan.Powershell.Runtime.SendAsyncStep[]]
    ${HttpPipelinePrepend},

    [Parameter(DontShow, HelpMessage='The URI for the proxy server to use')]
    [SysMan.Powershell.Category('Runtime')]
    [System.Uri]
    ${Proxy},

    [Parameter(DontShow, HelpMessage='Credentials for a proxy server to use for the remote call')]
    [ValidateNotNull()]
    [SysMan.Powershell.Category('Runtime')]
    [System.Management.Automation.PSCredential]
    ${ProxyCredential},

    [Parameter(DontShow, HelpMessage='Use the default credentials for the proxy')]
    [SysMan.Powershell.Category('Runtime')]
    [System.Management.Automation.SwitchParameter]
    ${ProxyUseDefaultCredentials}
)

begin {
    try {
        $outBuffer = $null
        if ($PSBoundParameters.TryGetValue('OutBuffer', [ref]$outBuffer)) {
            $PSBoundParameters['OutBuffer'] = 1
        }
        $parameterSet = $PsCmdlet.ParameterSetName
        $mapping = @{
            Handle = 'SysMan.WebApi.private\Invoke-SysManHandleMessage_Handle';
            HandleExpanded = 'SysMan.WebApi.private\Invoke-SysManHandleMessage_HandleExpanded';
        }
        $wrappedCmd = $ExecutionContext.InvokeCommand.GetCommand(($mapping[$parameterSet]), [System.Management.Automation.CommandTypes]::Cmdlet)
        $scriptCmd = {& $wrappedCmd @PSBoundParameters}
        $steppablePipeline = $scriptCmd.GetSteppablePipeline($myInvocation.CommandOrigin)
        $steppablePipeline.Begin($PSCmdlet)
    } catch {
        throw
    }
}

process {
    try {
        $steppablePipeline.Process($_)
    } catch {
        throw
    }
}

end {
    try {
        $steppablePipeline.End()
    } catch {
        throw
    }
}
}