HomeDev GuideAPI Reference
Dev GuideAPI ReferenceUser GuideGitHubNuGetDev CommunitySubmit a ticketLog In
GitHubNuGetDev CommunitySubmit a ticket

Connect for Campaign

The Optimizely Connect for Campaign add-on is part of Optimizely Connect for Marketing Automation, which connects Optimizely Content Management System, Optimizely Forms, and Optimizely Campaign.

With this add-on, marketers can collect visitor data and pass that on to Optimizely Campaign, for usage in campaign mailings.

Prerequisites

An Optimizely Content Management System (CMS) installation with Optimizely Forms, Optimizely Campaign, and the required Optimizely Connect for Marketing Automation.

Install

The Connect for Campaign MA connector is installed through the NuGet package EPiServer.ConnectForCampaign. See Add-ons platform compatibility for supported Optimizely versions.

Configure

Authenticate Connect for Campaign

Prerequisites

  • The user being used for the connector must have API privileges. If your user does not have API access privileges, you will need to submit a support ticket to create a user specifically for API access. Include the name of the client for whom you want the user created, and which API access is needed. In the case of the Connector, request SOAP API access. For security purposes, the user being granted access cannot be the same as a user that has general access rights to the client.
  • To find the Mandator ID (Client ID), access your Campaign client at the location below:
1441

To connect CMS with Optimizely Campaign, enter your authentication details  - Username, Password, Mandator ID (provided with your Optimizely Campaign setup) and a unique Connector Name, in the CMS admin view under CMS > Admin > Config > Optimizely Campaign.

975

📘

Note

You can have multiple instances of the Campaign connector. Click Add Connector to add another instance.

Connect Optimizely Forms with Optimizely Campaign

When the Optimizely Forms add-on is installed on the CMS website, you need to connect form fields with Optimizely Campaign, so that data from the specified fields can be sent to Campaign.

Autofill

When a website visitor submits a form, a tracking cookie is generated which can be used to identify the visitor. If the visitor opens the form again in the same web browser (assuming it still has the cookie and it is valid), the system automatically gets the visitor's data based on the cookie and fills in the data in the form.

This autofill feature can be  enabled and disabled in the CMS admin view, under Config > Tool Settings > Marketing Connectors > Global Settings > Enable Auto-fill on forms:

745

Clear the cache

Information, such as Session Token and Recipient Lists, is stored in the cache to improve performance.

To clear the cache, go to the Config tab > Optimizely Campaign in the CMS admin view and click Clear cache. You can also set the Cache timeout value and click Save.

975

Store tracking cookie

When a website visitor submits a form, a tracking cookie is generated which can be used to identify the visitor.

Breaking changes (Connect for Campaign 2)

EPiServer.ConnectForCampaign (2.0.0) depends on:

  • EPiServer.CMS.UI.Core version >= 11.2.4 and < 12
  • EPiServer.Marketing.Automation.Forms version >= 2.1.0 and < 3
  • EPiServer.ConnectForMarketingAutomation version >= 5.2.0 and < 6
  • EPiServer.Forms.UI version >= 4.16 and < 5

Interfaces and classes removed:

  • EPiServer.ConnectForCampaign.Core.Implementation.IRecipientListIdMapper.cs
  • EPiServer.ConnectForCampaign.Core.Implementation.RecipientListIdMapper.cs
  • EPiServer.ConnectForCampaign.Core.Implementation.IVisitorIdentifyProvider.cs
  • EPiServer.ConnectForCampaign.Core.Implementation.VisitorIdentifyProvider.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.CampaignDataSubmissionService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.CampaignFormValidationService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.CampaignMenuAssembler.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.CampaignProviderService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.CampaignSettingsRepository.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.
  • CampaignXFormMarketingAutomationInterception.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.ListService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.ProfileService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.ProgramService.cs
  • EPiServer.ConnectForCampaign.Implementation.Services.ScoringService.cs
  • EPiServer.ConnectForCampaign.Implementation.CampaignProvider.cs
  • EPiServer.ConnectForCampaign.Implementation.ProviderRepository.cs

