Scripts/New-BPAUser.ps1

function New-BPAUser {
    <#
        .SYNOPSIS
            Creates a new AutoMate BPA user.
 
        .DESCRIPTION
            New-BPAProcess creates a new user object.
 
        .PARAMETER Name
            The name/username of the new object.
 
        .PARAMETER Notes
            The new 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 new user
            New-BPAUser -Name David
 
        .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,

        <#[string]$Password, API BUG: does not support setting user password via REST call #>

        [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 user 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) {
        $Folder = Get-BPAFolder -Name USERS -BPAServer $BPAServer
    }

    # Get the template object from the PoshBPA\ObjectTemplates folder, and configure the object
    $newObject = Get-BPAObjectTemplate -Type "User" -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.Username    = $Name
    #$newObject.Password = $Password # Not yet supported by the API

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