Last Updated on February 1, 2025 by sandeeppote
On a XC installed instance you might want to customize the XC by adding your own Entities, Components, Entity Views etc. In this topic I will describe how to setup your development environment to add your custom plugin.
This topic assumes a Sitecore CMS and Commerce engine version 9.3 are running under IIS. I am using Visual Studio 2019.
Steps to setup-
Step 1- Extract Commerce Engine SDK
- Copy the downloaded SDK Sitecore.Commerce.Engine.SDK.5.0.76.zip on your development folder.
- If not available you may download Packages for On Premise WDP 2020.01-5.0.145
- Extract the commerce package and then extract Sitecore.Commerce.Engine.SDK.5.0.76.zip
data:image/s3,"s3://crabby-images/9d6ee/9d6ee439e66b2c19fdde30858a6b25dce2a5cda7" alt="Extracted files"
Step 2 – Setup Visual Studio Solution
- Open the Solution, by default this is Customer.Sample.Solution.sln
- Ensure Package Source is configured for Commerce- https://sitecore.myget.org/F/sc-commerce-packages/api/v3/index.json
- Build the Solution. It should restore the package and build successfully.
- (optional)Rename the Solution name. In this case I have renamed to Retail.Commerce
- (Optional) Create a solution folder “Project” and move Sitecore.Commerce.Engine project
- (Optional) Rename “Sitecore.Commerce.Engine” project to “Retail.Commerce.Engine”. Re reference AdventureWorks, Habitat and BrainTree projects if required. Adjust/rename namespace in classes.
- (Optional) Create Foundation and Feature projects. Build the solution again.
data:image/s3,"s3://crabby-images/294f9/294f9e1dfbe22f7f80460ecb6e8337c49f69ad29" alt="CompileVS"
Step 3 – Generate Development Certificate
Generate development certificate using script “New-DevelopmentCertificate”, so the localhost runs on SSL(https)
- Open powershell script and navigate to scripts folder.
- Execute New-DevelopmentCertificate script
- Change the Path($certificateOutputDirectory) if required. Certificate should be copied to \src\Project\Engine\code\wwwroot
data:image/s3,"s3://crabby-images/a1ed4/a1ed4699b0478bd2b57d6a395a2964b512c173e2" alt="generate_certificate"
data:image/s3,"s3://crabby-images/67ac4/67ac4c62c8869a385fb4c0699dfedfd06d0a5f51" alt="generate_certificate1"
Step 4 – Update configuration
- Change environment in Engine project/wwwroot/config.json file to HabitatAuthoring
- Change “SitecoreIdentityServerUrl”: “https://storefront930.identityserver.local”,
- Add the site name in AllowedOrigins in config.json
- Open Global.json in wwwroot/bootstrap folder in Engine project
- Update SQL Server, UserName and Password in EntityStoreSqlPolicy
- Check the database name
data:image/s3,"s3://crabby-images/4bd2c/4bd2cdb84655725b077a62624f14c907256e734a" alt="globalconfig1"
7. Update Host to your site host name in SitecoreConnectionPolicy
data:image/s3,"s3://crabby-images/f0d8b/f0d8bd307d7567aa4e3107f6ab5eeb2379b0eba7" alt="globalconfig2"
Note: You may copy the config.json and gloal.json file from Authoring Site hosted in IIS to your project, but to better understand the changes required I have noted the changes.
Step 5 – Update allowed origins in Identity Site
- Open Sitecore.Commerce.IdentityServer.Host.xml file. Should be in /config/production/Sitecore.Commerce.IdentityServer.Host.xml
- Navigate to section <CommerceEngineConnectClient><AllowedCorsOrigins>
- Add https://localhost:5000 to the
Step 6 – Ready for running the Engine
- Set Engine as your Startup Project
- Change the debug profile to “Engine” instead of “IIS Express”
- In IIS stop Authoring site. i.e. for your default instance it might be CommerceAuthoring_sc930 site
- Run the Engine from Visual Studio. This will open the console.
- Once the plugins are instantiated, it should listen to 5000 port. At this point you have configured Engine to run/debug from Visual Studio. Any calls from the business tool should be received by engine and console should be able to show the request that’s been received.
data:image/s3,"s3://crabby-images/78a1b/78a1bb2299b4c0431bb13d92bf62587441226634" alt="RunVSComm1"
data:image/s3,"s3://crabby-images/c0f7e/c0f7e0802d4ead9844f43f9c0714cb7959c65985" alt="RunVSComm3"
And here we have business tool sending request to engine running on Visual Studio, see GetNavigationView() been called in console-
data:image/s3,"s3://crabby-images/2d58f/2d58ff9dbf781ca7d0935213ad4197f702b1458d" alt="Bixfx"
data:image/s3,"s3://crabby-images/c4408/c440887e42d2cf01c7627fa670b3afe45d31b322" alt="RunVSComm4"
0 Comments
2 Pingbacks