exports/Start-SysManToolFromGet.ps1

<#
.Synopsis
Execute a tool from the server in the app pool context. This method is usually used to run a powershell script that\r\nreturn files
.Description
Execute a tool from the server in the app pool context. This method is usually used to run a powershell script that\r\nreturn files
.Link
https://docs.microsoft.com/en-us/powershell/module/sysman.webapi/start-sysmantoolfromget
#>

function Start-SysManToolFromGet {
[OutputType('SysMan.Powershell.Models.IPathsApiV2ToolIdRunGetResponses200ContentApplicationJsonSchema', 'SysMan.Powershell.Models.IApiErrorMessage')]
[CmdletBinding(DefaultParameterSetName='Run', PositionalBinding=$false)]
[SysMan.Powershell.Description('Execute a tool from the server in the app pool context. This method is usually used to run a powershell script that\r\nreturn files')]
param(
    [Parameter(Mandatory, HelpMessage='The id of the tool')]
    [SysMan.Powershell.Category('Path')]
    [System.String]
    ${Id},

    [Parameter(Mandatory, HelpMessage='The id of the tool')]
    [SysMan.Powershell.Category('Query')]
    [System.String]
    ${CmdId},

    [Parameter(HelpMessage='The name of the computer that will be sent into the tool. Can be empty string of no computer is needed.')]
    [SysMan.Powershell.Category('Query')]
    [System.String]
    ${CmdComputerName},

    [Parameter(HelpMessage='The mobile device name. Can be empty string if no mobile device is needed.')]
    [SysMan.Powershell.Category('Query')]
    [System.String]
    ${CmdMobileDeviceName},

    [Parameter(HelpMessage='The name of the user that will be sent into the tool. Can be empty string if no user is needed.')]
    [SysMan.Powershell.Category('Query')]
    [System.String]
    ${CmdUserName},

    [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 = @{
            Run = 'SysMan.WebApi.private\Start-SysManToolFromGet_Run';
        }
        $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
    }
}
}