Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Since every environment is different, all code should not be run in a production environment without your team or organization thoroughly testing first. We recommend the use of a test lab environment often referred to as a development/staging instance of Sitecore.
The disclaimer is provided because someone somewhere will inevitably not follow this recommendation and if they do hose their Sitecore environment, they have no one to blame but themselves.
All data and information provided in this book are for informational purposes only. Adam Najmanowicz, Michael West, and the SPE Team make no representations as to accuracy, completeness, currentness, suitability, or validity of any information in this book and will not be liable for any errors, omissions, or delays in this information or any losses, injuries, or damages arising from its display or use. All information found in this book is provided "as is" with no express or implied warranties.
Review prerequisites and details on how to get setup with SPE.
Windows Management Framework 5.1 (PowerShell) is generally available for most Windows environments.
Working with Docker is going to be the preferred method of installation.
You can find two flavors of the images:
Ex: docker pull sitecorepowershell/sitecore-powershell-extensions:6.4-1809
Sitecore Built
Ex: docker pull scr.sitecore.com/sxp/modules/sitecore-spe-assets:6.4-1809
With this approach, you essentially add a new layer during your image build to include the files from the asset image. Here are some samples of what you can add to your existing setup. Check out Sitecore's samples for additional guidance.
docker-compose.yml
Dockerfile (mssql-init)
Dockerfile (cm)
The SPE module installs like any other for Sitecore. This approach is appropriate for installations not within a containerized environment.
For Sitecore 10.1 and newer along with Identity Server you should enable the provided configuration Spe.IdentityServer.config.
For Sitecore 10.1 and newer you can leverage the IAR packages. There is still the need for dacpac deployments because SPE includes a security user and role.
We've tried to make upgrading SPE as seamless as possible. The following should provide you with some basic information on what to expect when upgrading.
You should be able to install directly over the previous installation of 6.0+.
For Sitecore 10.1 and newer along with Identity Server you should enable the provided configuration Spe.IdentityServer.config.
For Sitecore 10.1 and newer you can leverage the IAR packages. There is still the need for dacpac deployments because SPE includes a security user and role.
These versions used a different name for the assemblies and configs. You may find it easier to delete all files originally distributed with SPE before installing a newer version. Here are a few steps to consider:
Delete all files in the bin and App_Config/Include directories prefixed with Cognifide.
Delete /sitecore modules/Shell/PowerShell
Delete /sitecore modules/PowerShell
Reference the original SPE package (if available) to identify if any other files were included.
Sitecore items in the content tree will potentially shuffle around into their new location. Be sure to backup your custom scripts first.
Take a quick look at the to see which version of SPE you should be installing that is compatible with your Sitecore environment. Generally SPE has pretty good backwards compatibility but may require a new version to support the latest Sitecore CMS release.
PowerShell set to RemoteSigned
(probably optional)
The release of SPE 6.0 introduced name changes to some files which are now reflected throughout the documentation. Review to see the full scope of what changed. Any place where the name Cognifide or Cognifide.PowerShell was used is now replaced with Spe.
the module from the GitHub releases page and install through the Installation Wizard.
An additional patch is required for 10.1 to include the location /sitecore modules/items/
. See .
An additional patch is required for 10.1 to include the location /sitecore modules/items/
. See .
Using packages with the Items as Resources (IAR) files will require additional steps to remove database records that correlate with the contents of the *.dat files. Refer to the Sitecore documentation when upgrading for the process to cleanup the databases. may be helpful if you wish to take a more precise approach.
See the troubleshooting section
The module provides a command line (CLI) and a scripting environment (ISE) for automating tasks. SPE works with the Sitecore process, capable of making native calls to the Sitecore API and manipulating files. Running commands and writing scripts follow the standard and well-known Windows PowerShell syntax. Windows PowerShell is a common tool used in IT for desktop and server management, so we decided to stick with that as a framework to build upon.
The following are some helpful modules distributed with SPE.
Core
Platform
PowerShell Background Session Manager
Recreate site from sitemap
Extensions
Maintenance
Index On Demand
Media Library Maintenance
System Maintenance
Task Management
Reporting
Samples
Automatically show quick info section
Enforce user password expiration
Example Event Handlers
Getting Started - includes the Kitchen Sink Demo for Read-Variable
.
License Expiration
Random desktop background
Training Modules
Unlock user items on logout
Tools
Authoring Instrumentation
Copy Renderings
Data Management
Bulk Data Generator - useful for items and users
Bulk Item Restorer - restore items from recycle bin
Bulk Template Changer - can't think of a better description than this
Data Importer - create or update items from a Csv
Find and Replace - use Content Search to change text
Elevated Unlock - provides options to unlock items using delegated administration
Package Generator - a simple method to package up items
Publishing Status Gutter
Security Management
Logged in Session Manager
Transfer item security
Training
Disclaimer: With great power comes great responsibility – this tool can do a lot of good but also bring harm to a lot of content in a very short time – backup your system before running a script that modifies your content and never run any untested scripts in a production environment! We will not be held responsible for any use of it. Test your scripts on your development server first! Test on an exact copy of production before running scripts on production content.
The Integrated Scripting Environment (ISE) is a great way to group together commands and save for later use. This tool helps you write scripts in Powerful Ways!
Let's have a quick walk through of each ribbon tab available.
Write:
New - Creates a new script or module.
Open - Opens an existing script for the library.
Save - Saves the current script to the library.
Save As - Saves a copy of the current script to the library.
Reload - Opens the original copy of the current script without saving any modifications.
Script Execution:
Execute - Runs the current script as a background job or in the HttpContext
.
Selection - Runs the selected text of the current script.
Debug - Runs the current script with the debugging mode enabled. A temporary file is generated on the file system to support the use of breakpoints.
Abort - Stops the execution of an executing script.
Context:
Context - Specifies the current item in the script. Helpful if you write a script dependent on a specific path, or the current directory is denoted as a .
(dot) or _$pwd
(_present working directory). An MRU and tree view are provided for choosing a path.
Session - Specifies the session to use when executing the script. Reused sessions live in the HttpSession
. Options include the session created for the ISE instance, One-Time session, or the Persistent Session ID configured on the script.
UI Context:
Language - Specifies the context language to use when executing the script.
User - Specifies the context user to impersonate when executing the script. This can be used to emulate UserSwitcher
code.
Preferences:
Settings - This is where you configure the Console and ISE font family, font size, and other useful things.
Integration:
Rebuild All - This is where you rebuild the integration points for Control Panel, Gutters, and Ribbons. Without running this you will not see those integrations appear (or disappear).
The plugins feature is a great way to add custom behaviors while in the ISE. Any plugin added can make use of the Enable or Show rules to control how it appears in the ribbon.
Platform: Custom scripts added to the ISE Plugins integration point script library will appear here.
The Open dialog provides both a search and tree view of the scripts stored in the script libraries.
Below are the shortcuts available in the ISE.
Shortcut
Usage
TAB
Indent
Ctrl-Space
Autocomplete commands. Use the up or down direction keys to cycle through options.
Ctrl-Enter
Displays the command help window.
Ctrl-Z
Undo the previous change.
Ctrl-Alt-Shift +
Increase the font size
Ctrl-Alt-Shift -
Decrease the font size
Ctrl-E
Executes the script
Alt-E
Executes the selected text in the script
Ctrl-D
Debugs the script
Ctrl-Shift-E
Aborts the running script
Ctrl-F
Search for keywords in the script
SPE includes several built-in interfaces for managing and executing scripts, as well as provides tools for modifying content.
Here we'll discuss the Console, ISE, and other dialogs made available through SPE.
Beginner's guide to working with PowerShell and SPE.
The world renowned Sitecore PowerShell Extensions module has so much to offer, but sometimes those new to the module may find it difficult to know where to start. The following book should provide you with enough information to use and be productive with SPE.
Don't worry, you will be able to use it without having to write any code.
PowerShell is built on the Microsoft .Net technology; you will find that most APIs in your libraries can be accessed from within the PowerShell runtime. In this section we will see similarities between the C# and PowerShell syntax.
Use the table below to aid in translating from C# to PowerShell. Some of the examples below are not "exact" translations, but should give you a good idea on what it would look like. For example, creating a new dynamic list in C# is often written as a fixed dimensional array recreated with every new addition.
Note: Variables in PowerShell are denoted by the $
character followed by the name. You will see this through the examples below.
Working with Dynamic and Fixed dimensional arrays.
Working with hashtables.
Working with dictionaries.
Escape double quotes in string. Alternatively you can use a single quote.
As you can see in the table above, the language syntax is not all that different between C# and PowerShell. Within a few minutes you might even be able to translate code from your library classes into SPE scripts.
You may find yourself trying to optimize your scripts. A few things that might help include the following.
Example: The following demonstrates the use of an ArrayList. Performs much better than purely using @()
.
Example: The following demonstrates the use of List<string>. This is ideal when statically typed arrays are required.
Example: The following demonstrates the use of HashSet. Use when a distinct list of items is needed. Performs like a Dictionary but without the requirement for a key.
Example: The following demonstrates the use of HashSet where the casing of the items are ignored.
Example: The following demonstrates how to replace the use of Compare-Object with HashSet. This is useful and important when the collection size is large and you are working with simple data like strings. Compare-Object does offer a way to compare specific properties.
Example: The following measures code execution time using Measure-Command
.
Example: The following measures code execution time using a Stopwatch
.
Example: The following terminates the output.
Checklist of performance tuning ideas:
Use dynamic arrays to avoid the use of +=
Suppress output with > $null
instead of Out-Null
Use hashtables as lookup tables for data
Learning PowerShell begins with running your first command. In this section we learn about the basic command syntax, and some common ones you should learn.
Example: The following provides an example syntax for a fake command.
PowerShell commands follow a Verb-Noun syntax. Notice that all properly named commands start with a verb such as Get, Set, or Remove and end with a noun such as Item, User, or Role.
The parameters follow the command and usually require arguments. In our example above we have a parameter called SomeParameter followed by an argument of type SomeType. The final parameter SomeSwitch is called a switch. The switch is like a flag that enables or disables behavior for the command.
Example: The following provides possible permutations for the fake command.
Allow scripts to be written with the full command and parameter names
Avoid relying on positional or optional parameters.
Avoid abbreviating parameter names.
Avoid using command aliases (e.g. dir, cd).
Some of the most useful commands to learn can be seen in the table below. These come with vanilla PowerShell.
Get-Item
Returns an object at the specified path.
Get-ChildItem
Returns children at the specified path. Supports recursion.
Get-Help
Returns the help documentation for the specified command or document.
Get-Command
Returns a list of commands.
ForEach-Object
Enumerates over the objects passed through the pipeline.
Where-Object
Enumerates over the objects passed through the pipeline and filters objects.
Select-Object
Returns objects from the pipeline with the specified properties and filters objects.
Sort-Object
Sorts the pipeline objects with the specified criteria; usually a property name.
Get-Member
Returns the methods and properties for the specified object.
PowerShell supports chaining of commands through a feature called "Pipelines" using the pipe "|". Similar to Sitecore in that you can short circuit the processing of objects using Where-Object. Let’s have a look at a few examples.
Example: The following queries a Sitecore item and removes it.
PowerShell also comes with a set of useful commands for filtering and sorting. Let’s see those in action.
Example: The following queries a tree of Sitecore items and returns only those that meet the criteria. The item properties are reduced and then sorted.
Example: The following demonstrates how commands can be written clearly with little confusion on the intent, then how aliases and abbreviations can get in the way. Always think about the developer that comes after you to maintain the code.
Windows PowerShell is bundled with a ton of documentation that could not possibly be included with this book; we can however show you how to access it.
Example: The following examples demonstrate ways to get help…with PowerShell.
The provider architecture in PowerShell enables a developer to make a command like Get-Item interact with the filesystem files and folders, and then interact with the Sitecore CMS items.
The SPE module implements a new provider that bridges the Windows PowerShell platform with the Sitecore API. The following table demonstrates the use of Get-Item for a variety of providers.
Alias
Alias
Get-Item -Path alias:\dir
CmsItemProvider
core, master, web
Get-Item -Path master:\
Environment
Env
Get-Item -Path env:\HOMEPATH
FileSystem
C, D, F, H
Get-Item -Path c:\Windows
Function
Function
Get-Item -Path function:\prompt
Registry
HKLM, HKCU
Get-Item -Path hklm:\SOFTWARE
Variable
Variable
Get-Item -Path variable:\PSVersionTable
The default provider used by the PowerShell Console and ISE is the CmsItemProvider with the drive set to the master database.
Example: The following demonstrates switching between providers using the function cd, an alias for Set-Location, while in the Console.
You may have noticed that the C drive is the only path in which a backslash was used before changing drives. Leaving off the backslash will result in the path changing to C:\windows\system32\inetsrv. This similar behavior can be experienced while in the Windows PowerShell Console, where the path is changed to C:\Windows\System32.
Support for Sitecore 7 has discontinued with SPE 5.0.
The following guide should provide you with enough information to setup a development environment configured to contribute to SPE. We'll begin with a single installation of Sitecore 8+.
The solution requires Visual Studio 2015 or later.
This guide assumes a source root location of "C:\Source" and a site root location of "C:\inetput\wwwroot". These are not prerequisites of the project, and you can use whatever folder locations suit you.
Install Sitecore 8+ to a folder of your choice, for example C:\inetpub\wwwroot\SitecoreSPE_8
Clone the repo to your local development environment
Copy C:\Source\Console\deploy.user.json.sample
to C:\Source\Console\deploy.user.json
. This will be a file just for your local environment and will be ignored by git.
Edit the sites definition in deploy.user.json
to target your Sitecore web root folder, making sure you use double-slashes for paths like in the existing file. For this site, make sure the version
property is 8
. Remove any other sites in the file that do not apply.
The
deploy.user.json
file supports deploying SPE to multiple Sitecore installations. For now, we are just deploying to a single instance, but later on in the tutorial we will cover multiple instances.
Copy C:\Source\Console\UserConfiguration\App_Config\Include\z.Spe.Development.User.config.sample
to a file of the same name, without the .sample
suffix. This file can be edited to add any SPE-specific configuration that you want in your sites, but don't wish to commit back into the repo.
You may notice there is a %%sourceFolder%% value in this configuration file. This is a special string that gets replaced as part of the SPE deployment with your source folder location. You don't need to update this manually.
Open the solution in Visual Studio.
Compile the solution. Whenever you compile the solution, SPE will be automatically deployed to the site web root paths you have set in deploy.user.json
Login to Sitecore
Navigate to /Unicorn.aspx
. Use Unicorn to sync all projects into Sitecore.
SPE is now installed in Sitecore and you're ready for developing!
Any changes you make going foward just require a build of the solution. Remember that when pulling down updates to the source, you should execute a Unicorn sync to ensure your items are up to date.
The SPE deployment process supports multiple sites and multiple versions of Sitecore. The following steps carry on from above to add further support for another Sitecore site, such as 8.x or 9.x.
Complete the steps for a Single Instance.
Install Sitecore 8.x/9.x to a folder of your choice, for example C:\inetpub\wwwroot\SitecoreSPE_91
Edit the sites definition in deploy.user.json
to add your new Sitecore web root folder. Set the version
property to 9.0
, 9.1
or 9.2
depending on the major/minor version.
Follow steps 7 onward from the Single Instance guide above to deploy to your Sitecore 8.x/9.x installation and sync the SPE items into Sitecore.
SPE can be deployed to as many Sitecore sites as you like. Each time you first deploy to a new installation, make sure you use Unicorn to sync the latest state of items into Sitecore.
To add the SPE PowerShell Remoting Module scripts into your machine's PowerShell Module path, execute the .\Setup_Module.ps1
script from the source folder. This will add the \Modules
folder from source into your PSModulePath
environment variable. Once this is done, you can use Import-Module SPE
on your development machine to run the remoting scripts.
As part of the SPE deployment process, all of the relevant binary, configuration and sitecore module files are copied over from the projects within the solution. This means that any changes to static files such as JS / CSS files require a full build for these to be deployed to the site. As the build triggers an application pool recycle of your site, this can be a little slow for quick changes.
To enable a junction deployment for a site, add junction
property to the site definition and set it to true
:
Note that with junction deployments, a solution build is still required if you want to deploy any code or
.config
changes.It is not currently supported for a junction deployment site to be changed back into a non-junction deployment site. If you wish to do this, you should manually delete the following folders from your Sitecore installation before updating the
junction
property back tofalse
:sitecore modules\PowerShell
andsitecore modules\Shell\PowerShell
Example: The following example queries all of the content items and adds a new language version of "en-ca", while overwriting any that exist.
Example: The following example adds a language version from English to US and Polish while leaving the Title
field blank. If a version already exists nothing happens.
Example: The following example adds a language version from English to Polish of Template Name Sample Item. If the version exists a new version is created for that language. Finally the results are displayed as a table showing only the Name
, Language
, and Version
.
Example: The following example adds a language version in Polish to the Home item and all its children. If the version exists nothing happens. No fields were harmed in the making of this version.
Example: The following example queries all of the content items and removes the language version of "fr-CA".
Example: The following example creates a new item with language versions only matching the specified languages; all other language version are removed.
Supported parameters:
-Recurse
Translates item and its children
-IfExist
Accepts one of 3 pretty self explanatory actions: Skip
, Append
or OverwriteLatest
-TargetLanguage
accepts a list of languages that should be created
-DoNotCopyFields
creates a new version but does not copy field values from original language
-IgnoredFields
list of fields that should not be copied over from original item this can contain e.g. __Security
if you don't want the new version to have the same restrictions as the original version.
On top of the ignored fields in the -IgnoredFields
the following fields are ignored as configured within the Spe.config
file:
In this section we'll show how to manage item renderings.
Example: The following demonstrates the use of Get-LayoutDevice
and Get-Rendering
to find all renderings on a page associated with the FinalLayout.
Example: The following demonstrates the use of Get-Rendering
and Set-Rendering
for updating values on templates.
Example: The following demonstrates how to report on pages referencing the specified rendering.
Example: The following demonstrates how to report on which renderings are globally set to "Cacheable".
Example: The following demonstrates how to find renderings with a conditions node set on the item.
Example: The following demonstrates how to disable global caching on all renderings.
Example: The following removes a datasource from a rendering on the FinalLayout.
There are multiple methods of accessing help documentation in SPE to provide you with information on the commands available to you.
A report is available which will show you all available SPE commands:
When executed, this report provides a paged view of the SPE commands.
To display the available help for a command in the Console, simply use the Get-Help command:
For full documentation, including examples, use the -Full
parameter:
Through the Integrated Scripting Environment (ISE), SPE provides a method of acccessing help for available commands. To view the help for a command, simply highlight the command and press Ctrl + Enter.
After doing this, a dialog will appear with the relevant help information:
When writing scripts, you are able to include formatted comments that will be used to provide help text for functions. If formatted correctly, this help text will be available through the methods described above.
Example: A simple function with documentation:
Once the script containing this function has been invoked, the help text will be available:
The (SPE) module is a Sitecore development accelerator that can drastically increase your productivity and curtail the amount of time it takes to deliver a Sitecore solution.
The book provides documentation about how to use the module based on the latest released version. While some of the screenshots and materials may be slightly out-of-date, you will inevitably find details referring to something that doesn't exist on your installed version. Feel free to submit a pull request for corrections .
Support for Sitecore 7 has discontinued with SPE 5.0. Check the for version compatibility.
|
|
X-UnitTests - examples at how to use to test your scripts
- reports based on the Sitecore Rules Engine.
- similar to the Luke tool
- variety of reports to help audit the Sitecore solution.
There is nothing you can not do with PowerShell Console, because you're inside the Sitecore application. You can call the Sitecore API. - - Sitecore Symposium 2012
Recommended by to use as a tool for .
Get a job done with a one liner! Just provisioned a new language for the whole content tree with a one-liner. Whaaaat? Have to include it as a default install for all sandboxes now. - 's comment on Marketplace
Thank you for the GitBook. Invaluable Reference. - 's
The Sitecore powershell tools are absurdly good and helpful. I know they make a lot of people nervous, but they are incredibly well managed. Everybody should learn to sling some shell in Sitecore, you'll never look back. -
I literally couldn't work without SPE - I can't remember the last implementation I did that didn't have it installed lol @michaellwest & @adamnaj better not ever retire it -
See the section for some common fixes.
Questions, comments, and feature requests should be submitted on . You may also check out the for more interactive support. Not on Slack yet? Contact us on Twitter and we'll send you an invite.
The default security configuration for SPE requires the ISE to be in an before executing scripts. The following figure shows the ISE when the User Account Controls (UAC) are disabled. While this is a common configuration for developers, we highly encourage you to ensure UAC is enabled in higher environments.
For more commands built into the script editor see
We have a video series available to help walk you through the module .
We also maintain a comprehensive list of links to to help you on your journey to SPE awesomeness. Happy coding!
Example: The following demonstrates the use of Queue. A Sitecore Stack Exchange answer to may be helpful.
The verbs are considered “approved” if they align with those that Microsoft recommends. See the following URL for a list of approved verbs and a brief explanation on why they were chosen. They are intended to be pretty generic so they apply for multiple contexts like the filesystem, registry, and even Sitecore!
Meet the prerequisites found
SPE uses Unicorn for serializing Sitecore items to the source folder, and for syncing items from disk into Sitecore. For more information on Unicorn, see
For more rapid development, you can enable junction deployment on your sites. When this is enabled, rather than copying over the static files, will be setup for various folders so that the folders within the Sitecore installation are directly linked to the source folder. Any changes made in the solution are seen instantly, because the solution and the site are referencing the exact same files.
The section on provided a variety of examples in retrieving items based on their language. In this section will show how to manage items and their languages.
The default security configuration for SPE requires the Console to be in an before allowing the execution of commands. The following figure shows the Console when the User Account Controls (UAC) are disabled. While this is a common configuration for developers, we highly encourage you to ensure UAC is enabled in higher environments.
Example: The following moves renderings from one placeholder to another. .
For further information on comment-based help, refer to the .
Online help is additionaly available for all SPE commands in this documentation, with detailed explanations of commands and their parameters, along with useful examples. These can be found in the .
Shortcut
Usage
Enter
Submits line for execution.
Tab
Autocomplete commands. Press tab again to cycle through commands.
Shift+Tab
Reverse cycle through Autocomplete commands.
Shift+Enter
Inserts new line. Works when the backtick is used.
ArrowUp/Ctrl+P
Show previous command from history
ArrowDown/Ctrl+N
Show next command from history
Delete/backspace
Remove one character from right/left to the cursor
ArrowLeft/Ctrl+B
Move cursor to the left
ArrowRight/Ctrl+F
Move cursor to the right
Ctrl+ArrowLeft
Move cursor to previous word
Ctrl+ArrowRight
Move cursor to next word
Ctrl+A/Home
Move cursor to the beginning of the line
Ctrl+E/End
Move cursor to the end of the line
Ctrl+K/Alt+D
Remove the text after the cursor
Ctrl+H
Remove character before the cursor
Ctrl+D/Delete
Remove character selected by the cursor
Ctrl+C/Escape
Remove all text in the line
Ctrl+U
Remove the text before the cursor
Ctrl+V/Shift+Insert
Insert text from the clipboard
Ctrl+Alt+Shift +
Increase the font size
Ctrl+Alt+Shift -
Decrease the font size
PageUp
Scroll console up
PageDown
Scroll console down
Ctrl+R
Reverse search history
Modules may contain PowerShell Script Library items and PowerShell Script items. The following section outlines some of the basic concepts you need to know for the following chapters.
The library items represent a collection of scripts, and may be structured with one or more levels of libraries.
You'll find that with the Integration Points some libraries should be created with specific names (i.e. Content Editor, Control Panel).
As a best practice we recommend that the Functions library consist of reusable scripts containing PowerShell functions (i.e. Do-Something
) while other libraries contain the solution specific scripts (i.e. MakeScriptingGreatAgain
).
Example: The following demonstrates the use of the Functions script library containing Get-DateMessage.
Some names we've used included:
Beginner Tutorials
Content Editor
Content Maintenance
Content Interrogation
Development
Event Handlers
Functions
Internal
Page Editor
Pipelines
Profile and Security
Reports
Script Testing
Tasks
Toolbox
User Interaction
Web API
Interactive : The following fields support the two custom rules as well as a variety of out-of-the-box rules.
ShowRule (Show if rules are met or not defined) - typically controls visibility of integration points.
PowerShell
where specific persistent PowerShell session was already initiated
where specific persistent PowerShell session was already initiated and has the specific variable defined and not null
where exposed in a specific view
PowerShell ISE
when length script length is compares to number characters long
when the edited script is in a state
EnableRule (Enable if rules are met or not defined) - typically controls enabled state of integration points.
Same as above
There are a number of use cases for the EnableRule and ShowRule.
If there is a UI component the ShowRule can be used to ensure it appears while the EnableRule can toggle when it can be clicked.
If there is no UI component, the EnableRule is used to determine when the script should be executed; useful to limit creation of PowerShell runspaces.
ISE Plugin
ISE Plugin
Reports List View Action
Reports List View Action
Reports List View Export
Reports List View Export
The script items represent the code that will be executed.
There are three conventions that we recommend you follow which are shown with an example below.
Title Casing - This should be used when the name will be exposed in places such as the Content Editor, script library names, and Reports root directory.
Sentence casing - This should be used when the name is long and will not be visible to the user or is a report with a very long name.
Noun-Verb - This should be used when the script is stored within the Functions script library and will be imported using the command Import-Function.
Scripting
Script (Script body) : This is a multi-line text than should be edited using the PowerShell ISE application.
Session Persistency
PersistentSessionId (Persistent Session ID) : Context scripts using this ID will execute in a single session and be reused; leaving empty will cause the session to be discarded after execution. This value should be used for rules requesting the session ID.
You can interact with the providers typically available in the standard Windows PowerShell Console. Below are some of the important providers. Run the command Get-PSProvider
to see the complete list.
FileSystem - Supports interacting with files and folders.
CmsItemProvider - Supports interacting with the Sitecore content items.
The console prompt typically begins with PS master:\>
. The present working directory is using the CmsItemProvider and set to the master database.
Example: Change directories between providers.
The SPE Modules support a wide variety of predefined script libraries to help with exposing scripts to the Sitecore interface.
The following list outlines the available libraries for Integration Points that may be added to modules. These may also be generated automatically when creating or updating modules.
Context Menu - Visibility can be control using rules made available from within the Interactive field section.
Insert Item - Visibility can be control using rules made available from within the Interactive field section.
Warning - Appears as a warning message beneath the ribbon in the Content Editor.
Internal
List View - Represents the ribbon buttons such as for Actions and Exports.
Notification - Appears as a notification message beneath the ribbon in the Experience Editor.
LoggedIn
LoggingIn
Logout
The majority of scripts written with SPE contain one or more of the following commands:
Use this to retrieve a single item. Throws an error if the item does not exist.
Use when Sitecore query:
or fast:
is required. May return more than 1 item.
Use to return an item's children and grandchildren.
Use to create an item based on a specified data template.
Use to delete or recycle an item.
Accepts items returned by Get-Item
and Get-ChildItem
.
Use to transfer an item from one location to another.
Use to duplicate an item from one location to another.
Parameter Name
Description
Copy-Item
Get-Item
Get-ChildItem
Move-Item
New-Item
Remove-Item
AmbiguousPaths
More than one item matches the criteria so show them all.
–
✓
-
–
–
–
Database
The specified database will be used. Requires the ID to be set.
–
✓
–
–
–
–
DestinationItem
Parent item to receive the copied item.
✓
–
–
✓
–
–
FailSilently
Unauthorized access errors will be suppressed
✓
–
–
✓
–
✓
ForceId
Forces the new item to use a specified GUID
–
–
–
–
✓
–
ID
Matches the item by ID.
–
✓
✓
–
–
–
Item
Instance item.
✓
–
✓
✓
–
✓
Language
Specifies the languages to include.
–
✓
✓
–
✓
–
Parent
Specifies the parent item.
–
–
–
–
✓
–
Permanently
Specifies the item should be deleted rather than recycled.
–
–
–
–
–
✓
Query
Matches the items by an XPath query.
–
✓
–
–
–
–
StartWorkflow
Initiates the default workflow, if any.
–
–
–
–
✓
–
TransferOptions
Options flag used when copying from one database to another.
✓
–
–
✓
–
–
Uri
Matches the item by ItemUri.
–
✓
–
–
–
–
Version
Specifies the version to include.
–
✓
✓
–
–
–
WithParent
Specifies the command should include the parent item.
–
-
✓
–
–
–
Legend: "–" - not applicable; "✓" - available.
Below we will show how to use each command with the Windows PowerShell syntax followed by some examples of the common C# equivalent.
Example: The following will retrieve the item based on the Sitecore path.
As you may have noticed, the /sitecore
portion of the path is unnecessary. This is because the Sitecore item is represented by the root item of the drive master:
and is therefore optional.
Let's have a look at the equivalent code in C#.
The above will return the latest version of the item in your current language. But what if you want the item in another language? No problem!
Example: The following will retrieve the Danish version of the Home item.
I've formatted the output above to show you that indeed the right language was returned. The command supports wildcards for both -Language
and -Version
parameters. You may have also noticed that the forward and backward slashes can be used interchangeably.
Example: The following retrieves the latest version for all languages of an item.
Notice that the item with language en-US
at its third version.
Example: The following retrieves the item in all languages and versions.
You can see that specifying the language and version using the wildcard will retrieve all possible variants of an item. The wildcard can also include a partial match like en-*
. The use of that filter would return all items in the English language, ignoring the region.
Example: The following retrieves the child items in all languages and versions.
It's not always most efficient to operate on items by traversing the tree using Get-ChildItem
. This is especially true if you need to work on large trees but need to select only a few items (e.g. a specific template). For this we’ve introduced support for the Sitecore query within our provider.
Important to note that the query format sometimes requires the use of a
#
before and after paths when they contain reserved keywords or spaces.
Example: The following retrieves all items beneath the path /sitecore/content/ with the template of Sample Item.
Example: The following retrieves all items beneath the path /sitecore/content/ with the template of Sample Item in all versions and languages.
Example: The following retrieves items matching the query with a specified ISO date and present in a report dialog.
Example: The following returns items with a specific template under a given root using Fast query.
Example: The following retrieves items matching an XPath query.
Example: The following retrieves an item by id.
The Uri encodes the language and version within the path.
Example: The following retrieves an item by uri.
In all the examples you'll notice we specified the database. Windows PowerShell needs to know which provider to execute within. This also signals to SPE to show the dynamic parameters. Other examples of providers include the following:
HKLM: - The registry provider for HKEY_LOCAL_MACHINE.
C: - The filesystem provider for the C drive.
The following examples make use of custom PropertySet for the command Select-Object
.
Example: The following uses the PSSecurity PropertySet.
Example: The following uses the PSTemplate PropertySet.
Example: The following uses the PSImage PropertySet.
Example: The following uses the PSSchedule PropertySet.
Example: The following accesses the Image field casted to the type Sitecore.Data.Fields.ImageField
.
Note: You can use ._
and .PSFields
to gain access to the typed field.
Example: The following accesses the Link field casted to the type Sitecore.Data.Fields.LinkField
. From there you can see all of the available properties.
Example: The following finds all of the TextField
s and outputs to the console.
We often see the following two ways of accessing and changing fields used in scripts. One uses Set-ItemProperty
and the other is more natural to a Sitecore developer.
Example: The following sets the title property using Set-ItemProperty
.
Example: The following sets the title and clears the branch id using .Editing.BeginEdit
and .Editing.EndEdit
methods.
Note: The above example may also be written in the ISE where no console prompt is visible.
The previous examples work but are not the most efficient ways to change item content. The items returned by the provider expose the Sitecore item fields as automatic PowerShell properties.
Example: The following sets the title property using the automated PowerShell property.
Example: The following changes the display name of the item.
This technique may be used for a wide variety of property types.
Example:
There are a other hidden gems in automated PowerShell properties. For example, if we detect that the field is a Date or Datetime field, we will return System.DateTime
typed value from a field rather than the System.String
Sitecore stores internally.
Example: The following gets the created date.
Example: The following assigns a System.DateTime
value to the PowerShell automated property.
Great we've just changed it! Our property handlers take care of all the necessary usages of .Editing.BeginEdit
and .Editing.EndEdit
. This method can be applied for a variety of field types such as GeneralLink and Image.
To provide an example – I’ve extended my home with additional fields as follows:
Example: The following assigns an image to the Image field.
Easy enough, isn't it? Let SPE detect the field type for you and worry about what to call! Now let's assign a content item to GeneralLink.
Example: The following assigns a content item to a GeneralLink field.
What about fields that accept lists of items? We've got your back here as well.
Example: The following assigns all children of /sitecore/content/
item to the ItemList field.
Let's see how our item looks in the Content editor after all the assignments that we've just performed:
Great! Looks like it worked.
Those little improvements make your scripts much more succinct and understandable. Try it for yourself!
As with every rule there is an exception to this one. Those automated properties perform the $item.Editing.BeginEdit()
and $item.Editing.EndEdit()
every time which results in saving the item after every assignment. Assigning multiple properties on an item this way might be detrimental to the performance of your script. In such cases you might want to call $item.Editing.BeginEdit()
yourself before modifying the item. Subsequently call the $item["field name"] = "new value"
for each property modify. Finally end with the $item.Editing.EndEdit()
.
Choosing this way is situational and will usually only be required if you're working with a large volume of data. In those cases you might also want to introduce the Sitecore.Data.BulkUpdateContext
technique.
Example: The following sets multiple properties while using the Sitecore.Data.BulkUpdateContext
.
Example: The following generates a relative url to the specified site and assigns to a variable. Because the New-UsingBlock
command creates a new closure, you need to return the data to use in a different scope.
Some other classes you may want to use with the New-UsingBlock
function:
Sitecore.SecurityModel.SecurityDisabler
Sitecore.Data.BulkUpdateContext
Sitecore.Globalization.LanguageSwitcher
Sitecore.Sites.SiteContextSwitcher
Sitecore.Data.DatabaseSwitcher
Sitecore.Security.Accounts.UserSwitcher
Sitecore.Data.Items.EditContext
Sitecore.Data.Proxies.ProxyDisabler
Sitecore.Data.DatabaseCacheDisabler
Sitecore.Data.Events.EventDisabler
If you have reached this point, then you are clearly a nerd and want to access using the raw Sitecore API.
Example: The following queries all descendants of the media library, filters by size, and wraps with automatic properties.
You will find yourself one day in need of copying items on a small to large scale. The Copy-Item
command will likely meet the need.
Example: The following copies the item to the specified path with a new ID.
Note: The item name will match just as you type it in the command. Lowercase name in the destination will result in an item with a lowercase name.
Example: The following transfers the item to the specified path with the same ID.
Example: The following copies an entire tree of items and maintains the tree structure.
There is a always a better way to do something. Moving items en masse is certainly one that you don't want to do by hand. If the destination item exists the moved item will be added as a child. If the destination item does not exist the source item will be renamed when moved.
Example: The following moves the item from one parent to another.
Example: The following gets an item and moves to a new parent node, along with all the children.
Example: The following creates a new item with the specified template.
Example: The following creates a new item with the specified template id and id.
Example: The following creates a new item as a child of the specified item.
Note: The New-Item
command was passed to Format-Table -Autosize
to improve the formatting.
Example: The following removes the item permanently. Proceed with caution.
Sitecore PowerShell Extensions provides an organization structure composed of modules, libraries, and scripts. Modules make up the highest level and can be grouped together by module folders.
Some benefits to using modules:
Organization of custom scripts is a cinch.
The Platform module is one you should avoid changing.
Getting started with your own module is a short process and something you should do for all of your custom scripts.
Navigate to the Script Library item and Insert -> PowerShell Script Module.
Enter the name for the new module and click OK.
Right click the new module and Scripts -> Create libraries for integration points.
Select the appropriate integration points for your module.
Select the module and enable for use.
Open the ISE, switch to the Settings tab, and rebuild integrations.
The Functions integration allows for scripts to be discoverable through autocomplete while authoring scripts. Functions can be "disabled" by disabling the containing module.
Begin by adding a script library called "Functions" to a module. This can be created by the new module wizard.
Add a script to the "Functions" script library with a name that represents the purpose.
Use the command Import-Function
to discover the available functions.
Note: It's best practice to create function scripts that follow the Verb-Noun
pattern as outlined by Microsoft.
Here's a short video on authoring custom functions.
The Notification integration reveals to the user a notification above the content. The Sitecore rules engine may be used to control the enabled state; simply configure the Enable rule on the script. The script is executed every time the page loads.
Example: The following adds an information notification to the page for Sitecore 8 and a warning for Sitecore 7.
Note: Examples included in the following modules
License Expiration
The Experience Button integration adds a button to the Page Editor. Rules can be used to control visiblity and enablement. The script is only executed when the button is clicked.
Begin by adding a new script to the Experience Button library. The name of the script will appear in the tooltip.
Edit the script to perform the appropriate actions. The script can run in the background and show dialogs.
Change the icon of the item to match the script purpose.
Configure any Enable or Show rules as needed.
Example: The following adds a command which will display a dialog asking a question, then send an email with the response.
The Event Handler integration provides a way to execute scripts when defined events are fired.
Steps required to activate this integration include the following:
Enable the Spe.Events.config or apply your own patch with the required events enabled.
Add a new integration point library to your new or existing module.
Add a new script to the appropriate event library.
Configure an Enable Rule if needed.
Profit!
While SPE comes with an example configuration, which is disabled by default, it contains several events that may not meet your requirements.
An event configuration patch may look like the following:
To mimic the event item:added you should create nested script libraries such as Event Handlers -> Item -> Added followed by a script.
Custom ribbon commands for use in the ISE.
You can include custom ribbon commands in the ISE to aid in improving the script authoring experience.
For this example, we wish to have a plugin that analyzes the script and reports on any errors.
Create a new script stored under the following structure:
Use the following sample to fill in the script body.
Now you can run the command from the ribbon and see the results in the ISE.
Scripted Data Sources provide a way to use a PowerShell script to perform complex queries.
Here are some good reasons to use this feature:
Delivering complex functionality based on multiple criteria.
Your field may need to provide different set of items to choose from based on:
user name or role (in simplest case this can be done using right management, but maybe not always possible in a more elaborate scenario)
current day or month?
In a multisite/multimarket scenario you may want to show different items for each site
based on engagement analytics parameters of the page
based on where in the tree an item exist (some of it can be done with use of a “query:”)
anything you might want to build the code data source for…
Something that would be beyond the reach of a regular Sitecore query and potentially something that you would really need to deliver code source for. But maybe you’re not in a position to deploy that on your environment?
Field Data Source provides a great opportunity for a script.
Below are field types you may wish to use a script:
Checklist
Droplist
Grouped Droplink
Grouped Droplist
Multilist
Name Lookup Value List
Droplink
Begin by adding a new script library called Data Sources followed by adding a script. You can call it something like Get-GlobalOption.
Add the path to your script in the Source field on the data template. The source should be prefixed with script:
followed by the path.
Enjoy the results.
//TODO
//TODO
Use the following in your scripts to get access to the arguments passed to the processor.
Configure any Enable rules to ensure your script only runs when necessary.
Note: Examples included in the following modules
Enforce user password expiration
Note: Examples included in the following modules
Automatically show quick info section
Note: Examples included in the following modules
Unlock user items on logout
Content Editor
Content Editor
Content Editor
Content Editor
Content Editor
Content Editor
Content Editor
Page Editor
Page Editor
Interactive : Refer to the description shown for PowerShell Script Library .
Note: Include the backslash in the path (i.e. **C:**) to get the root of the drive when interacting with the FileSystem provider; the behavior seen is different than you might expeect because of w3wp.exe. See issue #.
Gutters - Requires the library to be .
Ribbon - Requires the library to be . Visibility can be control using rules made available from within the Interactive field section.
- Requires the library to be .
- Not a formal integration point library, but a good place to add scripts used for Data Source Scripts. Read more about how they work and . The Source field simply references the script like script:/sitecore/system/Modules/PowerShell/Script Library/[MODULE NAME]/Data Sources/[SCRIPT NAME].
- Requires a patch file to enable the desired events. Read more about it .
- Exposes scripts to the command Import-Function.
- Appears as a button in the ISE Settings tab.
(Experience Editor)
- Appears as a shortcut under Sitecore -> Reporting Tools -> PowerShell Reports.
- Appears as a shortcut under Sitecore -> Toolbox. Visibility can be control using rules made available from within the Interactive field section.
- Not a formal integration point library, but a good place to add scripts used for Scheduled Tasks. SPE includes a PowerShellScriptCommand
found under /sitecore/system/Tasks/Commands/PowerShellScriptCommand which is used to run scripts from within scheduled tasks.
- Exposes scripts than can be consumed through . The script can be executed by requesting a specific url.
- Not a formal integration point library, but a good place to add scripts used for Workflow Action Scripts. Read more about how they work .
Remoting - Interact with SPE through the provided web services as described . A Windows PowerShell module is made available to encapsulate the web service calls into PowerShell commands.
Some integrations need to be synced with the Core database through the ISE. See the section of the Scripting documents for instructions.
The following commands provide you with the core methods needed to manage your content. Due to the nature of Windows PowerShell, commands such as these are extended with custom parameters and switches using . These parameters are then added to the command at the time of use and only appear when the conditions are right. We've provided this table to help you discover the hidden gems within each command.
If you have retrieved your items directly using the Sitecore API you can still add the nice wrapper. You can do that by piping them through the Initialize-Item
command. We'll show an of this later.
Check out some performance details when using different methods of querying items on the .
Workaround found .
The setup is not exactly like you would find in the XPath Builder but should get the job done. Read more about it .
The contained within each module can be enabled or disabled globally. For this to take full affect the integration should be rebuilt in the ISE.
More reasons can be found in Adam's .
PowerShell Scripted Data Sources and
Sitecore Spark on using scripted datasources
Ever wanted to package up items and files without opening the Sitecore Package Designer each time? There are a number of commands available for generating packages.
Example: The following example demonstrates how to generate a package.
Example: The following adds a Post Step and custom attributes.
Example: The following adds a Post Step included with SPE to delete a file. The SPE Post Step code reads xml data stored in the comment section of the package.
Example: The following adds a Post Step Script included with SPE to change icons. The SPE Post Step code executes a script included with the package as stored in the attributes section.
The reports which come out of the box provide a wide variety of information regarding your Sitecore installation.
The custom reports can be found by navigating to Sitecore -> Reporting Tools -> PowerShell Reports.
As an example, let's run the Unused media items report.
Once the report completes, the results appear in a report window.
While SPE contains many reports, they don't match identical to ASR reports. We've done our best to build those that seem most relevant or likely to be used. If you find a report in ASR that you would like to exist in SPE please submit a request.
SPE Report
ASR Report
Active Aliases
Aliases
Audit
Broken Links2
Broken Links
Broken Links in publishable items
Item History
Items with Invalid Names
Items with security for an account2
Items with Security for an account
Items with Tokens in Fields
Links
Locked Items2
Locked Items
Logged errors
Logged in Session Manager5
Logged in Users
Limit number of versions4
Multiple versions
My Owned Items
Media items last updated before date3
Not recently modified
Media items not used by content items3
Orphaned media assets report
Owned items
Recent workflow history2
Recent Workflow History
Media items last updated after date3
Recently Modified
Regex Item Searcher
Renderings
Index Viewer5
-
Rules based report5
-
Task Manager report5
-
Check the reports in SPE under these sections to see the full list.
1 Configuration Audit report
2 Content Audit report
3 Media Audit report
4 Solution Audit report
5 Toolbox
Note: Examples included are in the following modules
Content Reports
You may wish to expose the reports to users such as Content Authors. Here are the steps required to grant access to users in the sitecore\Sitecore Client Authoring
role.
Here is what users may see in the event they do not have the appropriate access.
Navigate to the item /sitecore/content/Documents and settings/All users/Start menu/Right/Reporting Tools/PowerShell Reports
Grant access to sitecore\Sitecore Client Authoring
Verify the reports are now visible to the Authoring users.
Note: In verson 6.4 the default access changed from sitecore\Sitecore Client Maintaining
to a lower privileged account sitecore\Sitecore Client Authoring
.
The PowerShell Toolbox is quick way to access frequently used scripts.
Navigate to Sitecore -> PowerShell Toolbox and after selecting you should see the configured scripts:
Note: Examples included in the following modules
Authorable Reports
Logged in Session Manager
Package Generator
Task Management
Platform
View the list of user sessions and "kick" them out as needed.
Generate a report using the Sitecore Rules Engine.
View the list of SPE sessions and "kill" them as needed.
Simple tool for generating a site tree using an existing sitemap.
View and manage the configured scheduled tasks.
To create your own Toolbox item take the following steps: 1. Create the Toolbox folder under an SPE module. Use the context menu to simplify the process.
Right click the module name and choose Scripts -> Create libraries for integration points.
Select the Toolbox item and click Proceed.
Create a PowerShell Script under the Toolbox item.
Right click the Toolbox library and choose PowerShell Script.
Open and edit the PowerShell Script using the ISE.
Run the Rebuild All command in the ISE by navigating to the Settings tab and selecting the icon to rebuild. Be certain to enable the module before running the rebuild command.
Verify the new toolbox item appears in the Toolbox.
The Web API integration point exposes scripts through a url. This can be especially helpful when a script needs to be executed on the server but without knowledge of the script contents.
Here's the url broken down:
API Version - Specifies which service is being requested.
v2
- This is the service that executes scripts stored in the integration point library.
Database - Specifies which database contains the script.
master
- This database requires the credentials to be provided.
Script - Specifies the name of the script contained in the database. The SPE module containing the script needs to be enabled otherwise you'll receive a 404 error.
homeanddescendants
- Replace this name with whatever your script is called in the Web API library.
Query String Parameters (deprecated) - Specifies the additional bits of data for use by the web service.
user
and password
- Authenticates the request and in most cases will be needed. If the script is published to the web database the credentials are not required. You should use the Basic header instead of the query string.
All of the query string parameters added to the variable scriptArguments
. Use this PowerShell hashtable inside of your scripts. Check out the function Invoke-ApiScript
for an example of how these parameters can be put to good use.
Headers:
Use the Basic header to provide authentication information. Here is an example of how to build that for a script.
Note: Examples included in the following modules
Getting Started
The Workflows integration allows for scripts to run like workflow commands. Rules can be used to control visiblity and enablement. The script is only executed when the command is triggered.
Begin by adding a new item to a workflow command of template type /Modules/PowerShell Console/PowerShell Script Workflow Action
. We've added an insert option to help with this.
Edit the Type string field to your custom type or to the built in type Spe.Integrations.Workflows.ScriptAction, Spe
.
Edit the Script body with the appropriate script. I like to save my workflow scripts in a library called Workflows.
Configure the Enable rules on the workflow action item to specify when to execute. Leave the rule alone if you wish for it to execute any time the command is activated.
Edit the script in your Workflows library to perform the appropriate actions. The script can run in the background and show dialogs.
Change the icon of the workflow action item to match the script purpose.
Celebrate your success with the team!
Example: The following requests input from the user then writes to the workflow history.
Managing users and roles is a big topic and this section won't cover everything. We aim to show you different problems that have come up and how we solved them.
Example: The following command returns the security commands available.
Managing users should be a pretty straight forward task. While the User Manager provided by Sitecore is handy, you'll likely find yourself wanting to make bulk changes. The following examples should give you a few ideas about how to manage user accounts.
Example: The following generates a batch of test users in the default domain with the out-of-the-box user profile template. The users are then queried filtering on the name.
In case you forgot to set the user profile for accounts, we have a solution for that.
Example: The following queries a user and sets the profile template. Note that changing the profile template requires the user to be authenticated.
Example: The follow queries all the user accounts for the default provider and filters those over the age of 18. The age property is custom on the Profile. Finally, export to CSV.
Using Set-User
to update AD accounts may result in an "Access denied message"; this is due to the fact that the account querying user does not have write access to profile properties or the profile provider is not configured properly.
Example: The following queries roles using the specified identity.
The ACL commands provide an automated way of granting privileges to items.
Example: The following creates a new ACL and assigns to an item.
The following links provide a way to report issues and get the latest release.
View important details on how to keep Sitecore secure while using SPE.
You need to be mindful that Sitecore PowerShell Extensions is a very sharp tool and while it can be leveraged to do great things, it can also be a vector of dangerous attacks if not secured properly. This is why we recommend that you do not install it on Content Delivery instances and if possible avoid deploying it on servers that face Internet altogether.
Installing SPE in internet facing (DMZ) scenarios is not recommend. Please avoid installing in the Content Delivery instances. Implement a strategy which provides the least amount of access required. Consider locking down the web server to only allow connections to your databases and preapproved web services.
There are two main security policies to consider when using the SPE module:
Application Pool service account
Sitecore user account
The first policy relates to the Application Pool service account running in IIS. The Windows PowerShell runspace will have access to the local system via providers (i.e. FileSystem, Registry), and be managed through the Console or ISE. If the service account is capable of removing files from the root directory, then SPE can accomplish the same.
When using the IIS identities such as ApplicationPoolIdentity and NetworkService the scripts may have access to directories outside of the application such as the drive root; you should perform a due dilligence to make sure this is the case! You may also notice that the $HOME variable is empty; this is because only named service accounts have profiles.
The application pool service account can give SPE access to many features in the OS.
The second policy relates to the Sitecore user account. The code executed through SPE operates within the privileges of the logged in user. Keep in mind that this can be bypassed just as can be done through the Sitecore API as PowerShell scripts can call the APIs that disable the Sitecore security.
Application Security
The following settings are configured under core:\content\Applications\PowerShell
.
Feature
Visibility
PowerShell Console
sitecore\Developer (read)
PowerShell ISE
sitecore\Developer (read)
PowerShell ListView
sitecore\Sitecore Client Users (read)
PowerShell Runner
sitecore\Sitecore Client Users (read)
PowerShell Reports
Note: The security is validated in each SPE application within the function OnLoad
.
Menu Item Security
The following settings are configured under core:\content\Applications\Content Editor\Context Menues\Default\
.
Feature
Visibility
Command State
Edit with ISE
sitecore\Developer (read)
Enabled when item template is PowerShell Script otherwise Hidden
Console
sitecore\Developer (read)
Enabled when user is admin or in the role sitecore\Sitecore Client Developing otherwise Hidden
Scripts
sitecore\Sitecore Limited Content Editor (deny read)
Enabled when the service and user are authorized to execute otherwise Hidden
Note: See the Interactive section on PowerShell Script Library and PowerShell Script items for visibility and enabled rules. To hide each feature you can change the security settings for the roles that should not see the menu.
The following section outlines steps you can take to minimize the surface area for attack. The following topics describe how to manage security for interfaces and services for the various parts of the module.
Let's have a look at the configurable features which make up the UAC.
Gate
name
built-in name for the gate
token
name of the token to use for the elevated session
Token
The object which expires after a predetermined time. These can be unique to each gate or shared.
name
unique string used for the gate token attribute
expiration
timespan used to determine the elevated session lifetime (hh:mm:ss)
elevationAction
action to perform when session elevation is triggered (allow, block, password)
Actions supported out of the box:
Allow - Always allow the session to run elevated without prompting the user for permission. This should never be used outside of a developer's machine.
Block - Always block the session from running elevated without prompting the user for permission.
Password - Prompt the user for a password before running the session elevated, unless an unexpired session is active.
Confirm - Prompt the user for a confirmation before running the session elevated.
Example: The following extends the token expiration to 10 minutes and blocks the use of the Console.
Gates with Password protection enabled prompt the user when no elevated session is available. When using Azure AD and or similar provider you should use the Confirm action.
Content Editor
A Content Editor Warning is displayed when a PowerShell Module, Script Library, and Script is selected. Click "Elevate session" to show the hidden fields and enable the management of the item.
The "Drop session" option appears after credentials are verified. All scripts can be edited while the session is elevated.
ISE
A warning is presented in the ISE when no elevated session state is available.
The following warning is rendered in the ISE while the session state is elevated. Click "Drop elevated session state" if you do not want to wait for the elevated session to timeout.
The web services providing external access to Sitecore are disabled by default. You can override this behavior by patching the following configuration file \App_Config\Include\Spe.config
.
Look for the following section and enable as needed.
Remoting - Used when passing scripts to SPE for execution. Enable when using the SPE Remoting module. Service associated with RemoteAutomation.asmx
.
RESTful v2 - Used when the url contains all the information needed to execute a script saved in the SPE library. Service associated with RemoteScriptCall.ashx
.
File Download - Used when the url contains all the information needed to download a file from the server. Enable when using the SPE Remoting module. Service associated with RemoteScriptCall.ashx
.
File Upload - Used when the url contains all the information needed to upload a file to the server. Enable when using the SPE Remoting module. Service associated with RemoteScriptCall.ashx
.
Media Download - Used when the url contains all the information needed to download a media item from the server. Enable when using the SPE Remoting module. Service associated with RemoteScriptCall.ashx
.
Media Upload - Used when the url contains all the information needed to upload a media item to the server. Enable when using the SPE Remoting module. Service associated with RemoteScriptCall.ashx
.
Handle Download - Used when a file is downloaded through the Sitecore interface. Enable when using the SPE Remoting module. Service associated with RemoteScriptCall.ashx
.
Client - Used for the SPE Console. Service associated with PowerShellWebService.asmx
.
Execution - Used when SPE checks if the user has access to run the application.
RESTful v1 - Used in early version of SPE. Avoid using this if possible. Service associated with RemoteScriptCall.ashx
.
The preferred way to override the settings is through the use of a configuration patch file.
Example: The following enables the file and media downloads.
Example: The following enables the SPE Remoting service and requires a secure connection using HTTPS.
Note: When using the attribute requireSecureConnection
, you may find that this causes a 403 status code when testing against a server hosted behind a load balancer. If the load balancer maintains the TLS certificate and forwards traffic to a backend web server over port 80 .Net will not recognize this as a secure connection.
You are required to explicitly grant the SPE Remoting session user account to a predefined role found in the configuration Spe.config
. There is a generic list of permissions configured by default but we highly encourage you to adjust to meet your security requirements.
Example: The following configuration defines the roles that have access to use SPE Remoting. Any role previously defined in the <authorization/>
section is removed and custom roles are then added.
Example: The following configuration grants access to custom roles without removing any existing roles.
Step 2: Enter the role in which lower privileged users are members.
Step 3: Enter the user account with elevated access. This could be sitecore\Admin
or any other user your environment has configured. This user will be impersonated during script execution.
Step 5: Enable the delegated access item when ready for use.
When scripts are executed you should see them logged to the SPE log where the context user and impersonated user appear.
2304 14:02:32 INFO [Gutter] Executing script {CFE81AF6-2468-4E62-8BF2-588B7CC60F80} for Context User sitecore\test as sitecore\Admin.
Example: The following configuration will deny anonymous calls to the web services.
The following files are the bare minimum required to support SPE web services. This setup is suitable for environments such as servers built within a Continuous Integration environment that need remoting enabled. Remoting is disabled by default. If you need this functionality, enable it separately using a config patch file.
Required:
App_Config\Include\Spe\Spe.config
App_Config\Include\Spe\Spe.Minimal.config
bin\Spe.dll
bin\Spe.Abstractions.dll
sitecore modules\PowerShell\Services\web.config
sitecore modules\PowerShell\Services\RemoteAutomation.asmx
sitecore modules\PowerShell\Services\RemoteScriptCall.ashx
You will also need to patch the configuration with the following:
For your convenience we've included a package bundled with all of the above called SPE.Minimal-6.x.zip. Any of the disabled configuration files should be enabled following extraction.
Note: If you are using Sitecore 9.1 or later with Identity Server, there is a configuration file that should be enabled.
Spe.IdentityServer.config
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.
We have provided a handy way of executing scripts via web service using the Remoting Automation Service.
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.
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.
Example: The following downloads a single file from the Package directory.
Example: The following downloads a single media item from the library.
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.
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 improves upon the previous example.
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.
Examples for managing complex field types such as MultilistField and NameValueListField.
Example: The following demonstrates how to set a field to a known list of Ids. The Id is already converted to a GUID string.
Example: The following replaces an instance of an Id with an alternate Id. The Id is already converted to a GUID string.
Example: The following adds new Ids to an existing list. Makes use of the Sitecore.Text.ListString
class.
Example: The following appends an ID
to a set of items in all languages. It verifies that the field Keywords exists.
Example: The following example gets all of the items of a MultilistField
and append a specific ID
, ensuring that it's delimited with the |
character.
Example: The following example extracts the items from a 'keywords' field, comma separates the values, and then outputs to a report.
Example: The following example gets all of the name/value pairs of a NameValueListField
and appends a new pair.
There are several variables available out of the box for use in running commands and scripts. Many of the variables prefixed with Sitecore derive from the Sitecore.config settings. Run the command Get-Variable
to see the complete list available in the currently running session.
Note: Any new variables created are stored within the current session; when the session ends the variables are removed. Be careful not to overwrite the built-in variables.
The task scheduler is a great way to run scripts in a periodic fashion. You may find the need to automatically archive log files into a compressed file. Perhaps send an email with a generated report based on stale site content.
To help make the setup simple, we've provided a Task Command.
The command shown above is simply a type exposed as a public method in the Spe assembly. There exists an update method which accepts one or more items and executes the associated script.
Beneath Schedules you can create as many tasks as Sitecore will allow. Configure the Command and Items fields like that shown below.
The Items field contains the path to a script in the Script Library.
Below are some of the scripts found out-of-the-box with SPE.
We've added a context menu item to provide you with a shortcut to the Task Scheduler Editor.
Create a new scheduled task:
Run or edit the scheduled task:
The scheduled task is capable of running 1-to-many scripts. Choose all that apply for the selected task. Each script runs within a shared session, making it possible to share results between scripts.
Note: Make use of the Enable Rule to take advantage of the rules engine.
The task schedule has an intuitive dialog for working with and changing the frequency.
Note: Examples included are in the following modules
License Expiration
Media Library Maintenance
System Maintenance
Visual components made available to users in the Content Editor.
The Context Menu integration reveals a list of options to the user in the context menu under a special node called Scripts. The Sitecore rules engine may be used to control visibility and enabled state. The script is only executed when the option is clicked.
Begin by adding a new script to the Context Menu library. The name of the script will appear in the context menu.
Edit the script to perform the appropriate actions. The script can run in the background and show dialogs.
Change the icon of the item to match the script purpose.
Configure any Enable or Show rules as needed.
Note: Examples included in the following modules
Authoring Instrumentation
Copy Renderings
Index On Demand
Media Library Maintenance
Package Generator
Task Management
The Gutter integration reveals a visual notification to the user in the far left gutter. The Sitecore rules engine may be used to control enabled state.
Begin by adding a new script to the Gutters library.
Edit the script to create a new instance of Sitecore.Shell.Applications.ContentEditor.Gutters.GutterIconDescriptor
if the right conditions are met.
Set the Icon, Tooltip, and Click properties.
Return the gutter object
Configure any Enable rules to ensure the script runs only when necessary.
Rebuild the gutter integration from within the ISE.
Settings tab
Integration chunk
Sync Library with Content Editor Gutter command
Note: Examples included in the following modules
Publishing Status Gutter
The Insert Item integration reveals a list of options to the user in the context menu under the node called Insert. The Sitecore rules engine may be used to control visibility and enabled state. The script is only executed when the option is clicked.
Begin by adding a new script to the Insert Item library. The name of the script will appear in the context menu.
Edit the script to perform the appropriate actions. The script can run in the background and show dialogs.
Change the icon of the item to match the script purpose.
Configure any Show rules as needed.
Note: Examples included in the following modules
Task Management
Platform
The Ribbon integration reveals commands to the user in the ribbon. The Sitecore rules engine may be used to control visibility and enabled state. The script is only executed when the option is clicked.
Begin by adding a new child script library to the Ribbon library; we'll refer to this library as the Tab library. Choose a name that matches an existing tab to be used, such as Home or Developer, or a new name to create a new tab.
Add a child script library to the Tab library; we'll call this the Chunk library. Choose a name such as Edit or Tools.
Add a new script to the Chunk script library; we'll refer to this library as the Command library. The name of the script will appear in the ribbon chunk as a command.
Optionally add a short description on the item, which is found as a standard field on the item. The description will appear as a tooltip on the ribbon button.
Edit the script to perform the appropriate actions. The script can run in the background and show dialogs.
Change the icon of the item to match the script purpose.
Configure any Enable or Show rules as needed.
Example: The following script gets the selected Context Menu item and displays an alert using the item name.
Button Size:
There is a way to generate small buttons and combo buttons. You simply need to prefix the script name and SPE will generate accordingly.
Small$[SCRIPT_NAME]
Combo$[SCRIPT_NAME]
SmallCombo$[SCRIPT_NAME]
Similar to the Ribbon integration, this provides a way to show buttons when certain contextual conditions are met. Most common is with media items. The steps are the same as with the standard Ribbon, but the structure is slightly changed.
In the following example, we have a ribbon button that appears whenever the selected item in the Content Editor is a media item. Take note of the "Optimize" button.
The ribbon structure would look like the following:
The Warning integration reveals a notification to the user above content. The Sitecore rules engine can be used to control visibility and enabled state. The scripts are only executed when the rule is met and the command is clicked.
Begin by adding a new script library to the Warning library.
Edit the script to perform the appropriate actions. The script can run in the background and show dialogs.
The warning notification title, text and icon should be configured in the script.
Include options to the warning by adding one or more secondary scripts to the script library.
Configure any Enable rules to ensure the script only runs when required.
Note: Examples included in the following modules
License Expiration - disabled by default
See some of the community contributed modules built for SPE.
There are some really amazing contributions and add-ons to SPE from the community.
Example: The following lists configurations by name.
Example: The following syncs configurations just like you would through the Unicorn Control Panel or the PowerShell API.
The following are Sitecore modules that enhance the SPE experience.
Building reports is a straightforward task. We've provided a variety of examples for you to model when designing your own.
The Authorable Reports module includes reports such as Index Viewer and Rules based report that provide input dialogs to help make the reports dynamic.
Note: The Index Viewer and Rules Based Report are bundled as separate a package on the Sitecore Marketplace.
The Index Viewer report provides a great example at how to build a generic report that queries against the Sitecore index. By navigating to Sitecore -> Toolbox -> Index Viewer you can conveniently launch the report.
First you will be prompted with a dialog to select the index to search.
Next you will be prompted with a variety of buttons and knobs to narrow down the search results.
Finally the report is shown. Each row has an option to show more field results.
The Show Full Info link will then returns the additional fields not shown in the report.
The Authorable Reports module has a few points of interest.
The script library Internal/List View/Ribbon/SearchResultItem instructs the report to show the action scripts when the row contains an entry with the typename SearchResultItem.
The script library Toolbox/Index Viewer represents the shortcut.
Examples:
The Content Reports module includes other reports used for auditing. Below are some examples on how to create your own. You can control the report menu with the Enable and Show rules. This can be helpful if you want to secure specific reports with security roles.
The rules engine can be used the control the report export and action commands. Use the Enable and Show rules to make the necessary changes.
Examples:
Actions are simply commands powered by scripts and with visibility dependent on certain conditions like the .Net class of the object that is displayed or perhaps other session settings.
You define an action as a script located in an SPE script library and appears in the Actions panel. In the simplest scenario the action would appear when the script library name matches the .Net class name of the items displayed. In the above scenario the actions are placed under /Platform/Internal/List View/Ribbon/Item/
where Platform is the module and Item is a script library. Let's take a look at the script here /Platform/Internal/List View/Ribbon/Item/Open
The variable $selectedData
is provided to the script automatically by SPE in context of the content of the results on Show-ListView
.
When your action script is executed the environment is initialized with a number of variables at your disposal as seen below:
$selectedData
– the selected objects in the list view (the same will be passed to the $resultSet
variable for compatibility with older scripts)
$allData
– all objects passed to the list view using the -Data
parameter.
$filteredData
– all objects displayed after filtering is performed with the search criteria entered by the user in the ribbon.
$exportData
– same as $filteredData
, however in this case the objects will have additional properties to support easy display with properties processed as text.
$actionData
– any object that was passed to Show-ListView
using the -ActionData
parameter. Useful when you need additional context that the Show-ListView
command does not explicitly know about. It’s your custom data.
$formatProperty
– the content of the –Property
parameter when running the command.
$title
– window title of the list view.
$infoTitle
– info title of the list view.
$infoDescription
– info title of the list view.
Consequently you get the full state of the report the user sees in the UI and you can act upon it.
You can have multiple actions defined with dynamic visibility. The actions are generally only relevant in the context of your report. This is done on two levels. The first level happens based on the location of the script and .Net object type you are displaying in the report. The second level is based on Sitecore rules. For the action to appear all of the following conditions must be met:
All scripts visible in the report should be located in an enabled module.
The action script should be within the path /Internal/List View/Ribbon/[Object type]
. The [Object type]
is the name of the .Net class for which the action is valid. For example, if you want your action to be visible for Sitecore.Data.Items.Item
then save the script at the path /Internal/List View/Ribbon/Item
.
If the action script has no rules defined in the "Show if rules are met or not defined" field it will appear for all objects passed to Show-ListView
that are of the type based on location. Rules will provide more granular control and allow for rule-based conditions that determine action visibility.
The following screenshot shows how to create an action that only appears in reports that list objects of type Item
that are of template Schedule
.
For specific reports this global state might not always be enough. You can narrow down the rules further by using the report name. Name your report by providing an additional parameter to Show-ListView
.
Consider the following script:
The output of the report will be like any other unnamed report but adds support for additional rules. Let's say I want my action to open a new report that lists all the children of the selected items in the report "ListChildren". After running the action my script should display the new report with the children and close the "ListChildren" report. Not very useful but illustrates the point.
Now I need to save my script in the proper Script Library in my enabled module:
At this point my action will show on all reports what list Item objects. But now that my script is saved I can modify its rules to narrow it down only to Show for reports named "ListChildren". For this I can click the Runtime button in the ISE ribbon and edit the Show if rules are met or not defined field.
Now you can specify that you want the action to only appear when the report is named "ListChildren".
Confirm the save on all dialogs to persist your changes. Now our action appears when we run this script in ISE.
The action does not appear if no view name is provided to the -ViewName
parameter. Running the script below will produce a report with the action not shown:
The above action works just fine but will close the previous report and open a new report window in the Sitecore desktop. That's not a great user experience. What if you want to update the content of the report in place using the action? That's possible using the Update-ListView
command. Consider the following script:
In this case we're not closing the existing report but rather updating the list in place, all you need to do is send the new data to the Update-ListView
command.
One last thing that you might wonder is if the Write-Progress command works as it does in case of ISE or the dialog that runs scripts from Content Editor context menu. Let’s copy the following script into your action:
And you will see the following output:
The action runs fully asynchronously so you’re free to show any of the power of the provided commands. This means that you can ask for additional input using the Read-Variable
command or Show alert using the Show-Alert
command or do just about anything possible otherwise from the context menu, ribbon or other interactive integration points.
The Show-ListView
command has one more useful parameter named -ActionData
which I mentioned above but is worth mentioning again. Anything passed using this parameter will be set as the $actionData
variable – this means your report and actions can pass custom data in them it can be as simple as an object or as complex as a hashtable so there is really no hard limit on what can progress from a report to report. Any object that was passed to Show-ListView
using the -ActionData
parameter will be available to your action.
The persistent session ID will be respected and your script will run in that persistent session if it's already in memory or create a persistent session if it's not.
Alternatively you can elect to simply freeze the session the initial script that generated report was running in and run actions in that same frozen session by using the -ActionsInSession
parameter.
The Show-ListView
command provides the Hide parameter to control visibility of the UI elements.
Add parameter -Hide
with one or more of the following options:
AllExport
- hides all export scripts (left-most ribbon panel)
NonSpecificExport
- hides export filters that are not specific to this view as specified by -ViewName
(left-most ribbon panel)
Filter
- hides filter panel
PagingWhenNotNeeded
- hides paging when list is shorter than the page specified
AllActions
- hides all actions (right-most ribbon panel)
NonSpecificActions
- hides actions that are not specific to this view as specified by -ViewName
(right-most ribbon panel)
StatusBar
- hides status bar.
Example: The following example all of the UI elements in the report.
We've provided a few commands to interact with the user through dialogs.
Simple in the sense that the dialogs present the user with a short message and one or two buttons.
The Alert dialog is a way to notify the user of important information with an "OK" button.
Example: The following display a modal dialog.
No return value.
The Confirmation dialog is a way to verify with the user before proceeding.
Example: The following displays a modal dialog with an OK or Cancel confirmation.
Example: The following displays an input dialog for text.
Example: The following displays an input dialog with a error validation message.
The Read-Variable
command provides a way to prompt the user for information and then generate variables with those values.
Example: The following displays a dialog with a dropdown.
Note: The name selectedOption will result in a variable that contains the selected option.
Supported Parameter Values
Editor Types
bool
check
date
date time
droplist
droptree
groupeddroplink
groupeddroplist
info
item
link
marquee
multilist
multilist search
multiple user
multiple user role
multiple role
multitext
number
pass
radio
rule
rule action
tree
treelist
tristate
time
The Confirmation Choice dialog allows for multiple combinations like that seen with a "Yes, Yes to all, No, No to all" scenario.
Example: The following displays a modal dialog with choices.
Note: The hashtable keys should be incremented like btn_0, btn_1, and so on. The return value is the key name.
The Upload dialog provides a way to upload files from a local filesystem to the media library or server filesystem.
Example: The following displays an advanced upload dialog.
No return value.
The Download dialog provides a way to download files from the server to a local filesystem.
Example: The following displays a download dialog.
The Field Editor dialog offers a convenient way to present the user with fields to edit.
Example: The following displays a field editor dialog.
The File Browser is an obvious choice when you need to upload, download, or delete files.
Example: The following displays a file browser dialog for installation packages.
Example: The following displays a simple file browser dialog.
Example: The following displays a Sheer UI control without any additional parameters.
The "Data List" is essentially a report viewer which supports custom actions, exporting, and filtering.
Example: The following displays a list view dialog with the child items under the Sitecore tree.
The Results dialog resembles the Console but does not provide a prompt to the user. This is useful for when logging messages.
Example: The following displays a dialog with the all the information written to the ScriptSession output buffer.
We've built quite a few reports, many similar to the (ASR) module.
This tool provides similar functionality to the module. Search and rebuild the index on-demand.
This tool provides similar functionality to the module.
The url will look something like the following:
The integration point is disabled by default and can be enabled through configuration as described . See Restfulv2. Be sure to enable the SPE script module in the content tree.
Watch Adam present this and much more on Sitecore! Experienced .
See how Adam integrated if you are really curious to know more.
When using the you may need to increase the setting LDAP.SizeLimit
if you wish to return all Active Directory accounts.
Thank you for taking the time to check out the latest and greatest changes for SPE. Send a tweet sharing how much you love the module on .
See the for a compatibility matrix.
sitecore\Sitecore Client Authoring. See for instructions.
The bundled with the module provide convenient ways to interact with the Sitecore API. The module provides a User Account Control (UAC) feature akin to that of Microsoft Windows.
The way in which scripts make their way into Sitecore through built-in interfaces. Includes the , , and Content Editor via Item Saving.
Required for the following features: PowerShell .
Required for the following features: command. If the report export buttons do not work it could be because of this setting.
Required for the following features: PowerShell , PowerShell ,
Required for the following features: dialog, PowerShell Script Runner, (Context Menu, Insert Options, Ribbon).
There may be scenarios in which you need to grant users access to run scripts which require access to be higher the what is currently configured for the user. The various integration points made visible in the Content Editor (Context Menu, Ribbon, Reports) can be configured to run the scripts impersonating a power user. This has the advantage of giving lower privileged users "special" access without having to make members of more privileged roles. In this feature introduced a simple configuration item to apply the "special" access.
Step 1: Create a new delegated access item using the provided insert option.
Step 4: Select each script/library that should be delegated. Script/library items with a rule checking for delegated access should be included as well as scripts that should be run with the impersonated account.
Deny access to the web services for unauthenticated users and roles using the <deny>
element as described in sitecore modules\PowerShell\Services\web.config
.
If you disable Anonymous Authentication and enable Windows Authentication in IIS, such as the directory sitecore modules\PowerShell\Services\
you'll need to use the Credential parameter for any command that interacts with the services. See the section for examples.
Enable the remoting service through a configuration patch. See the page for more details.
Grant the remoting service user account through a configuration patch and granting acess to the appropriate role. See the page for more details.
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 . The SOAP service may require additional Windows authentication using the -Credential
parameter which is common when logged into a Windows Active Directory domain.
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 page for more details about the services available and how to configure.
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 .
Michael's follow up post on
Adam's initial post on
Example: The following changes the image linked on an item to a new image. Originally posted .
Example: The following removes an item link followed by removing the item. Originally posted .
Find all items based on a template found anywhere in the inheritance chain.
See how Adam added .
See how Adam added .
See the birth of by Adam.
Check out an example of the in the wild by Toby.
Alan provided a nice example on setting up the warning with commands.
A well known and widely adopted module has published some SPE commands. These commands are available (and optional) after installing Unicorn. Below are some samples ripped off from Kam Figy's blog posts and .
:
:
:
:
:
Content extracted from article written by Adam.
Rules add the full power of the Sitecore rules engine – similarly to what you can do on context menu items or ribbon actions in Content Editor. Some examples where this can be useful include only enabling or disabling the action for items located under a specific branch of the tree or if a exists.
for Sitecore product has published reports on Github that you can checkout .
Module
Script
System Maintenance
Archive Sitecore logs, Clean up deleted items older than 30 days
User Session Management
Remove idle user sessions
OK
yes
Cancel
no
OK
< user input >
Cancel
$null
OK
ok
Cancel
cancel
< variables >
< selection >
Name
string
Variable name
isSilent
Value
bool string int float datetime Item
Default value
$true
Title
string
Header or Label
"Proceed Silently
Tooltip (optional)
string
Short description or tooltip
"Check to run quietly
Tab (optional)
string
Tab title
"Simple"
Placeholder (optional)
string
Textbox placeholder
"Search text..."
Lines (optional)
int
Line count
3
Editor (optional)
string
Control type
"date time"
Domain (optional)
string
Domain name for security editor
"sitecore"
Options (optional)
string OrderedDictionary Hashtable
Data for checklist or dropdown
@{"Monday"=1;"Tuesday"=2}
Columns
int string
Number between 1 and 12 and string 'first' or 'last'
6 first
< first button >
btn_0
< second button >
btn_1
< third button >
btn_2
OK
ok
Cancel
cancel
OK
< selected file >
Cancel
undetermined
OK
< selected file >
Cancel
undetermined
Variable
Example
AppPath
C:\Inetpub\wwwroot\Console\Website\
HostSettings
... FontSize : 12 FontFamily : Wingdings ...
me
sitecore\admin
PWD
master:\
PSScript
$PSScript.Appearance.Icon # Returns the icon of the executing script
ScriptSession
... ID : e9fedd64-cad0-4c43-b950-9cd361b151fd ...
SitecoreAuthority
SitecoreContextItem
$SitecoreContextItem.Language.Name # Returns the language name
SitecoreDataFolder
C:\Inetpub\wwwroot\Console\Data
SitecoreDebugFolder
C:\Inetpub\wwwroot\Console\Data\debug
SitecoreIndexFolder
C:\Inetpub\wwwroot\Console\Data\indexes
SitecoreLayoutFolder
C:\Inetpub\wwwroot\Console\Website\layouts
SitecoreLogFolder
C:\Inetpub\wwwroot\Console\Data\logs
SitecoreMediaFolder
C:\Inetpub\wwwroot\Console\Website\upload
SitecorePackageFolder
C:\Inetpub\wwwroot\Console\Data\packages
SitecoreScriptRoot
master:\system\Modules\PowerShell\Script Library\Task Management\Toolbox
SitecoreCommandPath
master:\system\Modules\PowerShell\Script Library\Task Management\Toolbox\Task Manager
SitecoreSerializationFolder
C:\Inetpub\wwwroot\Console\Data\serialization
SitecoreTempFolder
C:\Inetpub\wwwroot\Console\Website\temp
SitecoreVersion
8.2.160729
Closes the runner job window after the script completes.
Close-Window
Ensures the runner process window is closed after the script finishes execution. This is commonly used when the runner should close after a report runs while in the Desktop mode.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Help Author: Adam Najmanowicz, Michael West
Add one or more base templates to a template item.
Add-BaseTemplate -Item <Item> -TemplateItem <TemplateItem[]>
Add-BaseTemplate -Item <Item> -Template <String[]>
Add-BaseTemplate -Path <String> -TemplateItem <TemplateItem[]>
Add-BaseTemplate -Path <String> -Template <String[]>
Add-BaseTemplate -Id <String> -TemplateItem <TemplateItem[]>
Add-BaseTemplate -Id <String> -Template <String[]>
Add-BaseTemplate [-Database <String>]
The Add-BaseTemplate command adds one or more base templates to a template item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to add the base template to.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Path to the item to add the base template to.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to add the base template to.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Sitecore item or list of items of base templates to add.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Path representing the template item to add as a base template. This must be of the same database as the item to be altered. Note that this parameter only supports a single template.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to add the base template to - required if item is specified with Id.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West, Alex Washtell
Add base template of /sitecore/templates/User Defined/BaseTemplate to a template, using a path.
Add multiple base templates to a template, using items.
Imports a CliXml string with data that represents Microsoft .NET objects and creates the objects within PowerShell.
ConvertFrom-CliXml [-InputObject] <String>
The ConvertFrom-CliXml command imports a CliXml string with data that represents Microsoft .NET Framework objects and creates the objects in PowerShell.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
String containing the Xml with serialized objects.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
System.String
The output type is the type of the objects that the cmdlet emits.
object
Help Author: Adam Najmanowicz, Michael West
ConvertTo-Xml
ConvertFrom-Xml
Export-CliXml
Import-CliXml
Converts an item from a clone to a fully independent item.
ConvertFrom-ItemClone [-Item] <Item> [-Recurse] [-PassThru]
ConvertFrom-ItemClone [-Path] <String> [-Recurse] [-PassThru]
ConvertFrom-ItemClone -Id <String> [-Database <String>] [-Recurse] [-PassThru]
Converts an item from a clone to a fully independent item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item to be converted.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be converted
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to be converted
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be converted
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
We generally see issues occurring due to an incompatible version of Windows PowerShell. Be sure to install Windows PowerShell version 3 or newer.
There is an additional configuration file added to support Identity Server. If you are installing Sitecore 9.1 or later you will want to enable the configuration file Spe.IdentityServer.config
.
Hack: Run this script on Sitecore 8.0.
Be sure the module is enabled and the integrations are rebuilt from within the ISE. The following are some of the integration issues you may experience:
Content Editor Gutter - Entries not listed.
Content Editor Ribbon - Buttons not visible or working.
Control Panel - Entries not listed.
Functions - Import-Function name parameter not populating with functions or can't be found after running the command.
Web API - Scripts not existing or can't be found.
404 error in browser console can be caused by missing SPE files, a custom pipeline, or perhaps a rewrite rule.
"The underlying connection was closed: An unexpected error occurred on a send." could be caused in Azure PaaS when requests are made using TLS 1.1 or lower. Setting the SecurityProtocol may help. Thanks to Jayesh Sheth for pointing to a resolution.
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
SPE ↓ / Sitecore→
8.0
8.1
8.2
9.0
9.1
9.2
9.3
10.0
10.1
10.2
10.3
10.4
4.0
✓
✓
–
–
–
–
–
-
-
-
-
-
4.1-4.6
✓
✓
✓
–
–
–
–
-
-
-
-
-
4.7
✓
✓
✓
✓
✓
–
–
-
-
-
-
-
5.0
✓
✓
✓
✓
✓
–
-
-
-
-
-
5.1
✓
✓
✓
✓
✓
–
-
-
-
-
-
6.0-6.2
✓
✓
✓
✓
✓
✓
✓
✓
✓
-
-
-
6.3
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
-
-
6.4
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
-
7.0
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
✓
Legend: "–" - not supported; "✓" - supported.
[2] Some features are not available. It is recommended to upgrade to the latest version available for 9.2.
When reviewing the different download packages you may see some names that are not too clear. The following list outlines what those names should mean.
N.X : Full N.X release - This refers to the package used by Standalone and CM roles. This includes what is required to see the PowerShell ISE, Console and their associated services.
N.X Minimal : Server-side remoting only - This refers to the package with only files. Useful for remotely connecting to SPE.
N.X Authorable Reports : Additional reports and tools - This package is a sublemental installation to the full version with additional reports. With version 6.0 this package is no longer needed as the reports are included with the full release.
N.X Remoting : SPE Remoting module for CI/CD - This provides a Windows PowerShell module for connecting to SPE remotely. Use in combination with the full or minimal packages.
Creates a version of the item in a new language based on an existing language version.
Creates a new version of the item in a specified language based on an existing language/version. Based on parameters you can make the command bahave differently when a version in the target language already exists and define which fields if any should be copied over from the original language.
© 2010-2020 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Add-ItemLanguage
Process the item and all of its children.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Default value is Append. Accepts one of 3 values:
Append - [Default] if language version exists create a new version with values copied from the original language
Skip - if language version exists don't do anything
OverwriteLatest - if language version exists overwrite the last version with values copied from the original language
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Default value is Skip. Accepts one of 2 values:
Skip - [Default] if the source item has no versions don't do anything
Add - if the source item has no versions create a version without any copied values
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language or a list of languages that should be created
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Creates a new version in the target language but does not copy field values from the original language
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
List of fields that should not be copied over from original item. As an example, use "__Security" if you don't want the new version to have the same restrictions as the original version.
In addition to the fields in -IgnoredFields the following fields are ignored as configured in Spe.config file in the following location: configuration/sitecore/powershell/translation/ignoredFields.
Fields ignored out of the box include:
__Archive date
__Archive Version date
__Lock
__Owner
__Page Level Test Set Definition
__Reminder date
__Reminder recipients
__Reminder text
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language that will be used as source language. If not specified the current user language will be used.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item / version to be processed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Translate the Home Item from English to US and Polish leaving the "Title" field blank. If a version exists don't do anything
Translate the children of Home item (but only those of Template Name "Sample Item") from English to US and Polish. If a version exists create a new version for that language. Display results in a table listing item name, language and created version number.
New-Item
Retrieves a Sitecore Database.
Get-Database [[-Name] <String>] [-Item <Item>]
The Get-Database command retrieves one or more Sitecore Database objects based on name or item passed to it.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the database to be returned.
Required?
false
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Database returned will be taken from the item passed to the command.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
System.String
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Database
Help Author: Adam Najmanowicz, Michael West
Useful code snippets to help you with those complex scripts.
Example: The following demonstrates how to list all of the fields of a template excluding the Standard Template fields.
Example: The following demonstrates how to generate the public facing url from a media item.
Example: The following demonstrates the use of the HtmlAgilityPack for parsing html.
Example: The following demonstrates how to update text in the document and exclude certain nodes.
Example: The following demonstrates how to remove empty paragraph tags in an html field.
Example: The following demonstrates removing style attributes from the html.
Example: The following prints the workflow history of the home item.
Example: The following will incrementally purge items from the recycle bin (master db) with a progress counter.
Example: The following logs messages to the browser console and then alerts the user with a message.
Returns Sitecore database archives.
Get-Archive [[-Database] <Database>] [[-Name] <String>]
The Get-Archive command returns Sitecore archives in context of the specified database.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the archive to retrieve.
Database for which the archives should be retrieved.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Database
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Archiving.Archive
Help Author: Adam Najmanowicz, Michael West
Returns all the items linked to the specified item..
Get-ItemReference -Item <Item>
Get-ItemReference -Item <Item> -ItemLink
Get-ItemReference -Path <String> [-Language <String[]>]
Get-ItemReference -Path <String> [-Language <String[]>] -ItemLink
Get-ItemReference -Id <String> [-Database <String>] [-Language <String[]>]
Get-ItemReference -Id <String> [-Database <String>] [-Language <String[]>] -ItemLink
The Get-ItemReference command returns all items linked to the specified item. If -ItemLink parameter is used the command will return links rather than items.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to be analysed.
Path to the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Id of the the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Database containing the item to be processed - can work with Language parameter to narrow the publication scope.
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
Return ItemLink that define both source and target of a link rather than items that are being linked to from the specified item.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Sitecore.Links.ItemLink
Help Author: Adam Najmanowicz, Michael West
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following gets the cloned Item
and returns the available notifications.
The following gets the cloned Item
based on the specified type of notification.
Retrieves item fields as either names or fields or template fields.
Get-ItemField [-Item] <Item> [-IncludeStandardFields] [-ReturnType <Name | Field | TemplateField>] [-Name <String[]>] [-Language <String[]>]
Get-ItemField [-Path] <String> [-IncludeStandardFields] [-ReturnType <Name | Field | TemplateField>] [-Name <String[]>] [-Language <String[]>]
Get-ItemField -Id <String> [-Database <String>] [-IncludeStandardFields] [-ReturnType <Name | Field | TemplateField>] [-Name <String[]>] [-Language <String[]>]
Retrieves item fields as either names or fields or template fields.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Includes fields that are defined on "Standard template"
Determines type returned. The possible values include:
Name - strings with field names.
Field - fields on the item
TemplateField - template fields.
Array of names to include - supports wildcards.
Language that will be analysed. If not specified the current user language will be used. Globbing/wildcard supported.
The item to be analysed.
Path to the item to be analysed.
Id of the item to be analysed.
Database containing the item to be analysed - can work with Language parameter to narrow the publication scope.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Sitecore.Data.Templates.TemplateField
Sitecore.Data.Fields.Field
Help Author: Adam Najmanowicz, Michael West
Get list of names of non standard fields from /sitecore/content/home item
Get list of fields including standard fields from /sitecore/content/home item and list their Name, DisplayName, SectionDisplayName and Description in a table.
Exports Microsoft .NET objects froms PowerShell to a CliXml string.
ConvertTo-CliXml [-InputObject] <PSObject>
The ConvertTo-CliXml command exports Microsoft .NET Framework objects from PowerShell to a CliXml string.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies the object to be converted. Enter a variable that contains the objects, or type a command or expression that gets the objects. You can also pipe objects to ConvertTo-CliXml.
The input type is the type of the objects that you can pipe to the cmdlet.
object
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
ConvertFrom-Xml
ConvertTo-Xml
Export-CliXml
Import-CliXml
Retrieves a Sitecore cache.
Get-Cache [[-Name] <String>]
The Get-Cache command retrieves a Sitecore cache.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the cache to retrieve. Supports wildcards.
The output type is the type of the objects that the cmdlet emits.
Sitecore.Caching.Cache
Help Author: Adam Najmanowicz, Michael West
Returns all the clones for the specified item.
Get-ItemClone [-Item] <Item>
Get-ItemClone [-Path] <String>
Get-ItemClone -Id <String> [-Database <String>]
The Get-ItemClone command returns all the clones for the specified item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to be analysed for clones presence.
Path to the item to be analysed for clones presence.
Id of the item to be analysed for clones presence.
Database containing the item to be processed - if item is being provided through Id.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Get-Item
Retrieves a list of items found in the specified archive.
The Get-ArchiveItem command returns items found in the "archive" and "recyclebin" archives.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies the archive to use when determining which ArchiveEntry items to process. Use Get-Archive to find the appropriate archive.
Specifies the ID for the original item that should be processed. This is NOT the ArchivalId.
Specifies the user responsible for moving the item to the archive.
None.
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Archiving.ArchiveEntry
Help Author: Adam Najmanowicz, Michael West
The following returns all items found in the specified archive.
The following returns items matching the ItemId found in the specified archive.
The following returns items moved to the recycle bin by the user found in the specified archive.
The following demonstrates changing the archive date on an item followed by retrieving the archived item.
Remove-ArchiveItem
Restore-ArchiveItem
Remove-Item
Remove-ItemVersion
You can see the Sitecore Stack Exchange answer describing the contents of the configuration.
Some users have reported an where the package installation in Sitecore hangs while installing SPE. One possible fix is to disable the Sitecore Analytics feature; this of course assumes you do not plan on using it for your instance.
Article: Martin Miles encountered the issue and proposed a fix .
- Missing Home item (fixed in 3.2)
"The request failed with an empty response." could be caused when TLS is offloaded to a load balancer and traffic to the endpoint is no longer over HTTPS. Fixed by issue #.
✓
✓
[1] Released by Sitecore for SXA which can be download from the however you should be safe simply installing the official SPE release on GitHub.
Publish-Item command unsupported ()
Indexing commands unsupported ()
Example: The following restores items in the media library that were removed yesterday. @technomaz.
Example:
Not seeing what you are looking for? You can always check out some Github Gists that and have shared or the .
Required?
false
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
2
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Returns the library item or path to the library where scripts for a particular integration point should be located for a specific module.
Get-SpeModuleFeatureRoot [-Module <Module>] [-ReturnPath] [-Feature] <String>
The Get-SpeModuleFeatureRoot command returns library item or path to the library where scripts for a particular integration point should be located for a specific module.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Module for which the feature root library should be returned. If not provided the feature root will be returned for all modules.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Feature for which the root library should be provided. If root item does not exist and -ReturnPath parameter is not specified - nothing will be returned, If -ReturnPath parameter is provided the path in which the feature root should be located will be returned
Valid features:
contentEditorContextMenu
contentEditorGutters
contentEditorRibbon
controlPanel
functions
listViewExport
listViewRibbon
pipelineLoggedIn
pipelineLoggingIn
pipelineLogout
toolbox
startMenuReports
eventHandlers
webAPI
pageEditorNotification
isePlugi
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
System.String
Help Author: Adam Najmanowicz, Michael West
Return the library item for "Content Editor Context Menu"
Return the Path to where "List View Export" scripts would be located if this feature was defined
Returns all the items referring to the specified item.
Get-ItemReferrer -Item <Item>
Get-ItemReferrer -Item <Item> -ItemLink
Get-ItemReferrer -Path <String> [-Language <String[]>]
Get-ItemReferrer -Path <String> [-Language <String[]>] -ItemLink
Get-ItemReferrer -Id <String> [-Database <String>] [-Language <String[]>]
Get-ItemReferrer -Id <String> [-Database <String>] [-Language <String[]>] -ItemLink
The Get-ItemReferrer command returns all items referring to the specified item. If -ItemLink parameter is used the command will return links rather than items.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to be analysed.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Return ItemLink that define both source and target of a link rather than items linking to the specified item.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Sitecore.Links.ItemLink
Help Author: Adam Najmanowicz, Michael West
Returns the object that describes a Sitecore PowerShell Extensions Module
Get-SpeModule -Item <Item>
Get-SpeModule -Path <String>
Get-SpeModule -Id <String> -Database <String>
Get-SpeModule -Database <String>
Get-SpeModule [-Database <String>] -Name <String>
The Get-SpeModule command returns the object that describes a Sitecore PowerShell Extensions Module.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
A script or library item that is defined within the module to be returned.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to a script or library item that is defined within the module to be returned.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of a script or library item that is defined within the module to be returned.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the module to be returned.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Name fo the module to return. Supports wildcards.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
System.String
The output type is the type of the objects that the cmdlet emits.
Spe.Core.Modules.Module
Help Author: Adam Najmanowicz, Michael West
Return all modules defined in the provided database
Return all modules defined in the master database Matching the "Content*" wildcard
Return the module the piped script belongs to
Returns entries from the history store notifying of workflow state change for the specified item.
Get-ItemWorkflowEvent [-Item] <Item> [-Identity <String>] [-Language <String[]>]
Get-ItemWorkflowEvent [-Path] <String> [-Identity <String>] [-Language <String[]>]
Get-ItemWorkflowEvent -Id <String> [-Database <String>] [-Identity <String>] [-Language <String[]>]
The Get-ItemWorkflowEvent command returns entries from the history store notifying of workflow state change for the specified item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
User that has been associated with the enteries. Wildcards are supported.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item to have its history items returned.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to have its history items returned - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the the item to have its history items returned - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to have its history items returned - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Workflows.WorkflowEvent
Help Author: Adam Najmanowicz, Michael West
Execute-Workflow
Returns list of the current sitecore jobs
Get-SitecoreJob
The Get-SitecoreJob command returns the list of the currently running jobs of Sitecore.
© 2010-2019 Implemented by Vangasewinkel Benjamin using the Adam Najmanowicz, Michael West Sitecore PowerShell Extensions. All rights reserved.
None
The output type is the type of the objects that the cmdlet emits.
Sitecore.Jobs.Job
Help Author: Vangansewinkel Benjamin
Returns the item template and its base templates.
Get-ItemTemplate [-Item] <Item> [-Recurse]
Get-ItemTemplate [-Path] <String> [-Recurse]
Get-ItemTemplate -Id <String> [-Database <String>] [-Recurse]
The Get-ItemTemplate command returns the item template and its base templates.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Return the template the item is based on and all of its base templates.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item to be analysed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be analysed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to be analysed.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be analysed - required if item is specified with Id.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.TemplateItem
Help Author: Adam Najmanowicz, Michael West
Get template of /sitecore/conent/home item
Get template of /sitecore/conent/home item and all of the templates its template is based on then format it to only show the template name, path and Key
Expands tokens in fields for items.
Expand-Token [-Item] <Item> [-Language <String[]>]
Expand-Token [-Path] <String> [-Language <String[]>]
Expand-Token -Id <String> [-Database <String>] [-Language <String[]>]
The Expand-Token command expands the tokens in fields for items.
Some example of tokens include:
$name
$time
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Language that will be processed. If not specified the current user language will be used. Globbing/wildcard supported.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item to be processed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the the item to be processed - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
The following expands tokens in fields on the item.
The following expands tokens in fields on the item. If the standard value of the field contains a token we modify the field to the token so the expansion will work (Sitecore API does not expand if the field is the same as Standard Values and never modified).
Returns the current user's browser user agent.
Returns current user's browser user agent. Works only if Console is running outside of job. (e.g. in ISE - script needs to be run from the dropdown under the "Execute" button)
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
Executes Sitecore Shell command for an item. This command used to be named Execute-ShellCommand - a matching alias added for compatibility with older scripts.
Invoke-ShellCommand [-Item] <Item> [-Name] <String> [-Language <String[]>]
Invoke-ShellCommand [-Path] <String> [-Name] <String> [-Language <String[]>]
Invoke-ShellCommand -Id <String> [-Database <String>] [-Name] <String> [-Language <String[]>]
Executes Sitecore Shell command for an item. e.g. opening dialogs or performing commands that you can find in the Content Editor ribbon or context menu.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Execute-ShellCommand
Name of the sitecore command e.g. "item:publishingviewer"
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
The item to be sent to the command.
Path to the item to be sent to the command - additionally specify Language parameter to fetch different item language than the current user language.
Id of the the item to be sent to the command - additionally specify Language parameter to fetch different item language than the current user language.
Database containing the item to be sent to the command - can work with Language parameter to narrow the publication scope.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Launch Publishing Viewer for /sitecore/content/home item.
Initiate /sitecore/content/home item duplication.
Show properties of the /sitecore/content/home item.
Returns one or more task schedule items using the specified criteria.
Get-TaskSchedule -Item <Item>
Get-TaskSchedule -Path <String>
Get-TaskSchedule [[-Database] <Database>] [[-Name] <String>]
The Get-TaskSchedule command returns one or more task schedule items, based on name/database filter, path or simply converting a Sitecore item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Task item to be converted.
Path to the item to be returned as Task Schedule.
Database containing the task items to be returned. If not provided all databases will be considered for filtering using the "Name" parameter.
Task filter - supports wildcards. Works with "Database" parameter to narrow tassk to only single database.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Tasks.ScheduleItem
Help Author: Adam Najmanowicz, Michael West
Creates a new item clone based on the item provided.
New-ItemClone [-Item] <Item> -Destination <Item> [-Name <String>] [-Recurse]
New-ItemClone [-Path] <String> -Destination <Item> [-Name <String>] [-Recurse]
New-ItemClone -Id <String> [-Database <String>] -Destination <Item> [-Name <String>] [-Recurse]
Creates a new item clone based on the item provided.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Parent item under which the clone should be created.
Name of the item clone.
Add the parameter to clone thw whole branch rather than a single item.
The item to be cloned.
Path to the item to be cloned.
Id of the item to be cloned
Database of the item to be cloned if item is specified through its ID.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Clone /sitecore/content/home/ under /sitecore/content/new-target/ with the "New Home" name.
New-Item
Creates new entry in the history store notifying of workflow state change.
New-ItemWorkflowEvent [-Item] <Item> [-OldState <String>] [-NewState <String>] [-Text <String>] [-Language <String[]>]
New-ItemWorkflowEvent [-Path] <String> [-OldState <String>] [-NewState <String>] [-Text <String>] [-Language <String[]>]
New-ItemWorkflowEvent -Id <String> [-Database <String>] [-OldState <String>] [-NewState <String>] [-Text <String>] [-Language <String[]>]
Creates new entry in the history store notifying of workflow state change.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Id of the old state. If not provided - current item workflow state will be used.
Id of the old state. If not provided - current item workflow state will be used.
Action comment.
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
The item to have the history event attached.
Path to the item to have the history event attached - additionally specify Language parameter to fetch different item language than the current user language.
Id of the the item to have the history event attached - additionally specify Language parameter to fetch different item language than the current user language.
Database containing the item to have the history event attached - can work with Language parameter to narrow the publication scope.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Execute-Workflow
Executes Workflow action for an item. This command used to be named Execute-Workflow - a matching alias added for compatibility with older scripts.
Invoke-Workflow [-Item] <Item> [-CommandName <String>] [-Comments <String>] [-Language <String[]>]
Invoke-Workflow [-Path] <String> [-CommandName <String>] [-Comments <String>] [-Language <String[]>]
Invoke-Workflow -Id <String> [-Database <String>] [-CommandName <String>] [-Comments <String>] [-Language <String[]>]
Executes Workflow action for an item. If the workflow action could not be performed for any reason - an appropriate error will be raised.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Execute-Workflow
Namer of the workflow command.
Comment to be saved in the history table for the action.
Language that will be used as source language. If not specified the current user language will be used. Globbing/wildcard supported.
The item to have the workflow action executed.
Path to the item to have the workflow action executed - additionally specify Language parameter to fetch different item language than the current user language.
Id of the the item to have the workflow action executed - additionally specify Language parameter to fetch different item language than the current user language.
Database containing the item to have the workflow action executed - can work with Language parameter to narrow the publication scope.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Submit item to approval, item gotten from path
Reject item, item gotten from pipeline
Imports a function script from the script library's "Functions" folder.
Import-Function [-Name] <String> [-Library <String>] [-Module <String>]
The Import-Function command imports a function script from the script library's "Functions" folder.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the script in the "Functions" library or one of its sub-libraries.
Name of the library withing the "Functions" library. Provide this name to disambiguate a script from other scripts of the same name that might exist in multiple sub-librarties of the Functions library.
Name of the module "Functions" are going to be taken from. Provide this name to disambiguate a script from other scripts of the same name that might exist in multiple Modules.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.Object
Help Author: Adam Najmanowicz, Michael West
The following imports a Resolve-Error function that you may later use to get a deeper understanding of a problem with script should one occur by xecuting the "Resolve-Error" command that was imported as a result of the execution of the following line
Executes a script from Sitecore PowerShell Extensions Script Library. This command used to be named Execute-Script - a matching alias added for compatibility with older scripts.
Invoke-Script [-Item] <Item> [-ArgumentList <Object[]>]
Invoke-Script [-Path] <String> [-ArgumentList <Object[]>]
Executes a script from Sitecore PowerShell Extensions Script Library.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Execute-Script
The script item to be executed.
Path to the script item to be executed. Path can be absolute or Relavie to Script library root. e.g. the following two commands are equivalent:
PS master:> Invoke-Script 'master:\system\Modules\PowerShell\Script Library\Examples\Script Testing\Long Running Script with Progress Demo' PS master:> Invoke-Script 'Examples\Script Testing\Long Running Script with Progress Demo'
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.Object
Help Author: Adam Najmanowicz, Michael West
Run a script with arguments passed in.
The arguments are passed and used in the called script like below:
Aliases
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
false
Position?
2
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The following gets the cloned Item
, returns the available notifications, and finally accepts the notifications.
The following gets the cloned Item
, returns the available notifications, and finally rejects the notifications.
Send an object content to the client
Out-Download -InputObject <Object> [-ContentType <String>] [-Name <String>]
The cmdlet allows to send content of an object (FileInfo, Stream, String, String[] or Byte[]) to the client. This is used for example by report scripts to send the report in HTML, Json or Excel without saving the content of the object to the disk drive. You can specify an object type and file name to make sure the downloaded file is interpreted properly by the browser.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Object content to be sent to the client. Object must be of one of the following types:
FileInfo,
Stream,
String,
String[],
Byte[]
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
The MIME content type of the object. In most cases you can skip this parameter and still have the content type be deduced by the browser from the
Common examples (after Wikipedia)
application/json
application/x-www-form-urlencoded
application/pdf
application/octet-stream
multipart/form-data
text/html
image/png
image/jpg
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Name of the file you want the user browser to save the object as.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByPropertyName)
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
System.Object
The output type is the type of the objects that the cmdlet emits.
System.Boolea
Help Author: Adam Najmanowicz, Michael West
Send first log file to the user
Send Hello World text file to the user
Get a list of sitecore branches under root item in the master database and send the list to user as excel file
New-UsingBlock.
New-UsingBlock [-InputObject] <IDisposable> [-ScriptBlock] <ScriptBlock>
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Object that should be disposed after the Script block is executed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Script to be executed within the "Using" context.
Required?
true
Position?
2
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
System.IDisposable
The output type is the type of the objects that the cmdlet emits.
void
Help Author: Adam Najmanowicz, Michael West
Assuming all items under /sitecore/content/home have both 'Title' and 'MetaTitle' fields... Using New-UsingBlock to bulk update items under /sitecore/Content/ to have their 'MetaTitle' field to be equal to the 'Title' field
Using New-UsingBlock to perform a test with UserSwitcher - checking whether an anonymous user can change a field The test should end up showing the error as below and the Title should not be changed!
Remove one or more base templates from a template item.
Remove-BaseTemplate -Item <Item> -TemplateItem <TemplateItem[]>
Remove-BaseTemplate -Item <Item> -Template <String[]>
Remove-BaseTemplate -Path <String> -TemplateItem <TemplateItem[]>
Remove-BaseTemplate -Path <String> -Template <String[]>
Remove-BaseTemplate -Id <String> -TemplateItem <TemplateItem[]>
Remove-BaseTemplate -Id <String> -Template <String[]>
Remove-BaseTemplate [-Database <String>]
The Remove-BaseTemplate command removes one or more base templates from a template item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to remove the base template from.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Path to the item to remove the base template from.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to remove the base template from.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Sitecore item or list of items of base templates to remove.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Path representing the template item to remove as a base template. This must be of the same database as the item to be altered. Note that this parameter only supports a single template.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to remove the base template from - required if item is specified with Id.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West, Alex Washtell
Remove base template of /sitecore/templates/User Defined/BaseTemplate from a template, using a path.
Remove multiple base templates from a template, using items.
Removes Language/Version from a single item or a branch of items
Removes Language/Version from a an Item either sent from pipeline or defined with Path or ID. A single language or a list of languages can be defined using the Language parameter. Language parameter supports globbing so you can delete whole language groups using wildcards.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Remove-ItemLanguage
Deleted language versions from the item and all of its children.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language(s) that should be deleted form the provided item(s). A single language or a list of languages can be defined using the parameter. Language parameter supports globbing so you can delete whole language groups using wildcards.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Version(s) that should be deleted form the provided item(s). A single version or a list of versions can be defined using the parameter. Version parameter supports globbing so you can delete whole version groups using wildcards.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language(s) that should NOT be deleted form the provided item(s). A single language or a list of languages can be defined using the parameter. Language parameter supports globbing so you can delete whole language groups using wildcards.
If Language parameter is not is not specified but ExcludeLanguage is provided, the default value of "*" is assumed for Language parameter.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If provided - trims the selected language to value specified by this parameter.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item/version to be processed. You can pipe a specific version of the item for it to be removed.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be processed - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Specifying this switch will move the items to the archive rather than recycle bin.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Remove Polish and Spanish language from /sitecore/content/home item in the master database
Remove all english based languages defined in /sitecore/content/home item and all of its children in the master database
Remove all languages except those that are "en" based defined in /sitecore/content/home item and all of its children in the master database
Trim all languages to 3 latest versions for /sitecore/content/home item and all of its children in the master database
The following moves the specified item version to the archive.
Remove-Item
Prompts user to provide values for variables required by the script to perform its operation.
Prompts user to provide values for variables required by the script to perform its operation. If user selects the "OK" button the command will return 'ok' as its value. If user selects the "Cancel" button or closes the window with the "x" button at the top-right corner of the dialog the command will return 'cancel' as its value.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies the variables that value should be provided by the user. Each variable definition can have the following structure:
Name - the name of the PowerShell variable - without the $ sign
Value - the initial value of the variable - if the variable have not been created prior to launching the dialog - this will be its value unless the user changes it. if Value is not specified - the existing variable name will be used.
Title - The title for the variable shown above the variable editor.
Tooltip - The hint describing the parameter further - if the -ShowHints parameter is provided this value will show between the Variable Title and the variable editor.
Editor - If the default editor selected does not provide the functionality expected - you can specify this value to customize it (see examples)
Tab - if this parameter is specified on any Variable the multi-tab dialog will be used instead of a simple one. Provide the tab name on which the variable editor should appear.
Variable type specific:
Root - for some Item selecting editors you can provide this to limit the selection to only part of the tree
Source - for some Item selecting editors you can provide this to parametrize the item selection editor. (Refer to examples for some sample usages)
Lines - for String variable you can select this parameter if you want to present the user with the multiline editor. The for this parameter is the number of lines that the editor will be configured with.
Domain - for user and role selectors you can limit the users & roles presented to only the domain - specified)
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog description displayed below the dialog title.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Text shown on the cancel button.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Text shown on the OK button.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Specifies whether the variable hints should be displayed. Hints are shown below each the variable title but above the variable editing control.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog title - shown at the top of the dialog.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog width.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog width.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
The following provides a dialog with a dropdown of options, and how to read the selected value.
Following is an example of a simple dialog asking user for various variable types.
The type of some of the controls displayed to the user are iferred from the variable type (like the $item variable or DateTime) The editors for some other are set by providing the "editor" value
Following is an example of a multi tabbed dialog asking user for various variable types.
The type of some of the controls displayed to the user are inferred from the variable type (like the $item variable or DateTime) The editors for some other are set by providing the "editor" value
Publishes a Sitecore item.
Publish-Item [-Item] <Item> [-Recurse] [-Target <String[]>] [-PublishMode <Unknown | Full | Incremental | SingleItem | Smart>] [-PublishRelatedItems] [-RepublishAll] [-CompareRevisions] [-FromDate <DateTime>] [-AsJob] [-Language <String[]>]
Publish-Item [-Path] <String> [-Recurse] [-Target <String[]>] [-PublishMode <Unknown | Full | Incremental | SingleItem | Smart>] [-PublishRelatedItems] [-RepublishAll] [-CompareRevisions] [-FromDate <DateTime>] [-AsJob] [-Language <String[]>]
Publish-Item -Id <String> [-Database <String>] [-Recurse] [-Target <String[]>] [-PublishMode <Unknown | Full | Incremental | SingleItem | Smart>] [-PublishRelatedItems] [-RepublishAll] [-CompareRevisions] [-FromDate <DateTime>] [-AsJob] [-Language <String[]>]
The Publish-Item command publishes the Sitecore item and optionally subitems. Allowing for granular control over languages and modes of publishing.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies that subitems should also get published with the root item.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Specifies one or many publishing targets. The default target database is "web".
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Specified the Publish mode. Valid values are:
Full
Incremental
SingleItem
Smart
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Turns publishing of related items on. Works only on Sitecore 7.2 or newer
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Republishes all items provided to the publishing job.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Turns revision comparison on.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Publishes items newer than the date provided only.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The Sitecore API called to perform the publish is different with this switch. You may find that events fire as expected using this.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language of the item that should be published. Supports globbing/wildcards. Allows for more than one language to be provided at once. e.g. "en*", "pl-pl"
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item that should be published - can work with Language parameter to narrow the publication scope.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item that should be published - can work with Language parameter to narrow the publication scope.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
None.
Help Author: Michael West, Adam Najmanowicz
Publish to many databases
Shows a dialog to users allowing to upload files to either server file system or items in media library.
Receive-File [-Description <String>] [-ParentItem] <Item> [-Title <String>] [-CancelButtonName <String>] [-OkButtonName <String>] [-Versioned] [-Language <String>] [-Overwrite] [-Unpack] [-Width <Int32>] [-Height <Int32>]
Receive-File [-Description <String>] [-Path] <String> [-Title <String>] [-CancelButtonName <String>] [-OkButtonName <String>] [-Overwrite] [-Unpack] [-Width <Int32>] [-Height <Int32>]
Receive-File [-ParentItem] <Item> -AdvancedDialog [-Width <Int32>] [-Height <Int32>]
Executing this command with file path on the server (provided as -Path parameter) provides script users with means to upload a file from their computer. Executing it for an Item located in Sitecore Media library (provided as -ParentItem) allows the user to upload the file as a child to that item. If the file has been uploaded the dialog returns path to the file (in case of file system storage) or Item that has been created if the file was uplaoded to media library.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Dialog description displayed below the dialog title.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item under which the uploaded media items should be stored.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Path to the folder where uploaded file should be stored.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Dialog title - shown at the top of the dialog.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Text shown on the cancel button.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Text shown on the OK button.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Indicates that the Media item should be created as a Versioned media item.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Specifies the language in which the media item should be created. if not specified - context language is selected.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
indicates that the upload should overwrite a file or a media item if that one exists. Otherwise a file with a non-confilicting name or a sibling media item is created.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Indicates that the uplaod is expected to be a ZIP file which should be unpacked when it's received.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Shows advanced dialog where user can upload multiple media items and select if the uploaded items are versioned, overwritten and unpacked.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog width.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Dialog width.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
System.String
The output type is the type of the objects that the cmdlet emits.
Sitecore.Data.Items.Item
System.String
Help Author: Adam Najmanowicz, Michael West
Upload text.txt file to server disk drive. A new file is created with a non-conflicting name and the path to it is returned
Upload text.txt file to media library under the 'master:\media library\Files' item A new media item is created and returned
Upload text.txt file to media library under the 'master:\media library\Files' item using advanced dialog. A new media item is created but "undetermined" is returned as the dialog does not return the results.
Upload text.txt file to media library under the 'master:\media library\Files' item. A new versioned media item in Danish language is created and returned. If the media item existed - it will be overwritten.
Removes items permanently from the specified archive.
The Remove-ArchiveItem command permanently removes entries from specified archive.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies the archive to use when determining which ArchiveEntry items to remove. Use Get-Archive to find the appropriate archive.
Specifies the ID for the original item that should be processed. This is NOT the ArchivalId.
Specifies the user responsible for moving the item to the archive.
Specific items from the archive may be deleted when using this parameter.
AccountIdentity
Sitecore.Data.Archiving.ArchiveEntry
The output type is the type of the objects that the cmdlet emits.
None.
Help Author: Adam Najmanowicz, Michael West
The following removes items matching the ItemId found in the specified archive.
The following removes items from the recycle bin by the user found in the specified archive.
The following removes all items from the recycle bin found in the specified archive.
Get-ArchiveItem
Restore-ArchiveItem
Remove-Item
Remove-ItemVersion
Sends a sheer message to the app in which context the script is executing.
Send-SheerMessage [-Name] <String> [-GetResult] [-Parameters <Hashtable>]
Sends a sheer message to the app in which context the script is executing.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the Sheer message to execute.
Help Author: Adam Najmanowicz, Michael West
If you execute the following script in the PowerShell ISE the Save dialog will popup
Resets item fields, specified as either names, fields or template fields.
Resets item fields, specified as either names, fields or template fields.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Includes fields that are defined on "Standard template"
Array of field names to include - supports wildcards.
The item to be analysed.
Path to the item to be analysed.
Id of the item to be analysed.
Database containing the item to be reset - can work with Language parameter to narrow the publication scope.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
None
Help Author: Adam Najmanowicz, Michael West, Alex Washtell
Reset all item fields, excluding standard fields.
Reset all item fields, including standard fields.
Reset all item fields with names beginning with "a", excluding standard fields.
The following resets one of the Standard Values fields for all versions and languages.
Restores items to the original database from the specified archive.
The Restore-ArchiveItem command restores entries from specified archive back to the original database.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Specifies the archive to use when determining which ArchiveEntry items to process. Use Get-Archive to find the appropriate archive.
Specifies the ID for the original item that should be processed. This is NOT the ArchivalId.
Specifies the user responsible for moving the item to the archive.
Specific items from the archive may be restored when using this parameter.
AccountIdentity
Sitecore.Data.Archiving.ArchiveEntry
The output type is the type of the objects that the cmdlet emits.
None.
Help Author: Adam Najmanowicz, Michael West
The following restores items matching the ItemId found in the specified archive.
The following restores items from the recycle bin by the user found in the specified archive.
The following restores all items from the recycle bin found in the specified archive.
Get-ArchiveItem
Restore-ArchiveItem
Remove-Item
Remove-ItemVersion
Sets the current host property.
Set-HostProperty [-ForegroundColor <Black | DarkBlue | DarkGreen | DarkCyan | DarkRed | DarkMagenta | DarkYellow | Gray | DarkGray | Blue | Green | Cyan | Red | Magenta | Yellow | White>] [-BackgroundColor <Black | DarkBlue | DarkGreen | DarkCyan | DarkRed | DarkMagenta | DarkYellow | Gray | DarkGray | Blue | Green | Cyan | Red | Magenta | Yellow | White>] [-HostWidth <Int32>] [-Persist]
Sets the current host property and perssits them for the future if used with -Persist parameter.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Color of the console text.
Color of the console background.
Width of the text buffer (texts longer than the number provided will wrap to the next line.
Persist the console setting provided
Help Author: Adam Najmanowicz, Michael West
Set width of the console buffer to 80 and persist it for the future instances
Set color of the console text to cyan. Next instance of the console will revert to default (white).
Allows users to download files from server and file items from media library.
Send-File [-Path] <String> [-Message <String>] [-NoDialog] [-ShowFullPath] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
Send-File [-Item] <Item> [-Message <String>] [-NoDialog] [-ShowFullPath] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
Executing this command with file path on the server provides script users with means to download a file to their computer. Executing it for an Item located in Sitecore Media library allows the user to download the blob stored in that item. If the file has been downloaded the dialog returns "downloaded" string, otherwise "cancelled" is returned.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The following abbreviations are aliases for this cmdlet:
Download-File
Path to the file to be downloaded. The file has to exist in the Data folder. Files from outside the Data folder are not downloadable.
Message to show the user in the download dialog.
The item to be downloaded.
If this parameter is used the Dialog will not be shown but instead the file download will begin immediately.
If this parameter is used the Dialog will display full path to the file downloaded in the dialog, otherwise only the file name will be shown.
Download dialog title.
Download dialog width.
Download dialog height.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
Download File from server disk drive
Download item from media library
The New-UsingBlock
command disposes of the provided input object after the specified scriptblock completes execution. You may find the data returned by the scriptblock is contained within the following object System.Collections.ObjectModel.Collection
1[[System.Management.Automation.PSObject, System.Management.Automation, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35]]`. This helps when multiple objects are returned and is .
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Pauses the script and shows an alert to the user.
Show-Alert [-Title] <String>
Pauses the script and shows an alert specified in the -Title to the user. Once user clicks the OK button - script execution resumes.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Text to show the user in the alert dialog.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Help Author: Adam Najmanowicz, Michael West
Shows prompt message box asking user to provide a text string.
Show-Input [-Prompt] <String> [-DefaultValue <String>] [-Validation <String>] [-ErrorMessage <String>] [-MaxLength <Int32>]
Shows prompt message box asking user to provide a text string.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Prompt message to show in the message box shown to a user.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Default value to be provided for the text box.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Regex for value validation. If user enters a value that does not validate - en error message defined with the "ErrorMessage" parameter will be shown and user will be asked to enter the value again.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Error message to show when regex validation fails.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Maximum length of the string returned. If user enters a longer value - en error message will be shown and user will be asked to enter the value again.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
Requests that the user provides an email, validates it against a regular expression snd whows an allert if the format is not valid
Uses Show-Input command to request user a new name for the content item validating the proper characters are used and assigns the result to $newName variable (nothing gets changed)
Requests that the user provides a string of at most 5 characters
Shows Field editor for a provided item.
Show-FieldEditor -Item <Item> -PreserveSections [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Show-FieldEditor -Item <Item> [-SectionTitle <String>] [-SectionIcon <String>] [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Show-FieldEditor -Path <String> [-Language <String[]>] -PreserveSections [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Show-FieldEditor -Path <String> [-Language <String[]>] [-SectionTitle <String>] [-SectionIcon <String>] [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Show-FieldEditor -Id <String> [-Database <String>] [-Language <String[]>] -PreserveSections [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Show-FieldEditor -Id <String> [-Database <String>] [-Language <String[]>] [-SectionTitle <String>] [-SectionIcon <String>] [-Name <String[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>] [-IncludeStandardFields]
Shows Field editor for a provided item allows for editing all or selected list of fields. If user closes the dialog by pressing the "OK" button "ok" string will be returned. Otherwise "cancel" will be returned.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Array of names of the fields to be edited.
This parameter supports globbing so you can simply use "" to allow editing of all fields. If a field is prefixed with a dash - this field will be excluded from the list of fields. e.g. the following will display all fields except title from Show-FieldEditor -Path "master:\content\home" -Name "", "-Title"
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Title of the dialog containing the field editor.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Width of the dialog containing the field editor.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Height of the dialog containing the field editor.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Add this parameter to add standard fields to the list that is being considered to be displayed
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The item to be edited.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue, ByPropertyName)
Accept Wildcard Characters?
false
Path to the item to be edited - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the the item to be edited - additionally specify Language parameter to fetch different item language than the current user language.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to be edited - can work with Language parameter to narrow the publication scope.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Language that will be edited. If not specified the current user language will be used. Globbing/wildcard supported.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If added this parameter tells editor to preserve the original item field sections, otherwise all fields are placed in a single section Named by SectionTitle parameter and having the SectionIcon icon.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If PreserveSections is not added to parameters - this parameter provides a title for the global section all fields are placed under.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If PreserveSections is not added to parameters - this parameter provides a iconfor the global section all fields are placed under.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
Show field editor that shows all non-standard fields on sitecore/content/home item except for field "title" The dialog will be titled "My Home Item" all fields inside will be in single section.
Show field editor that shows all fields including standard fields on sitecore/content/home The dialog will preserve the item sections.
Sets the item template.
The Set-ItemTemplate command sets the template for an item.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
The item to set the template for.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Path to the item to set the template for.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Id of the item to set the template for.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Sitecore item representing the template.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Path representing the template item. This must be of the same database as the item to be altered.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Hashtable of key value pairs mapping the old template field to a new template field.
@{"Title"="Headline";"Text"="Copy"}
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Database containing the item to set the template for - required if item is specified with Id.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West, Alex Washtell
Set template of /sitecore/content/home item using a Template path.
Set template of /sitecore/content/home item using a TemplateItem.
Set the template and remap fields to their new name.
Executes Sitecore Sheer application.
Show-Application [-Application] <String> [[-Parameter] <Hashtable>] [-Icon <String>] [-Modal] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
Executes Sitecore Sheer application, allows for passing additional parameters, launching it on desktop in cooperative or in Modal mode.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the Application to be executed. Application must be defined in the Core databse.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Additional parameters passed to the application.
Required?
false
Position?
2
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Icon of the executed application (used for titlebar and in the Sitecore taskbar on the desktop)
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Causes the application to show in new browser modal window or modal overlay if used in Sitecore 7.2 or later.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Title of the window the app opens in.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Width of the modal window.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Height of the modal window.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
Help Author: Adam Najmanowicz, Michael West
Show Content Editor in new window (or as an overlay in modal mode in Sitecore 7.2+) with "/sitecore/templates" item selected.
Show Content Editor as a new application on desktop with "/sitecore/content/home" item selected.
Shows Sitecore Sheer control as a modal dialog.
Show-ModalDialog -Control <String> [-Parameters <Hashtable>] [-HandleParameters <Hashtable>] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
Show-ModalDialog -Url <String> [-HandleParameters <Hashtable>] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
Shows Sitecore Sheer control as a modal dialog. If control returns a value - the value will be passed back as the result of the command execution.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Name of the Sitecore Sheer control to show
A fully formed URL that constitutes a control execution request.
Hashtable of parameters to pass to the control in the url.
Title of the control dialog.
Width of the control dialog.
Height of the control dialog.
The input type is the type of the objects that you can pipe to the cmdlet.
Sitecore.Data.Items.Item
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Sends output to an interactive table in a separate window.
Show-ListView [-PageSize <Int32>] [-Modal] [-ActionData <Object>] [-ViewName <String>] [-ActionsInSession] [-Show <None | SharedExport | Filter | PagingAlways | SharedActions | StatusBar | All>] [-InfoTitle <String>] [-InfoDescription <String>] [-MissingDataMessage <String>] [-Icon <String>] -Data <Object> [-Property <Object[]>] [-Title <String>] [-Width <Int32>] [-Height <Int32>]
The Show-ListView command sends the output from a command to a grid view window where the output is displayed in an interactive table. Because this command requires a user interface, it does not work in a non-interactive scenarios like within web service calls. You can use the following features of the table to examine your data: -- Sort. To sort the data, click a column header. Click again to toggle from ascending to descending order. -- Quick Filter. Use the "Filter" box at the top of the window to search the text in the table. You can search for text in a particular column, search for literals, and search for multiple words. -- Execute actions on selected items. To execute action on the data from Show-ListView, Ctrl+click the items you want to be included in the action and press the desired action in the "Actions" chunk in the ribbon. -- Export contents of the view in XML, CSV, Json, HTML or Excel file and download that onto the user's computer. The downloaded results will take into account current filter and order of the items.
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Number of results shown per page.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If this parameter is provided Results will show in a new window (in Sitecore 6.x up till Sitecore 7.1) or in a modal overlay (Sitecore 7.2+)
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Additional data what will be passed to the view. All actions that are executed from that view window will have that data accessible to them as $actionData variable.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
View signature name - this can be used by action commands to determine whether to show an action or not using the Show/Enable rules.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If this parameter is specified actions will be executed in the same session as the one in which the command is executed.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Shows UI elements selectively in the results dialog -- All - shows all UI elements automatically - default value -- SharedExport - shows export filters that are not specific to this very -ViewName report (left-most ribbon panel) -- Filter - shows filter panel -- PagingAlways - shows paging when list is shorter than the page specified -- SharedActions - shows actions that are not specific to this very
-ViewName report (right-most ribbon panel) -- StatusBar - shows status bar.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Title on the panel that appears below the ribbon in the results window.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Description that appears on the panel below the ribbon in the results window.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
If no Items were provided for -Data parameter the message provided in this parameter will be shown in the middle of the List View dialog to notify users of the lack of items to display.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Icon of the result window. (Shows in the top/left corner and on the Sitecore taskbar).
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Data to be displayed in the view.
Required?
true
Position?
named
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
Specifies the object properties that appear in the display and the order in which they appear. Type one or more property names (separated by commas), or use a hash table to display a calculated property.
The value of the Property parameter can be a new calculated property. To create a calculated, property, use a hash table. Valid keys are: -- Name (or Label) <string> -- Expression <string> or <script block>
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Title of the results window.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Width of the results window. Only applicable when also using the -Modal
switch.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
Height of the results window. Only applicable when also using the -Modal
switch.
Required?
false
Position?
named
Default Value
Accept Pipeline Input?
false
Accept Wildcard Characters?
false
The input type is the type of the objects that you can pipe to the cmdlet.
System.Management.Automation.PSObject
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West
This command formats information about Sitecore items in a table. The Get-ChildItem command gets objects representing the items. The pipeline operator (|) passes the object to the Show-ListView command. Show-ListView displays the objects in a table.
This command formats information about Sitecore items in a table. The Get-ItemReferrer command gets all references of the "Sample Item" template. The pipeline operator (|) passes the object to the Show-ListView command. Show-ListView displays the objects in a table. The Properties are not displaying straight properties but use the Name/Expression scheme to provide a nicely named values that like in the case of languages which are aggregarde form the "Languages" property.
The following demonstrates the use of a custom object used in the report. Notice that a custom Icon can be set.
Out-GridView
Format-Table
Shows a user a confirmation request message box.
Show-Confirm [-Title] <String>
Shows a user a confirmation request message box. Returns "yes" or "no" based on user's response. The buttons that are shown to the user are "OK" and "Cancel".
© 2010-2019 Adam Najmanowicz, Michael West. All rights reserved. Sitecore PowerShell Extensions
Text to show the user in the dialog.
Required?
true
Position?
1
Default Value
Accept Pipeline Input?
true (ByValue)
Accept Wildcard Characters?
false
The output type is the type of the objects that the cmdlet emits.
System.String
Help Author: Adam Najmanowicz, Michael West