Scripts/New-BPATask.ps1

function New-BPATask {
    <#
        .SYNOPSIS
            Creates a new AutoMate BPA task.
 
        .DESCRIPTION
            New-BPATask creates a new task object.
 
        .PARAMETER Name
            The name of the new object.
 
        .PARAMETER AML
            The AutoMate Markup Language (AML) to set on the object.
 
        .PARAMETER Notes
            The notes to set on the object.
 
        .PARAMETER Folder
            The folder to place the object in.
 
        .PARAMETER BPAServer
            The server to create the object on.
 
        .EXAMPLE
            # Create a new task
            New-BPATask -Name "Test Task"
 
        .NOTES
            Author(s): : David Seibel
            Contributor(s) :
            Date Created : 11/07/2016
            Date Modified : 02/12/2018
 
        .LINK
            https://github.com/davidseibel/PoshBPA
    #>

    [CmdletBinding()]
    param(
        [Parameter(Mandatory = $true, Position = 0)]
        [ValidateNotNullOrEmpty()]
        [string]$Name,        

        [ValidateScript({$_ -like "<AMTASK>*"})]
        [string]$AML = "",

        [string]$Notes = "",

        [ValidateScript({$_.TypeName -eq "Folder"})]
        $Folder,

        [string]$BPAServer
    )

    $guid = "{$((New-Guid).Guid)}"

    if (-not $BPAServer -and $global:BPAConnectionInfo.Count -gt 1) {
        throw "Multiple BPA Servers are connected, please specify which server to create a new task on!"
    } elseif (-not $BPAServer) {
        $BPAServer = $BPAConnectionInfo.Server
    }

    $user = Get-BPAUser -BPAServer $BPAServer | Where-Object {$_.Name -ieq ($BPAConnectionInfo | Where-Object {$_.Server -eq $BPAServer}).Credential.UserName}
    if (-not $Folder) {
        # Place the task in the users task folder
        $Folder = $user | Get-BPAFolder -Type TASKS
    }

    # Get the template object from the PoshBPA\ObjectTemplates folder, and configure the object
    $newObject = Get-BPAObjectTemplate -Type "Task" -BPAServer $BPAServer
    $newObject.ID          = $guid
    $newObject.Name        = $Name
    $newObject.ParentID    = $Folder.ID
    $newObject.Path        = Join-Path -Path $Folder.Path -ChildPath $Folder.Name
    $newObject.CreatedBy   = $user.ID
    $newObject.Notes       = $Notes
    $newObject.AML         = $AML

    $newObject | New-BPAObject -BPAServer $BPAServer
    return (Get-BPATask -ID $guid -BPAServer $BPAServer)
}