Accelerator B2C Commerce Sync Cartridge - Source
Configuration
The B2C Commerce instance requires a service definition that must be configured to interact with the Mule API.
Uploading the service definition
The following instructions provide guidance on how to import and configure the service definition for a site called RefArch. If your site ID is different, you must edit the endpoints.xml file to adjust the references accordingly.
- In Business Manager, select Administration > Operations > Import & Export:
- Click Upload in the 'Import & Export Files' section.
- Click Choose File displayed in the 'Upload Import Files' section:
- Locate and select the endpoints.xmldefinition file in the 'cartridges' source directory.
- After you select the import file, click Upload to upload the import file:
Importing the service definition
The following instructions describe how to import the service definition leveraged by the Customer Sync Cartridge.
Note: You must first upload the endpoints.xml import file to Business Manager first, as described in the previous section.
- In Business Manager, select Administration > Operations > Import & Export:
- Click Import in the 'Services' section:
- Select the file named endpoints.xmland then click Next:
- After the import process validates the file, confirm that the file has validated without any errors and then click Next to continue:
- On the 'Import' step, select Merge as the import mode and then click Import to process the uploaded file:
- Allow the import file to complete its processing and then confirm that the import has succeeded:
Note: The 'Status' section shows the import progress of the file being processed. Click Refresh to update. A successful import has a process status of Success. You can ignore any warnings about "Communication logging" when importing to sandbox environments:
Configuring the Service Definition
The following describes how to configure the service definition for the cartridge so that it can communicate with the B2C Commerce Experience API deployed in CloudHub.
To change the credentials for all deployments:
- In Business Manager, select Administration > Operations > Services:
- Click the Credentials tab:
- Edit the mule.auth-RefArchservice credentials by clicking the credential name.
- If your site ID is not RefArch, update the suffix of the credential name and then replace RefArchwith your site name.
- Use the following properties to configure the credentials for the service:
| Property Name | Value | Description | 
|---|---|---|
| URL | http://replacehostname/api | Specify the URL to your B2C Commerce Experience API deployment | 
| User | Mule Integration API Client ID | Specify the Mule experience API client ID (use a dummy value if not known) | 
| Password | Mule Integration API Client Secret | Specify the Mule experience API client secret (use a dummy value if not known) | 
After the service credentials properties are updated, click Apply to save your changes, and then click the << Back to List button:
Adjusting your SiteId
Use the following instructions if your site ID is not RefArch and you did not edit the endpoints.xml file before importing.
- Select the Services tab.
- Edit the mule.auth-RefArchservice definition by clicking on the service name.
- Update the suffix of each service name and the log-prefix definition by replacing SiteId with your site name.
- Update the suffix of the credential name and replace *SiteId with your site name:
- Repeat steps 2-4 for the mule.rest-RefArchservice.
This completes the configuration. There is no need to modify the associated profile-mule profile.
Configure custom preferences
The Customers and Orders sync processes can be enabled or disabled by setting
the muleSyncCustomersEnabled and muleSyncOrdersEnabled custom preferences,
respectively. By default, the sync process will not execute if not set. To
create and set the preferences:
- Select Administration > Site Development > System Object Types
- Select SitePreferences.
- Click the Attribute Definition tab.
- Click New and define the following custom site attribute:ID: muleCustomerSyncEnabledDisplay Name: Sync Customers to MuleHelp Text: Enable or disable publishing of customer profile updates to MuleValue Type: Boolean 
- Click Apply
- Set the default value to Trueand click Apply
- Click << Back and repeat the above steps for the second attribute:ID: muleOrderSyncEnabledDisplay Name: Sync Orders to MuleHelp Text: Enable or disable publishing of new customer orders to MuleValue Type: Boolean 
- Click the Attribute Grouping tab.
- Add a new attribute group as follows:ID: MuleName: Mule SettingsDescription: Custom settigns for Mule integrations 
- Click apply and then click the Edit link for the new group
- Click the ellipsis (...) to the left of the Add button
- In the search area, type Mule and click Find
- Select both Mule custom preferences and click Select
- Click << Back to return to the Site Preferences object settings page
Configure custom properties
The synchronization process requires the addition of custom properties to
associate a master identifier with each of the Profile and Order objects.
These properties must be created as follows:
- Click Administration > Site Development > System Object Types
- Click on the Order object link
- Select the Attribute Definitions tab
- Click the New button and add the following attribute:ID: masterSalesOrderIdDisplay Name: Master Sales Order IDHelp Text: Identifies the master sales order an item is associated with.Value Type: String 
- Click Apply
- Select << Back to List and click on the Product object link
- Select the Attribute Definitions tab
- Click the New button and add the following attribute:ID: masterProductIdDisplay Name: Master Product IDHelp Text: Identifies the master product an item is associated with.Value Type: String 
- Click Apply
- Select << Back to List and click on the Profile object link
- Select the Attribute Definitions tab
- Click the New button and add the following attribute:ID: masterPartyRoleIdDisplay Name: Master Party Role IDHelp Text: Identifies the master party role a customer profile is associated with.Value Type: String 
- Click Apply
This completes the configuration.