This guide walks you through the necessary steps to configure and perform the sync.
Steps to sync data:
- Sync opt-in/out status 
- Sync contacts 
- Sync customer data 
- Import product catalog 
- Sync orders 
Sync opt in/out status
Choose whether you want to sync opt-in and opt-out status and how this data is stored in NetSuite.
Learn about integration behaviour for syncing opt-in/out status in NetSuite integration behaviour.
- Expand the Sync opt in/out status drop-down menu, and choose Yes (to sync) or No (not to sync). 
 
 If you choose No, and don’t want to sync opt-ins, you can move forward to Step 8.
 
- Expand the Choose in what directions(s) opt in state is synced drop-down menu, then choose the sync direction. - From NetSuite to Dotdigital 
- From Dotdigital to NetSuite 
- Bi-directional 
 Sync updates from either system.
 
- Expand the Select the entities you want to sync opt-in state for to select the entities you want to sync opt-in state for, choose from customers, leads, prospects, and contacts or combinations of. 
- Select NEXT. 
- Expand the Opt in data held in drop-down menu, and choose how you want to store your opt-in and opt-out data in NetSuite. - NetSuite’s subscription status - Use the default mechanism in NetSuite for the marketing subscription status. 
- Using a field 
 The opt-in and opt-out statuses are stored in a field on the contact and customer records.
 
If you selected Subscription Status then skip to step 8, otherwise continue to the steps below.
Holding opt-in and opt-out status in a field
- Expand the Default opt in status drop-down menu and choose a default opt in status from: - None 
 No opt-in status is set. Each contact or customer has their opt-in and opt-out status set in a field.
- Opted in 
 All customers and contacts are opted in unless explicitly opted out by a field value.
- Opted out 
 All customers and contacts are opted out unless explicitly opted in by a field value.
 
- Expand the Opt in status field drop-down menu, then choose the property field that holds your contacts’ and customers’ opt-in and opt-out status. 
- Expand the Value type drop-down menu, then choose the field's data type. - Boolean value 
 A Boolean (true/false) value is held in the field.
- Specific value 
 Text with specific values is held in the field.
 
- If you chose your data type as Boolean values with no assumed default opt-in or opt-out status, you must now choose what the true value indicates in the field. 
 
 Expand the Checked value represents drop-down menu and select either Opted in or Opted out.
 
- If you chose your data type as Specific values, enter the text value precisely as it appears in NetSuite to indicate your opt-in value and opt-out value. 
- Select NEXT. 
Sync contacts
- For Contact syncing, expand the Sync contact data drop-down menu and choose either Yes (to sync contacts) or No (not to sync). 
- Select NEXT. 
- To choose the direction that you sync contact data, expand the Contact sync option drop-down menu, then choose the direction you want to sync contact data. - Bi-directional 
 Contact data is synced from both NetSuite and Dotdigital.
- From NetSuite to Dotdigital 
 Contact data is synced only from NetSuite to Dotdigital.
- From Dotdigital to NetSuite 
 Contact data is synced only from Dotdigital to NetSuite.
 
- When syncing data, the integration must know which system holds the master data initially. If conflicting data is found in the initial sync, it takes the data from the master system and overwrites the other system. 
 
 Expand the Master system drop-down menu, then choose your master system.- NetSuite 
 NetSuite data overwrites any conflicting records in Dotdigital during the initial sync.
- Dotdigital 
 Dotdigital data overwrites any conflicting records in NetSuite during the initial sync.
 
 ⚠️ You must choose the correct master system, or you will lose data.
 
 
- Select NEXT. 
Contact field mapping
You can map fields from a Dotdigital data field to a NetSuite field, and we automatically reverse these to map the other way when required.
In addition to the NetSuite entities fields and custom fields, we also list some calculated fields which are indicated by the encapsulating [[ ]] , such as [[ Firstname Lastname ]].
These Dotdigital data fields must be mapped:
- EMAIL 
- FIRSTNAME 
- LASTNAME 
You should map the following NetSuite fields if you want to use or set them:
- Category (category) - to a text field 
By default, we pre-populate the minimum required fields that need mapping. We recommend only mapping fields you want to use in Dotdigital rather than all fields on the entity.
To set up field mapping:
- On the Contact field mappings, use the drop-down menus to map your Dotdigital data fields to your NetSuite contact fields. 
 
 Your mappings are tested to ensure the minimum required fields are mapped. If an issue is shown, adjust your mappings to correct this.
- Once testing is successfully completed, select NEXT. 
If you need to filter to a subset of contacts
⚠️ Important
These steps must be performed by a developer.
The integration uses SuiteQL to access your NetSuite data, and we automatically filter for customer entities that have an email and are not duplicates. Optionally you can add your own filters if you need to limit the data further.
- For Contacts SuiteQL filter, enter additional filter criteria, using SuiteQL WHERE clause syntax against the contacts table (c). 
 
 The filter will be something like BUILTIN.DF(c. {The field id} ) = ' {Value to filter on} ' for example:- c.country = ‘US’ 
