Newer Version Available
ExperienceBundle for Experience Builder Sites
Before the Summer ’19 release (API version 45.0 and earlier), the Network, CustomSite, and SiteDotCom metadata types combined to define an Experience Builder site. However, retrieving the SiteDotCom type produces a binary .site file that isn’t human readable. By retrieving the ExperienceBundle type instead of SiteDotCom, you can extract and edit granular site metadata in a human-readable format, contained in a three-level folder structure.
Limitations
- Managed packages aren’t supported.
ExperienceBundle Structure
When you retrieve ExperienceBundle, the data is stored in a three-level folder structure.
The experiences folder contains a folder for each Experience Builder
site in your org. Each site_name
folder—customer_service in this example—contains
subfolders that define the site and represent the different elements that you access in Experience Builder. Each
subfolder has .json files that contain the properties that you can edit on your local
machine or scratch org and then deploy.
| Folder | Contents |
|---|---|
| brandingSets | branding_set_name.json defines the site’s branding set properties. |
| config |
|
| routes | Contains one file per page, named page_name.json, which defines the URL and other route-related information. |
| themes | Contains one file per theme, named theme_name.json, which defines the theme. |
| variations | Contains one file per variation, named
experienceVariation_name.json. You can use an experience variation to change the default behavior of an Experience Builder site based on the audience, such as branding, page variations, component visibility, or component attributes. |
| views | Contains one file per view, named view_name.json. Each file defines an SPA view, which is equivalent to a page to the end user. A view consists of regions that contain other regions or components in the rendered page. |
For a complete definition of ExperienceBundle and the files it includes, see the Metadata API Developer Guide.
Enable the ExperienceBundle Metadata Type
After you enable ExperienceBundle for Aura sites, Metadata API calls (retrieve and deploy) and Salesforce DX operations (pull, push, and status) use the ExperienceBundle type instead of SiteDotCom.
If you use change sets to deploy your site, the list of dependencies includes two items of type Site.com—MySiteName and MySiteName1. MySiteName1 now represents ExperienceBundle instead of SiteDotCom.
- From Setup, enter Digital Experiences in the Quick Find box, and then select Settings.
- Select Enable ExperienceBundle Metadata API.
- Save your changes.
Alternatively, you can enable this feature when creating a scratch org using a scratch org definition file. (See the Metadata Coverage report.)
1{
2 "orgName": "Sample Org",
3 "edition": "developer",
4 "features": [
5 "COMMUNITIES"
6 ],
7 "settings": {
8 "experienceBundleSettings": {
9 "enableExperienceBundleMetadata": true
10 },
11 "communitiesSettings": {
12 "enableNetworksEnabled": true
13 }
14 }
15}Retrieve and Deploy ExperienceBundle Using Metadata API
In Metadata API, a manifest file defines the components that you’re trying to retrieve. This example shows a package.xml manifest file for retrieving an Experience Builder site using ExperienceBundle instead of SiteDotCom.
1<?xml version="1.0" encoding="UTF-8"?>
2<Package xmlns="http://soap.sforce.com/2006/04/metadata">
3 <types>
4 <members>*</members>
5 <name>CustomSite</name>
6 </types>
7 <types>
8 <members>*</members>
9 <name>ExperienceBundle</name>
10 </types>
11 <types>
12 <members>*</members>
13 <name>Network</name>
14 </types>
15 <version>46.0</version>
16</Package>After you retrieve the .zip file, unzip it to access and edit the files.
Retrieve and Deploy ExperienceBundle with Salesforce DX
Salesforce Developer Experience (DX) is a set of tools that streamlines the entire development lifecycle. It improves team development and collaboration, facilitates automated testing and continuous integration, and makes the release cycle more efficient and agile.
- Retrieve all the Experience Builder sites in your org using sf project retrieve start
- Deploy updates using sf project deploy start
- Check for conflicts or changes on the server using sf project deploy preview or sf project retrieve preview
- Retrieve a list of available templates using sf community list template
- Create a site using sf community create
- Publish an Experience Builder site using sf community publish