Plumber is a configuration viewer for Sitecore Commerce, a bit like showconfig.aspx
in Sitecore but with a more visual interface and built-in search capabilities.
Checking what happens in Sitecore Commerce can sometimes be a bit complicated. This tool will give you insight into how the pipelines are configured, which blocks are used and how the policies are configured per environment.
Plumber is a Vue single page application. Built for production, you can use it with any web server. It doesn't require any server side technology for itself.
A small introduction: https://commerceservertips.com/introducing-plumber-the-configuration-viewer-for-sitecore-commerce-2/
Plumber is compatible with:
- Sitecore Commerce 8.2.1
- Sitecore Commerce 9 and up.
If you're using Sitecore Commerce 8.2.1 see: Using Plumber with Sitecore Commerce 8.2.1
You don't have to install Plumber to use it: you can use the hosted version on https://vwr.plumber-sc.com. You do need to configure Sitecore Identity Server and configure your Commerce Engines that you want Plumber to have access to.
- Configuring Identity Server for Sitecore Commerce 9 for hosted Plumber
- Configuring Identity Server for Sitecore Commerce 9.1 for hosted Plumber
- Configuring your commerce engine for hosted Plumber
You can use the Settings dialog in Plumber to change:
- the url of the engine you are connecting to;
- the url of the Sitecore Identity Server you are connecting to;
- the client id you are using when connecting with Identity Server;
Plumber-sc uses Sitecore Identity Server to get an authentication token, used to authenticate against the commerce engine. You need to add plumber-sc as a client in the configuration of Identity Server.
You can find Identity Server's configuration in the appsettings.json
file in the wwwroot
folder of Sitecore Identity Server.
Open the file and add the following to the Clients
section:
{
"ClientId": "Plumber",
"ClientName": "Plumber",
"AccessTokenType": 0,
"AccessTokenLifetimeInSeconds": 3600,
"IdentityTokenLifetimeInSeconds": 3600,
"AllowAccessTokensViaBrowser": true,
"RequireConsent": false,
"RequireClientSecret": false,
"AllowedGrantTypes": [
"implicit"
],
"RedirectUris": [
"https://vwr.plumber-sc.com/"
],
"PostLogoutRedirectUris": [
"https://vwr.plumber-sc.com/"
],
"AllowedCorsOrigins": [
"https://vwr.plumber-sc.com/"
],
"AllowedScopes": [
"openid",
"dataEventRecords",
"dataeventrecordsscope",
"securedFiles",
"securedfilesscope",
"role",
"EngineAPI"
]
},
This configuration sets up Identity Server to allow authentication from clients authenticating with client id Plumber
coming from https://vwr.plumber-sc.com/
.
In Sitecore 9.1, Identity Server is used for the whole platform. This brought about a change in the configuration file going from JSON to XML.
You can find Identity Server's configuration in the \Config\production\
folder where Sitecore Identity Server was installed.
Create a new file in this folder called Plumber.IdentityServer.Host.xml
and paste the the following xml:
<?xml version="1.0" encoding="utf-8"?>
<Settings>
<Sitecore>
<IdentityServer>
<Clients>
<PlumberClient>
<ClientId>Plumber</ClientId>
<ClientName>Plumber</ClientName>
<AccessTokenType>0</AccessTokenType>
<AllowOfflineAccess>true</AllowOfflineAccess>
<AlwaysIncludeUserClaimsInIdToken>false</AlwaysIncludeUserClaimsInIdToken>
<AccessTokenLifetimeInSeconds>3600</AccessTokenLifetimeInSeconds>
<IdentityTokenLifetimeInSeconds>3600</IdentityTokenLifetimeInSeconds>
<AllowAccessTokensViaBrowser>true</AllowAccessTokensViaBrowser>
<RequireConsent>false</RequireConsent>
<RequireClientSecret>false</RequireClientSecret>
<AllowedGrantTypes>
<AllowedGrantType1>implicit</AllowedGrantType1>
</AllowedGrantTypes>
<RedirectUris>
<RedirectUri1>{AllowedCorsOrigin}/auth/callback</RedirectUri1>
</RedirectUris>
<PostLogoutRedirectUris>
<PostLogoutRedirectUri1>{AllowedCorsOrigin}</PostLogoutRedirectUri1>
</PostLogoutRedirectUris>
<AllowedCorsOrigins>
<AllowedCorsOrigins1>https://vwr.plumber-sc.com</AllowedCorsOrigins1>
</AllowedCorsOrigins>
<AllowedScopes>
<AllowedScope1>openid</AllowedScope1>
<AllowedScope2>EngineAPI</AllowedScope2>
<AllowedScope3>postman_api</AllowedScope3>
</AllowedScopes>
<UpdateAccessTokenClaimsOnRefresh>true</UpdateAccessTokenClaimsOnRefresh>
</PlumberClient>
</Clients>
</IdentityServer>
</Sitecore>
</Settings>
This configuration sets up Identity Server to allow authentication from clients authenticating with client id Plumber
coming from https://vwr.plumber-sc.com
. If you're running plumber-sc on a different port you need to adjust these settings.
To configure your engine to allow Plumber, you add plumber-sc as an allowed origin. Open config.json
in the wwwroot
folder of your commerce engine and add the url of hosted Plumber (https://vwr.plumber-sc.com
) to the AllowedOrigins
section. It should look something like this:
"AllowedOrigins": [
"https://localhost:4200",
"http://localhost:4200",
"https://vwr.plumber-sc.com"
],
This document describes two ways of installing Plumber: as an IIS website or running it in development mode directly from NPM.
You can download the latest compiled version of Plumber-sc from releases. The file release.zip
contains a pre-compiled version of Plumber that you can install as an IIS site.
Make sure you have installed the IIS Rewrite module (https://www.iis.net/downloads/microsoft/url-rewrite)
To use IIS to host Plumber-sc:
- In IIS Manager, create a new website called
plumber-sc
, use port8080
and set the folder to host the application. - Copy the contents of
release.zip
to the folder you specified in the previous step. - Configure Plumber, Sitecore Identity Server and the commerce engine. Instructions are in the following paragraphs.
If you want to run plumber-sc in development mode open a command prompt, navigate to the root of the repository and run npm run dev
. This will start the tool at http://localhost:8080
in development mode. Any change you make in the code will automatically trigger a rebuild.
Configuration of Plumber is done in config.json
located in the static
directory.
The default config.json looks like this:
{
"EngineUri": "http://localhost:5000",
"IdentityServerUri": "http://localhost:5050",
"ClientId": "Plumber",
"PlumberUri": "http://localhost:8080"
}
The following table describes the parameters and their default values.
Parameter | Default | Description |
EngineUri | "http://localhost:5000" | Base uri of the commerce engine |
IdentityServerUri | "http://localhost:5050" | Base uri of the Sitecore Identity Server. Identity Server is used to retrieve a token to connect to Commerce Engine. This means you need a user account to be able to access it. If you are using Sitecore Commerce 9.1 enter the url for Sitecore Identity Server which was installed when using Sitecore XP 9.1. If you're using Sitecore Commerce 8.2.1 leave this empty. See also: Using Plumber with Sitecore Commerce 8.2.1 |
ClientId | "Plumber" | Client id used to connect to identity server. See the section on how to configure Identiy Server. |
PlumberUri | "http://localhost:8080" | Base uri of the commerce engine |
There are different ways to configure Sitecore Identity Server based on the version:
Plumber-sc uses Sitecore Identity Server to get an authentication token, used to authenticate against the commerce engine. You need to add plumber-sc as a client in the configuration of Identity Server.
You can find Identity Server's configuration in the appsettings.json
file in the wwwroot
folder of Sitecore Identity Server.
Open the file and add the following to the Clients
section:
{
"ClientId": "Plumber",
"ClientName": "Plumber",
"AccessTokenType": 0,
"AccessTokenLifetimeInSeconds": 3600,
"IdentityTokenLifetimeInSeconds": 3600,
"AllowAccessTokensViaBrowser": true,
"RequireConsent": false,
"RequireClientSecret": false,
"AllowedGrantTypes": [
"implicit"
],
"RedirectUris": [
"http://localhost:8080",
"http://localhost:8080/?"
],
"PostLogoutRedirectUris": [
"http://localhost:8080",
"http://localhost:8080/?"
],
"AllowedCorsOrigins": [
"http://localhost:8080/",
"http://localhost:8080"
],
"AllowedScopes": [
"openid",
"dataEventRecords",
"dataeventrecordsscope",
"securedFiles",
"securedfilesscope",
"role",
"EngineAPI"
]
},
This configuration sets up Identity Server to allow authentication from clients authenticating with client id Plumber
coming from http ://localhost:8080
. If you're running plumber-sc on a different port you need to adjust these settings.
In Sitecore 9.1, Identity Server is used for the whole platform. This brought about a change in the configuration file going from JSON to XML.
You can find Identity Server's configuration in the \Config\production\
folder where Sitecore Identity Server was installed.
Create a new file in this folder called Plumber.IdentityServer.Host.xml
and paste the the following xml. Don't forget to replace http://localhost:8080
with the url where you are hosting your copy of Plumber:
<?xml version="1.0" encoding="utf-8"?>
<Settings>
<Sitecore>
<IdentityServer>
<Clients>
<PlumberClient>
<ClientId>Plumber</ClientId>
<ClientName>Plumber</ClientName>
<AccessTokenType>0</AccessTokenType>
<AllowOfflineAccess>true</AllowOfflineAccess>
<AlwaysIncludeUserClaimsInIdToken>false</AlwaysIncludeUserClaimsInIdToken>
<AccessTokenLifetimeInSeconds>3600</AccessTokenLifetimeInSeconds>
<IdentityTokenLifetimeInSeconds>3600</IdentityTokenLifetimeInSeconds>
<AllowAccessTokensViaBrowser>true</AllowAccessTokensViaBrowser>
<RequireConsent>false</RequireConsent>
<RequireClientSecret>false</RequireClientSecret>
<AllowedGrantTypes>
<AllowedGrantType1>implicit</AllowedGrantType1>
</AllowedGrantTypes>
<RedirectUris>
<RedirectUri1>{AllowedCorsOrigin}/auth/callback</RedirectUri1>
</RedirectUris>
<PostLogoutRedirectUris>
<PostLogoutRedirectUri1>{AllowedCorsOrigin}</PostLogoutRedirectUri1>
</PostLogoutRedirectUris>
<AllowedCorsOrigins>
<AllowedCorsOrigins1>http://localhost:8080</AllowedCorsOrigins1>
</AllowedCorsOrigins>
<AllowedScopes>
<AllowedScope1>openid</AllowedScope1>
<AllowedScope2>EngineAPI</AllowedScope2>
<AllowedScope3>postman_api</AllowedScope3>
</AllowedScopes>
<UpdateAccessTokenClaimsOnRefresh>true</UpdateAccessTokenClaimsOnRefresh>
</PlumberClient>
</Clients>
</IdentityServer>
</Sitecore>
</Settings>
This configuration sets up Identity Server to allow authentication from clients authenticating with client id Plumber
coming from http://localhost:8080
. If you're running plumber-sc on a different port you need to adjust these settings.
There are some small things you need to configure in your commerce engine to so Plumber-sc can access it.
First, you need to add plumber-sc as an allowed origin. Open config.json
in the wwwroot
folder of your commerce engine and add the url (by default http://localhost:8080
) to the AllowedOrigins
section. It should look something like this:
"AllowedOrigins": [
"https://localhost:4200",
"http://localhost:4200",
"http://localhost:8080",
"http://sxa.storefront.com"
],
If you're using SC 8.2.1 there are a couple of things you need to change:
- As 8.2.1 doesn't use Sitecore Identity Server you can leave the
IdentityServerUri
blank; - Because the commerce engine is probably not using https, change the
EngineUri
to http://localhost:5000
A default config.json
will look like this:
{
"EngineUri": "http://localhost:5000",
"IdentityServerUri": "",
"ClientId": "Plumber",
"PlumberUri": "http://localhost:8080"
}
As Plumber is doing a cross-site request you need to enable CORS support in your commerce engine, which means you will need to rebuild and deploy it.
To add CORS support do the following:
In the Sitecore.Commerce.Engine
project change the following in startup.cs
:
-
In the
ConfigureServices
method add the following line:
services.AddCors();
-
In the
Configure
method add the following line:
app.UseCors(builder => builder.WithOrigins("http://localhost:8080").AllowCredentials().AllowAnyHeader().AllowAnyMethod());
If you want to change something in the app, below you will find instructions on how to build the project below.
# install dependencies
npm install
# serve with hot reload at localhost:8080
npm run dev
# build for production with minification
npm run build
# build for production and view the bundle analyzer report
npm run build --report
# run unit tests
npm run unit
# run e2e tests
npm run e2e
# run all tests
npm test
For a detailed explanation on how things work, check out the guide and docs for vue-loader.