- BUILTIN.DF(c.myCustomField) = ‘Region A’ 
 
 - If you specify a filter, it is tested and must work before you can proceed. 
 
- Select NEXT. 
Data alignment
The integration can align the contact data from the master system to the other system when first created. This can be useful to ensure your data is fully populated in the non-master system. However, the master system's data will overwrite any conflicting data in the non-master system.
- Expand the Initial contact data alignment drop-down menu, and choose either Yes or No. - No 
 Only data changed from this point is synced.
- Yes 
 All data from the master system is synced to the non-master system.
 
⚠️ Warning
You must choose the correct option, or you will lose data.
Sync customer data
In this section we set up the integration to sync customer data with NetSuite. Customer entities in NetSuite includes customers, prospects and leads.
- For Customer syncing, expand the Sync customer data drop-down menu and choose either Yes (to sync) or No (not to sync). 
- Select NEXT. 
- To choose the direction that you sync customer data, expand the Contact sync options drop-down menu, then choose the direction you want to sync customer data. - Bi-directional 
 Customer entity data is synced from both NetSuite and Dotdigital.
- From NetSuite to Dotdigital 
 Customer entity data is synced only from NetSuite to Dotdigital.
- From Dotdigital to NetSuite 
 Customer entity data is synced only from Dotdigital to NetSuite.
 
- When syncing data, the integration must know which system holds the master data initially. If conflicting data is found in the initial sync, it will take the data from the master system and overwrite the other system. Choose from. 
 
 Expand the Master system drop-down menu, then choose your master system.- NetSuite 
 NetSuite data overwrites any conflicting records in Dotdigital during the initial sync.
- Dotdigital 
 Dotdigital data overwrites any conflicting records in NetSuite during the initial sync.
 - ⚠️ You must choose the correct master system, or you will lose data. 
 
 
- Select NEXT. 
- For Customer types to sync, you can choose between People, Companies (B2B) or both. 
 
 If you choose to sync Companies then you must ensure you have custom data fields available in Dotdigital to map the NetSuite fields isPerson and Companyname to.
 
- For Customer stages to sync, you can choose the stages you want to sync customer data for. Choose between Prospects, Leads, and Customers. 
- Select NEXT. 
Customer default statuses
- For each contact entity type (Prospect, Lead and Customer) you must choose a default status to set on the record. Expand the relevant drop-down menu, then choose the default status you want to apply. 
- Select NEXT. 
Customer default category
Earlier versions of NetSuite allowed leads, prospects and customers to be created without providing a value for their Category. However, later versions made this a required field. Therefore, if the integration needs to update the opt-in or opt-out status for a record without a category, it must apply a default category, or it's unable to update.
- Expand the Default category drop-down menu, then choose a default category. 
- Expand the Use default category when missing drop-down menu, then choose whether or not the integration is allowed to apply the default category when required: - Yes 
 The default category is applied when required.
- No - The update is skipped if no category is present on the record. 
 
- Select NEXT. 
Customer data alignment
The integration can align the customer entity data from the master system to the other system when first created. This can be useful to ensure your data is fully populated in the non-master system. However, the master system's data will overwrite any conflicting data in the non-master system.
- Expand the Initial contact data alignment drop-down menu, and choose either Yes or No. - No 
 Only data changed from this point is synced.
- Yes 
 All data from the master system is synced to the non-master system.
 
⚠️ Warning
You must choose the correct option, or you will lose data.
Customer field mapping
You can map fields from a Dotdigital data field to a NetSuite field, and we automatically reverse these to map the other way when required. In addition to the NetSuite entities fields and custom fields, we also list some calculated fields which are indicated by the encapsulating [[ ]] , such as [[ Firstname Lastname ]].
These Dotdigital data fields must be mapped:
- Email 
- First name 
- Last name 
If syncing companies then the following NetSuite fields must be mapped:
- Company name - to a text field. 
- Is individual - to a Yes/No field. 
You should map the following NetSuite fields if you want to use or set them:
- Category - to a text field. 
- Entity status- to a text field. 
By default, we pre-populate the minimum required fields that need mapping. We recommend only mapping fields you want to use in Dotdigital rather than all fields on the entity.
To set up field mapping:
- On the Customer field mappings, use the drop-down menus to map your Dotdigital data fields to your NetSuite customer fields. 
 
- Your mappings are checked against the required minimum mappings. If an issue is shown, adjust your mappings to correct this. 
- Select NEXT. 
If you need to filter to a subset of contacts
⚠️ Important
These steps must be performed by a developer.
The integration uses SuiteQL to access your NetSuite data, and we automatically filter for contacts entities that have an email and are not duplicates. Optionally you can add your own filters if you need to limit the data further.
- For Contact's SuiteQL filter, enter additional filter criteria, using SuiteQL WHERE clause syntax against the customers table (c). 
 
 The filter will be something like BUILTIN.DF(c. {The field id} ) = ' {Value to filter on} ' for example:- c.country = ‘US’ 
