Transactional messaging architecture transactional-messaging-architecture
Transactional messaging relies on a specific architecture, which is made up of several instances:
-
A control instance, on which the message templates are created.
-
One or more execution instances, which receive events and deliver messages.
Adobe Campaign users log on to the control instance to:
- Create transactional message templates
- Generate the message preview using a seed list
- Display reports
- Monitor the execution instances
Execution instances are here to:
- Receive events
- Link them to transactional message templates
- Send a personalized message to each recipient
Install instances installing-instances
There are several precautions to take when installing the Transactional message packages. Adobe recommends you to work in a test environment before putting into production. You also need to have a compatible Adobe Campaign license. For more information, please contact your Adobe account executive.
If you need to use several channels, you must install and configure related packages before installing Transactional message packages. For more on this, see Add a delivery channel.
Control instance control-instance
To install the control instance on your machine, select the Transactional message control package via the Tools > Advanced > Import package menu. For more on this, see Installing Campaign Classic standard packages.
The detailed steps to configure the control instance are presented in this section.
Support several control instances supporting-several-control-instances
It is possible to share an execution cluster among several control instances. For example, if you manage several specialized stores, you can configure one control instance per brand and link them all to the same execution cluster.
Execution instance execution-instance
To install an execution instance on your machine, select the Transactional message execution package via the Tools > Advanced > Import package menu. For more on this, see Installing Campaign Classic standard packages.
The detailed steps to configure an execution instance are presented in this section.
Available delivery channels
The email channel is available by default. To deliver your transactional messages on multiple channels, you can add other channels (mobile channel, Mobile App channel, etc.).
Add a delivery channel adding-a-delivery-channel
Adobe recommends you always add the delivery channel package before installing the Transactional message package.
However, if you have started a transactional messaging project on the email channel, then decide during the project to add a new channel, you can follow the steps below.
-
Install the channel you need, for example the Mobile channel, using the package import assistant (Tools > Advanced > Import package… > Adobe Campaign Package).
-
Perform a file import (Tools > Advanced > Import package… > File), and select the datakitnms
[Your language]
packagemessageCenter.xml file. -
In the XML content of the data to import, keep only the delivery template that corresponds to the added channel. For example, if you have added the Mobile channel, keep only the entities element that corresponds to the Mobile transactional message (smsTriggerMessage). If you have added the Mobile App Channel, keep only the iOS transactional message (iosTriggerMessage) and the Android transactional message (androidTriggerMessage).
Transactional push notifications transactional-messaging-and-push-notifications
When combined with Mobile App channel module, transactional messaging enables you to push transactional messages through notifications on mobile devices.
To use transactional message modules with Mobile App Channel, you need to apply the following configurations:
- Install the Mobile App Channel package onto the control and execution instances.
- Replicate the Mobile application type Adobe Campaign service as well as the mobile applications that it contains on the execution instances.
The event must contain the following elements:
- The mobile device ID (registrationId for Android and deviceToken for iOS). This ID represents the “address” that the notification will be sent to.
- The link to the mobile application or integration key (uuid) which lets you recover connection information specific to the application.
- The channel to which the notification will be sent (wishedChannel): 41 for iOS and 42 for Android
- All data useful for personalization
Here is an example of an event that contains this information:
<SOAP-ENV:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">
<SOAP-ENV:Body>
<urn:PushEvent>
<urn:sessiontoken>mc/</urn:sessiontoken>
<urn:domEvent>
<rtEvent wishedChannel="41" type="DELIVERY" registrationToken="2cefnefzef758398493srefzefkzq483974">
<mobileApp _operation="none" uuid="com.adobe.NeoMiles"/>
<ctx>
<deliveryTime>1:30 PM</deliveryTime>
<url>http://www.adobe.com</url>
</ctx>
</rtEvent>
</urn:domEvent>
</urn:PushEvent>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>
Transactional messaging and LINE transactional-messaging-and-line
Combined with LINE Channel, transactional messages allow you to send real time messages on the LINE app installed in consumer mobile devices. This is used to send the Welcome message when a LINE user adds the brand’s page.
To use transactional message module with LINE, the following elements are needed for the configuration on your marketing instance and your execution instance:
- Install the LINE Connect package on both instances.
- Install the Transactional message control package on your marketing instance, and the Transactional message execution package on the execution instance.
- Create a LINE external account and service on both instances with identical naming for them to be synchronized. For more information on how to create a LINE external account and service, refer to this section.
Then, from the Explorer , in Platform > External account , you need to configure different external accounts on both instances:
-
Create an External database external account in your execution instance with the following configuration:
- Label and Internal name : name your external account as needed.
- Type : select External database .
- Enabled box must be checked.
From the Connection category:
-
Type : select your database server e.g. PostgresSQL.
-
Server : enter your database server URL.
-
Account : enter your database account.
note note NOTE The database user needs to have read rights on the following tables for FDA connection: XtkOption, NmsVisitor, NmsVisitorSub, NmsService, NmsBroadLogRtEvent, NmsBroadLogBatchEvent, NmsTrackingLogRtEvent, NmsTrackingLogBatchEvent, NmsRtEvent, NmsBatchEvent, NmsBroadLogMsg, NmsTrackingUrl, NmsDelivery, NmsWebTrackingLogXtkFolder. -
Password : enter the password for your database account.
-
Database : enter the database name of the execution instance.
-
Target of an HTTP relay to remote database’s account box must be checked.
-
Create an External Database account in your marketing instance with the following configuration.
- Label and Internal name : name your external account as needed.
- Type : select External database .
- Enabled box must be checked.
From the Connection category:
- Type : select HTTP relay to remote Database .
- Server : enter your campaign’s server URL of the execution instance.
- Account : enter the account used to access your execution instance.
- Password : enter the password for the account used to access your execution instance.
- Data Source : enter the following syntax
nms:extAccount:ID
of your external database account in the execution instance.
-
Create an Execution instance external account in your marketing instance using the following configuration to create the data synchronization workflow:
- Label and Internal name : name your external account as needed.
- Type : select Execution instance .
- Enabled box must be checked.
From the Connection category:
- URL : enter your execution instance’s URL.
- Account : enter your account used to access your execution instance.
- Password : enter the password for the account used to access your execution instance.
From the Account connection method category:
- Method : select Federated Data Access (FDA) .
- FDA account : select your FDA account from the drop-down.
- Click the Create the archiving workflow button.
- Click the Create data synchronization workflow button to create the LINE data sync workflow.
-
You can now start creating transactional messages.