Properties, methods, constants removed/changed:

  • EPiServer.ConnectForCampaign.Core.Configuration.ICampaignConfig.CacheTimeout
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignConfig.CacheTimeout
  • EPiServer.ConnectForCampaign.Core.Models.CampaignDataList.ParentName
  • EPiServer.ConnectForCampaign.Core.Models.CampaignDataList.FeatureSupport
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignSettings.Id
  • EPiServer.ConnectForCampaign.Implementation.Helpers.FullFormSubmissionData
  • EPiServer.ConnectForCampaign.Implementation.Helpers.ActiveExternalFieldMappingTable
  • EPiServer.ConnectForCampaign.Implementation.Helpers.ServiceValidationMessage
  • EPiServer.ConnectForCampaign.Implementation.Helpers.RecipientIdentification
  • EPiServer.ConnectForCampaign.Implementation.Helpers.RecipientListId
  • EPiServer.ConnectForCampaign.Implementation.Helpers.OptInProcessId
  • EPiServer.ConnectForCampaign.Services.Implementation.AuthenticationService.ctor()
  • EPiServer.ConnectForCampaign.Services.Implementation.OptinProcessService.ctor()
  • EPiServer.ConnectForCampaign.Services.Implementation.RecipientListService.ctor()
  • EPiServer.ConnectForCampaign.Services.Implementation.RecipientService.ctor()

Other

  • Change the type of the Id property in EPiServer.ConnectForCampaign.Core.Models.CampaignDataList.cs from "int" to "long".
  • Change return type of EPiServer.ConnectForCampaign.Services.Implementation.GetAllRecipientLists() to IEnumerable.

Breaking changes (Connect for Campaign 3)

EPiServer.ConnectForCampaign (3.0.0) depends on:

  • EPiServer.CMS.UI.Core version >= 11.2.4 and < 12
  • Optimizely.Marketing.Automation.Forms version >= 2.1.0 and < 3
  • EPiServer.ConnectForMarketingAutomation version >= 5.5.3 and < 5.7
  • EPiServer.Forms.UI version >= 4.20 and < 5

Properties, methods, constants removed/changed:

  • EPiServer.ConnectForCampaign.Core.Configuration.ICampaignConfig. TrackingCookieTimeout
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignConfig. TrackingCookieTimeout
  • EPiServer.ConnectForCampaign.Core.Configuration. ICampaignSettings. UserName
  • EPiServer.ConnectForCampaign.Core.Configuration.ICampaignSettings.Password
  • EPiServer.ConnectForCampaign.Core.Configuration.ICampaignSettings.MandatorId
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignSettings.UserName
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignSettings.Password
  • EPiServer.ConnectForCampaign.Implementation.Configuration.CampaignSettings.MandatorId

Breaking changes (Connect for Campaign 4.1.0)

EPiServer.ConnectForCampaign (4.1.0) depends on:

  • EPiServer.CMS version >= 12.15.0 and < 13
  • Optimizely.Marketing.Automation.Forms version >= 3.2.0 and < 4

Properties, methods, constants, classes removed/changed:

  • EPiServer.ConnectForCampaign.Implementation.Helpers.Constants.UserNameFieldKey
  • EPiServer.ConnectForCampaign.Implementation.Helpers.Constants.PasswordFieldKey
  • EPiServer.ConnectForCampaign.Implementation.Helpers.Constants.MandatorIdFieldKey
  • EPiServer.ConnectForCampaign.Services.Implementation.OptinProcessService
  • EPiServer.ConnectForCampaign.Services.Implementation.RecipientListService
  • EPiServer.ConnectForCampaign.Services.Implementation.RecipientService

Obsoleted classes and interfaces

  • EPiServer.ConnectForCampaign.Services.Implementation.AuthenticationService.cs
  • EPiServer.ConnectForCampaign.Services.Implementation.IAuthenticationService.cs
  • EPiServer.ConnectForCampaign.Services.IServiceClientFactory.cs
  • EPiServer.ConnectForCampaign.Services.ServiceClientFactory.cs

Other

  • Change from using campaign SOAP API service to REST API

Related blog post: Configuring the Episerver (Optimizely) Campaign connector through code by David Knipe