- BUILTIN.DF(c.myCustomField) = ‘Region A’ 
 
 - If you specify a filter, it is tested and must work before you can proceed. 
 
- Select NEXT. 
Import product catalog
In this section, we configure how items sync from NetSuite to Dotdigital as a product catalog. You must complete this step if you want to make the most of Dotdigital’s ecommerce features.
Learn more about Dotdigital ecommerce features.
- On Product catalog sync, expand the Sync product catalog drop-down menu, then choose Yes (to sync) or No (not to sync). 
- Select NEXT. 
 NetSuite lets you specify the prices of items in multiple currencies. However, Dotdigital’s product catalogs only store prices in a single currency.
- Expand the Catalog price currency drop-down menu, then choose the currency you want to use in Dotdigital. 
- You might not hold an online store URL and image URL for each item you want to sync. However, Dotdigital's ecommerce features require these to operate. You can specify default values to use if we cannot find a value for an item. 
 
 For Company or online store URL, enter the URL for your company or online store.
 
 For Fallback product image URL, enter the URL to use whenever we cannot map an item’s specific image.
 
- Select NEXT. 
- If you use NetSuite’s built-in ecommerce store, you can choose to filter products listed for sale online. 
 
 Expand the Sync only online products drop-down menu, then choose Yes or No.- Yes 
 Syncs only items flagged as online (isOnline = ‘T’ in SuiteQL) .
- No 
 Syncs all items available for syncing.
 
 
- For What product types do you want to sync, select the item types you want to sync into the product catalog. 
Optional: If you want to filter to a custom subset of items.
By default, the integration syncs all items matching the types you requested in the previous step.
However, you can specify additional filter criteria for each item type to further customise which items are included in the product catalog.
Requires NetSuite administrator knowledge.
- In the Product filters box, enter any additional filter criteria, using SuiteQL WHERE clause syntax against the items table (i), for example, i.shipindividually = ‘T’. 
 
 If you specify a filter, it is tested and must work before you can proceed.
 
- Select NEXT. 
- You must define the field mappings from Dotdigital’s product catalog fields to NetSuite's item fields. By default we define the minimum mappings required. 
 
 In addition to the NetSuite items fields and custom fields we list some calculated fields which are indicated by the encapsulating [[ ]] , such as [[ Price: Base Price]]. The calculated fields include mappings to the price types held against an item denoted as [[ Price: Price type name ]], which allow you to assign the price type you wish to the product catalog's price and specialPrice fields.
 - You must map the following Dotdigital product catalog fields: - image_path 
 Use [[ Blank ]] if you don't hold this in NetSuite, and the default image path is used.
- name 
- price 
- sku 
- url 
 Automatically set to your fallback store URL.
 
 - Enter the Product field mappings as required. 
 
- Select NEXT. 
Create new product catalog fields
If you need to sync custom data, for example, tech specs, from NetSuite that doesn’t yet exist in your product catalog, you can create new fields directly from the mapping screen.
- Select ADD NEW MAPPING. 
 A new row appears at the bottom of the table with field mappings.
- Enter a new value in the Product catalog fields column. 
 After entering the new value, an option Set to ‘Your entered value’ appears above the field. Select it to set the value.
 If you don’t select this option, your new field may not be saved and the box will appear blank.
- In the NetSuite item fields column, choose the NetSuite field you want to map. 
 Your new catalog field is mapped and ready to sync.
Sync orders
This section configures the syncing of order data to Dotdigital to enable Dotdigital’s ecommerce features.
- Expand the Sync orders drop-down menu, then choose whether you want to sync orders or not. - Yes - Sync orders. 
- No - Don’t sync orders. 
 
- Select NEXT. 
- Sometimes you may have a custom field on a sales order that better represents who made the purchase rather than using NetSuite’s associated customer record. For instance this could be that you are a B2B business and track the individual who made the order, rather than just using the default email associated with the company that made the order. 
 
 Expand the Alternative email field drop-down menu, then choose whether you want to to use an alternate email field to associate an order with.- No 
 Associate the order with the customer record it is linked to; choose this if you are not sure.
- Yes 
 Choose an alternate email field or link to a customer or contact field to associate the order with.
 
 
- If you selected Yes, select the custom field that you want the order associated with. We use the email address of any contact or customer to identify the contact in Dotdigital who will have the order associated with it. 
- Select NEXT. 
- Optionally, select any additional fields that are associated with a sales order that you want to add to an order record in Dotdigital. 
- Select NEXT. 
- The integration uses SuiteQL to access your NetSuite transaction data, and we automatically bring in any sales orders and cash sale transactions that can be associated by email address to a contact in Dotdigital. 
 
 Optionally you can add your own filters if you need to limit the data further using SuiteQL WHERE clause syntax against the transaction table which can be referred to using the table reference t. e.g. t.currency= 1.
 
- Select NEXT. 
Next steps

