XML Format for Contact Imports
    • 7 Minutes to read
    • Dark
      Light

    XML Format for Contact Imports

    • Dark
      Light

    Article summary

    This topic describes how to import contact and profile attribute data with an XML file.

    For general information about XML, see http://de.wikipedia.org/wiki/XML.

    Related Topics​

    Basic File Structure

    To format your XML file, use the following guidelines.

    Component

    Description

    ​ XML Declaration and Encoding​

    The first line of your file specifies the XML version and character encoding in the file.

    ​Tags​

    The elements in an XML file are marked with a start tag (<elementname>) and an end tag (</elementname>).

    ​XML Elements​

    Contact data is enclosed in elements that tell Mapp Engage where to store the information. Key elements include:

    • userdata - Contains all of the contact data in the import file. This element includes space for the XML namespace attribute. In this attribute, you reference the web services URI from Mapp, which contains definitions for all the elements in the file.
      The XML namespace attribute is xmlns="http://webservices.ecircle-ag.com/ecm".

    • list - Contains the definition of any new custom attributes to import with this list.

    • user - Contains the data to be imported into the profile of a single contact. The information that you provide in the email, mobilenumber, or faxnumber attributes identify the contact to add or update.

    ​XML Attributes​

    Many elements provide space to specify attributes. For attributes, you enter a name and value pair. Enter an equal sign after the name of the XML attribute, then provide the attribute value. Set the attribute value in quotation marks. In the sample XML that follows, encoding is an attribute name and "UTF-8" is the attribute value.

    Hint:

    Replace the encoding of the code examples with an encoding that matches the characters in your input file. Select the correct character encoding on the interface when you import the file

    Element and attribute names are normally case-sensitive in XML files. Mapp Engage performs a case-insensitive comparison of attribute names in the XML file to the existing attributes in your system during import. This comparison prevents the creation of that new attributes with different capitalisation.

    The following sample shows the correct nesting for all elements in a contact import file. The sample contains values for new custom attributes that are defined during import. The sample also specifies values for all standard attributes, member attributes, read mode, and message limitation.

    Sample XML

     
    	<userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    		<list> 
    			<namedattr-definition enum="false" type="date" name="LastPurchase"/> 
    			<namedattr-definition enum="false" type="number" name="HouseholdSize"/> 
    			<namedattr-definition enum="false" type="string" name="Hobbies"/> 
    				<user> 
    					<email>joseph.example@emaildomain.com</email> 
    					<mobilenumber>498912345678</mobilenumber> 
    					<faxnumber>00000000</faxnumber> 
    					<identifier>11122233abc</identifier> 
    					<firstname>Joseph</firstname> 
    					<lastname>Example</lastname> 
    					<nickname>Joe</nickname> 
    					<dateofbirth>1983-06-23</dateofbirth> 
    					<title>1</title> 
    					<zipcode>12345</zipcode> 
    					<partnerid>12345</partnerid> 
    					<isolanguagecode>en</isolanguagecode> 
    					<isocountrycode>US</isocountrycode> 
    					<timezone>Europe/Berlin</timezone> 
    					<namedattr name="TotalPurchases">944.76</namedattr> 
    					<namedattr name="LastPurchase">15.03.2010</namedattr> 
    					<namedattr name="HouseholdSize">3</namedattr> 
    					<namedattr name="Hobbies">Dancing</namedattr> 
    					<memberattr name="LastPurchase">shoes</memberattr> 
    					<memberattr name="LocalStore">Manchester</memberattr> 
    					<channel type="email" mode="prefer" format="email-html"/> 
    					<channel type="mobile" mode="allow"/> 
    					<channel type="fax" mode="deny"/> 
    					<maxmessages number="2" period="7"/> 
    				</user> 
    		</list> 
    	</userdata>

    Standard Attributes​

    Mapp Engage offers several standard attributes to store contact profile data. These attributes are offered by default in every system.

    For more information about data formats for the standard attributes, see ​Quick Reference: Contact Import XML​.

    Custom Attributes​

    Custom attributes store data about a contact. This type of attribute is created specifically for your system. Custom attributes are specific to your system, and do not come standard with Mapp Engage. You can create custom attributes to the store the data about your contacts that is relevant to your digital marketing needs and strategies.

    In the XML file, custom attributes use the namedattr element, which contains an XML attribute to specify the name of the custom attribute. Enter the value that you want to store in the contact profile between the start tag and end tag.

    <namedattr name="x">value</namedattr>

    • Replace X with the name of the attribute. You can view the name of the profile attributes in your system in the ​Administration​ area.

    • If a custom attribute with that name exists, Mapp Engage adds the values to the existing attribute.

    • If a custom attribute with that name does not exist, Mapp Engage creates an attribute to store the data. We strongly recommend that you specify the data type and enumeration during import. For more information, see​ New Custom Attributes​.

    Hint:

    In the following example, the custom attribute LastPurchase exists in the system, and is not defined in the XML file

    Example

    Contact Jane Miller is imported with her email address, mobile number, and first name. Mapp Engage records the date of their last purchase in a custom attribute named LastPurchase.

     
    <userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    	<list> 
    		<user> 
    			<Email>Jane.Miller@email.com</Email> 
    			<MobileNumber>498912345678</MobileNumber> 
    			<FirstName>Jane</FirstName> 
    			<namedattr name="LastPurchase">15.03.2016</namedattr> 
    		</user> 
    	</list> 
    </userdata>

    New Custom Attributes​

    You can create custom attributes when you import a file. You can specify the data type, and whether the attribute is enumerated.

    You can import new custom attributes in the same file that you use for contact data import. You do not need a separate XML file.

    WARNING!

    You can only specify the data type and enumeration of new custom attributes that do not exist in Mapp Engage. If the import file specifies the data type for a custom attribute that exists, an error occurs. Mapp Engage cannot process the import file

    In the XML file, new custom attributes use the namedattr-definition element. The XML attributes define the enumeration, data type, and name.

    Example

    This example defines three new custom attributes.

     
    	<userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    		<list> 
    			<namedattr-definition enum="false" type="date" name="LastPurchase"/> 
    			<namedattr-definition enum="true" type="number" name="HouseholdSize"/> 
    			<namedattr-definition enum="false" type="string" name="Hobbies"/> 
    		</list> 
    	</userdata> 

    XML Attribute

    Description

    Possible Values

    enum

    Defines whether the attribute is enumerated.

    By default, all new custom attributes that you create with an XML import are enumerated. All the values for this attribute that are included in the file are added as enumerated values.

    If the attribute is enumerated, all values in the import file become part of the enumeration. An enumerated attribute can have up to 1000 values. If more than 1000 values are present in an imported file, the import fails.

    • true

    • false

    type

    Defines the data type. If you do not specify a data type, the new custom attribute is assigned the string data type.

    • string

    • number

    • date

    name

    Defines the name of the attribute.

    The name of a custom attribute cannot contain any underscores or special characters.

    The name of a custom attribute can contain a period.


    Member Attributes​

    Member attributes let you save different information for the same contact in different groups.

    You can only create member attributes with import of an XML or CSV file. You cannot create member attributes manually on the Mapp Engage interface. Member attributes always use the string data type.

    In the XML file, member attributes use the memberattr element, which contains an XML attribute to specify the name of the member attribute. Enter the value that you want to store in the contact profile between the start tag and end tag.

    <memberattr name="x">value</memberattr>

    • Replace X with the name of the attribute.

    • If a member attribute with that name exists in the group, Mapp Engage adds the values to the existing attribute.

    • If a member attribute with that name does not exist in the group, Mapp Engage creates an attribute for the data.


    Example

     
    	<userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    		<list> 
    			<user> 
    				<Email>jose.example@email.com</Email> 
    				<memberattr name="LastPurchase">shoes</memberattr> 
    				<memberattr name="LocalStore">Manchester</memberattr> 
    			</user> 
    		</list> 
    	</userdata>

    Group Attributes​

    A group attribute stores one value for all members of a group. The value is identical for all group members.

    Hint:

    It is not possible to import group attributes in an XML file that is used for contact data import. Group attributes must be imported in a separate XML file. For additional information, see ​XML Format for Group Attribute Imports

    Read Mode​

    The read mode stores information about how contacts want to receive messages.

    Mapp Engage uses the read mode to decide which channel to use when it sends messages to your contacts. The read mode controls the following channels: email, SMS, and mobile push.

    Read mode preferences apply to group messages only. Read mode preferences do not apply to system messages.

    Hint:

    By default, read mode preferences are only valid within a specific group. These settings do not apply for messages that the contact receives from other Mapp Engage groups.

    During import, you can choose to apply the read mode preferences system-wide. This option means that the read mode settings for each contact are overwritten for all groups this contact is a member of. This option is found in the ​Advanced Options​ area of the ​Import Contacts​ window.

    You can edit the read mode setting for a single contact in the Mapp Engage interface. The preferences that you enter in Mapp Engage manually overwrite any read mode preferences that have been imported in an XML or CSV file

    In the XML file, read mode uses the channel element.

    Example

    The following file specifies that Jane Miller has three preferences. Jane prefers messages via email, prefers HTML messages (rather than text messages) and allows SMS messages.

     
    	<userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    		<user> 
    			<Email>Jane.Miller@email.com</Email> 
    			<channel type="email" mode="prefer" format="email-html"/> 
    			<channel type="mobile" mode="allow"/> 
    			<channel type="fax" mode="deny"/> 
    		</user> 
    	</userdata>

    The following table shows you how to set up the XML file to specify read mode.

    XML Attribute

    Description

    Possible Values

    type

    Defines the channel for which the read mode preference applies.

    • email - Preference applies to email messages.

    • mobile - Preference applies to SMS messages.

    • fax - Preference applies to mobile push messages.

    mode

    Defines the preference for the channel.

    • allow

    • deny

    • prefer

    format

    Defines which message format is sent to the contact.

    • email-html-multipart

    • email-html

    • email-text

    • mobile-sms

    • fax-printed

    Message Limitation​

    You can use an XML import file to specify the maximum number of messages you send to a contact. This message limitation is specific to a single contact. You can also set message limitation on a system level. For more information, see ​Message Limitation​

    Message limitations apply to all Mapp Engage messaging channels (email, SMS, and mobile push). Message limitations do not apply to system messages or single messages.

    In the XML file, message limitation uses the maxmessages element.

    Example

    The following file specifies that Jane Miller receives no more than two messages in seven days.

    <?xml version="1.0" encoding="ISO-8859-1"?> 
    	<userdata xmlns="http://webservices.ecircle-ag.com/ecm"> 
    		<user> 
    			<Email>Jane.Miller@email.com</Email> 
    			<maxmessages number="2" period="7"/> 
    		</user> 
    	</userdata>

    XML Attribute

    Description

    Possible Values

    number

    Defines how many messages a contact receives.

    • 1 - 99 - The maximum number of messages that can be sent to the contact.

    • 0 - The contact does not receive any messages. To deactivate contacts temporarily, use this value.

    period

    Defines the period, in days. Once the maximum number of messages within the time period is reached, no additional messages are sent to the contact.

    • 1 - 31 - The period, in days.


    Was this article helpful?