exports/New-SysManApplication.ps1

<#
.Synopsis
Creates a new application. For the application to be valid the following properties has to be unique:\r\nName, InstallCollection, UninstallCollection, InstallActiveDirectoryGroup, UninstallActiveDirectoryGroup
.Description
Creates a new application. For the application to be valid the following properties has to be unique:\r\nName, InstallCollection, UninstallCollection, InstallActiveDirectoryGroup, UninstallActiveDirectoryGroup
.Link
https://docs.microsoft.com/en-us/powershell/module/sysman.webapi/new-sysmanapplication
#>

function New-SysManApplication {
[OutputType('SysMan.Powershell.Models.IApplication', 'SysMan.Powershell.Models.IApiErrorMessage')]
[CmdletBinding(DefaultParameterSetName='Create', PositionalBinding=$false, SupportsShouldProcess, ConfirmImpact='Medium')]
[SysMan.Powershell.Description('Creates a new application. For the application to be valid the following properties has to be unique:\r\nName, InstallCollection, UninstallCollection, InstallActiveDirectoryGroup, UninstallActiveDirectoryGroup')]
param(
    [Parameter(ParameterSetName='Create', ValueFromPipeline, HelpMessage='Creates a new application')]
    [SysMan.Powershell.Category('Body')]
    [SysMan.Powershell.Models.IUpsertApplicationV2Command]
    ${Cmd},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='The target deployment configurations')]
    [SysMan.Powershell.Category('Body')]
    [SysMan.Powershell.Models.IApplicationDeploymentConfiguration[]]
    ${DeploymentConfigurations},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='The description')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${Description},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='General message')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${GeneralMessage},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='Describes if the Application has a general message')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${HasGeneralMessage},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='The application requires a license when installed')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${HasLicense},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='A description over the requierd license')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${LicenseDescription},

    [Parameter(ParameterSetName='CreateExpanded', Mandatory, HelpMessage='The name')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${Name},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='If the application is installed on a client before the OS was redeployed the application should be installed againautomatically')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${ReinstallOnDeployment},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='If the general message should be visible when the application is installed')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${ShowGeneralMessageOnInstallation},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='If the general message should be visible when the application is uninstalled')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${ShowGeneralMessageOnUninstallation},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='If the license description should be visible when the application is installed')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${ShowLicenseDescriptionOnInstallation},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='If the license description should be visible when the application is uninstalled')]
    [SysMan.Powershell.Category('Body')]
    [System.Management.Automation.SwitchParameter]
    ${ShowLicenseDescriptionOnUninstallation},

    [Parameter(ParameterSetName='CreateExpanded', HelpMessage='The version the Application has')]
    [SysMan.Powershell.Category('Body')]
    [System.String]
    ${Version},

    [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 = @{
            Create = 'SysMan.WebApi.private\New-SysManApplication_Create';
            CreateExpanded = 'SysMan.WebApi.private\New-SysManApplication_CreateExpanded';
        }
        $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
    }
}
}