Remoting
There are a number of use cases where you need to remotely run scripts within SPE. Here we will try to cover a few of those use cases.
Remoting Automation Service
We have provided a handy way of executing scripts via web service using the Remoting Automation Service.
Remoting Module Setup
The setup of the module only requires a few steps: 1. In the Sitecore instance install the Sitecore module package. 2. On the local desktop or server install the SPE Remoting module.
After downloading you may need to unblock the file by right-clicking the zip and unblocking.
Ensure that you have run
Set-ExecutionPolicy RemoteSigned
in order for the SPE Remoting module will run. This typically requires elevated privileges.
The remoting services use a combination of a SOAP service (ASMX) and HttpHandler (ASHX). Remoting features are disabled by default and should be configured as needed as can be seen in the security section here. The SOAP service may require additional Windows authentication using the -Credential
parameter which is common when logged into a Windows Active Directory domain.
Windows Authenticated Requests
If you have configured the web services to run under Windows Authentication mode in IIS then you'll need to use the Credential parameter for the commands.
You'll definitely know you need it when you receive an error like the following:
Example: The following connects Windows PowerShell ISE to a remote Sitecore instance using Windows credentials and executes the provided script.
Example: The following connects to several remote instances of Sitecore and returns the server name.
File and Media Service
We have provided a service for downloading all files and media items from the server. This disabled by default and can be enabled using a patch file. See the Security page for more details about the services available and how to configure.
Example: The following downloads a single file from the Package directory.
Example: The following downloads a single media item from the library.
Script Sessions and Web API Tutorial
Advanced Script Sessions
Inevitably you will need to have long running processes triggered remotely. In order to support this functionality without encountering a timeout using Invoke-RemoteScript
you can use the following list of commands.
Get-ScriptSession
- Returns details about script sessions.Receive-ScriptSession
- Returns the results of a completed script session.Remove-ScriptSession
- Removes the script session from memory.Start-ScriptSession
- Executes a new script session.Stop-ScriptSession
- Terminates an existing script session.Wait-ScriptSession
- Waits for all the script sessions to complete before continuing.
These commands are not only used for remoting, we just thought it made sense to talk about them here.
Example: The following remotely runs the id of a ScriptSession
and polls the server until completed.
Example: The following remotely runs a script and checks for any output errors. The LastErrors parameter is available for ScriptSession
objects.
Example: The following redirects messages from Write-Verbose
to the remote session. The data returned will be both System.String
and Deserialized.System.Management.Automation.VerboseRecord
so be sure to filter it out when needed. More information about the redirection 4>&1
can be read here.
Example: The following improves upon the previous example.
Troubleshooting
If you receive the following error when trying to run a script (note the namespace is Microsoft.PowerShell.Commands
instead of Spe
or similar):
then add the following line as the first line within the Invoke-RemoteScript block: Set-Location -Path "master:"
Example:
This issue occurs due to the fact that the remoting session defaults to the FileSystem
provider. Changing the location activates the custom provider included with SPE. As part of the custom provider there are additional parameters added to commands native to PowerShell.
References
Last updated