Scripts/New-BPAFolder.ps1
function New-BPAFolder { <# .SYNOPSIS Creates a new AutoMate BPA folder. .DESCRIPTION New-BPAFolder creates a new folder object. .PARAMETER Name The name of the new folder. .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 a new folder Get-BPAFolder ParentFolder | New-BPAFolder -Name "FTP Workflows" .NOTES Author(s): : David Seibel Contributor(s) : Date Created : 09/11/2017 Date Modified : 02/12/2018 .LINK https://github.com/davidseibel/PoshBPA #> [CmdletBinding()] param( [Parameter(Mandatory = $true, Position = 0)] [ValidateNotNullOrEmpty()] [string]$Name, [string]$Notes = "", [Parameter(Mandatory = $true)] [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 folder on!" } elseif (-not $BPAServer) { $BPAServer = $BPAConnectionInfo.Server } $user = Get-BPAUser -BPAServer $BPAServer | Where-Object {$_.Name -ieq ($BPAConnectionInfo | Where-Object {$_.Server -eq $BPAServer}).Credential.UserName} $newObject = Get-BPAObjectTemplate -Type "Folder " -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 | New-BPAObject -BPAServer $BPAServer return (Get-BPAFolder -ID $guid -BPAServer $BPAServer) } |