Functions/Public/Copy-AMProcess.ps1
function Copy-AMProcess { <# .SYNOPSIS Copies an AutoMate Enterprise process. .DESCRIPTION Copy-AMProcess can copy a process object within, or between servers. .PARAMETER InputObject The object to copy. .PARAMETER Name The new name to set on the object. .PARAMETER Folder The folder to place the object in. .PARAMETER Connection The server to copy the object to. .INPUTS The following AutoMate object types can be modified by this function: Process .OUTPUTS Process .EXAMPLE # Copy process "Start Service" from server1 to server2 Get-AMProcess "Start Service" -Connection server1 | Copy-AMProcess -Folder (Get-AMFolder PROCESSES -Connection server2) -Connection server2 .EXAMPLE # Copy process "Start Service" with new name "Restart Service" Get-AMProcess "Start Service" | Copy-AMProcess -Name "Restart Service" .LINK https://github.com/AutomatePS/AutomatePS #> [CmdletBinding()] param ( [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [ValidateNotNullOrEmpty()] $InputObject, [ValidateNotNullOrEmpty()] [string]$Name, [ValidateScript({$_.Type -eq "Folder"})] $Folder, [ValidateNotNullOrEmpty()] $Connection ) BEGIN { if ($PSBoundParameters.ContainsKey("Connection")) { $Connection = Get-AMConnection -Connection $Connection if (($Connection | Measure-Object).Count -eq 0) { throw "No AutoMate server specified!" } elseif (($Connection | Measure-Object).Count -gt 1) { throw "Multiple AutoMate servers specified, please specify one server to copy the process to!" } $user = Get-AMUser -Connection $Connection | Where-Object {$_.Name -ieq $Connection.Credential.UserName} } } PROCESS { foreach ($obj in $InputObject) { if ($obj.Type -eq "Process") { if ($PSBoundParameters.ContainsKey("Connection")) { # Copy from one AutoMate server to another if ($obj.ConnectionAlias -ne $Connection.Alias) { if ($PSBoundParameters.ContainsKey("Folder")) { if ($Folder.ConnectionAlias -ne $Connection.Alias) { throw "Folder specified exists on $($Folder.ConnectionAlias), the folder must exist on $($Connection.Name)!" } } else { $Folder = Get-AMFolder -ID $user.ProcessFolderID -Connection $Connection } } } else { $Connection = Get-AMConnection -ConnectionAlias $obj.ConnectionAlias if (-not $PSBoundParameters.ContainsKey("Folder")) { $Folder = Get-AMFolder -ID $obj.ParentID -Connection $obj.ConnectionAlias } $user = Get-AMUser -Connection $Connection | Where-Object {$_.Name -ieq $Connection.Credential.UserName} } if (-not $PSBoundParameters.ContainsKey("Name")) { $Name = $obj.Name } switch ($Connection.Version.Major) { 10 { $copyObject = [AMProcessv10]::new($Name, $Folder, $Connection.Alias) } 11 { $copyObject = [AMProcessv11]::new($Name, $Folder, $Connection.Alias) } default { throw "Unsupported server major version: $_!" } } if ($PSBoundParameters.ContainsKey("Connection") -and $obj.ConnectionAlias -ne $Connection.Alias) { # If an object with the same ID doesn't already exist, use the same ID (when copying between servers) if ((Get-AMProcess -ID $obj.ID -Connection $Connection -ErrorAction SilentlyContinue | Measure-Object).Count -eq 0) { $copyObject.ID = $obj.ID } } $copyObject.CreatedBy = $user.ID $currentObject = Get-AMProcess -ID $obj.ID -Connection $obj.ConnectionAlias $copyObject.CommandLine = $currentObject.CommandLine $copyObject.EnvironmentVariables = $currentObject.EnvironmentVariables $copyObject.RunProcessAs = $currentObject.RunProcessAs $copyObject.WorkingDirectory = $currentObject.WorkingDirectory $copyObject.CompletionState = $currentObject.CompletionState $copyObject.Enabled = $currentObject.Enabled $copyObject.LockedBy = $currentObject.LockedBy $copyObject.Notes = $currentObject.Notes $copyObject | New-AMObject -Connection $Connection } else { Write-Error -Message "Unsupported input type '$($obj.Type)' encountered!" -TargetObject $obj } } } } |