Automation Action – Execute PowerShell | ThinkAutomation
Automation Action: Execute PowerShell
Execute PowerShell commands and assign the results to a variable.
Executes a Windows PowerShell command or script. Returns the response to a ThinkAutomation variable.
Enter the PowerShell Command or Script or specify PowerShell Script File.
In the PowerShell Command or Script you can either specify the command and it’s parameters or you can specify the command only and then provide parameter names, values & types in the Parameters Grid.
Example – Single Command With Parameters
To get the current Windows version. Set the PowerShell Command to Get-ItemProperty
and add parameters:
Parameter Name | Value | Type |
---|---|---|
Path | HKLM:SOFTWAREMicrosoftWindows NTCurrentVersion | String |
Name | ReleaseId | String |
You can use %variable% replacements for parameter values (or part of).
If you need to pass multiple values to a single parameter, you need to send through a special ThinkAutomation array type. To do this, prefix your parameter value with the word ARRAY: followed by comma-separated values.
This will return:
ReleaseId : 2009 PSPath : Microsoft.PowerShell.CoreRegistry::HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindows NTCurrentVersion PSParentPath : Microsoft.PowerShell.CoreRegistry::HKEY_LOCAL_MACHINESOFTWAREMicrosoftWindows NT PSChildName : CurrentVersion PSDrive : HKLM PSProvider : Microsoft.PowerShell.CoreRegistry
Example – Command
You can also execute a PowerShell command/script. Set the Command to:
(Get-ItemProperty -Path "HKLM:SOFTWAREMicrosoftWindows NTCurrentVersion" -Name ReleaseId).ReleaseId
You can use %variable% replacements inside the Command, eg:
(Get-ItemProperty -Path "%RegKey%" -Name ReleaseId).ReleaseId
Nothing should be specified in the Parameters grid.
The above will return 2009
.
Remember to enclose string parameters in quotes.
Wait Max (Seconds)
Specify the maximum seconds to wait for the command or script to execute. If the command or script does not complete within the specified number of seconds then an error will be raised. This setting prevents scripts that do not properly handle timeouts from halting execution of the Automation.
Assign To
Select the variable that you want the Response to be assigned to. The entire PowerShell command response will be assigned to the field/variable.
Testing
You can use the Test button to test the Command/Script. The response will be displayed and also copied to the clipboard.
External Modules
If your PowerShell command or script uses external modules/cmdlets you need to enter the module names in the Import Module Names entry. Separate multiple modules with commas. You can use the module name or path.
In order to be able to run the PowerShell script you need to set an appropriate PowerShell Execution Policy. For guidance on this from Microsoft, see: https://docs.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_execution_policies?view=powershell-6