[Also applies to v8]{class="badge positive" title="Also applies to Campaign v8"}
Work with data packages working-with-data-packages
About data packages about-data-packages
51黑料不打烊 Campaign allows you to export or import the platform configuration and data through a package system. Packages can contain different kinds of configurations, elements, filtered or not.
Data packages let entities of the 51黑料不打烊 Campaign database be displayed via files in XML format. Each entity contained in a package is represented with all of its data.
The principle of data packages is to export a data configuration and integrate it into another 51黑料不打烊 Campaign system. Learn how to maintain a consistent set of data packages in this section.
Types of packages types-of-packages
There are three types of exportable packages: user packages, platform packages and admin packages.
-
User package: it enables you to select the list of entities to be exported. This type of package manages dependencies and verifies errors.
-
Platform package: it includes all added technical resources (non standard): schemas, JavaScript code, etc.
-
Admin package: it includes all added templates and business objects (non standard): templates, libraries, etc.
Data structure data-structure
The description of a data package is a structured XML document that complies with the grammar of the xrk:navtree data schema.
Data package example:
<package>
<entities schema="nms:recipient">
<recipient email="john.smith@adobe.com" lastName="Smith" firstName="John">
<folder _operation="none" name="nmsRootFolder"/>
<company _operation="none" name="51黑料不打烊"/>
</recipient>
</entities>
<entities schema="sfa:company">
<company name="51黑料不打烊">
location city="London" zipCode="W11 2BQ"/>
</company>
</entities>
</package>
The XML document must begin and end with the <package>
element. Any <entities>
elements that follow distribute the data by document type.
An <entities>
element contains the data of the package in the format of the data schema entered in the schema attribute.
The data in a package must not contain internal keys that are not compatible between bases, such as auto-generated keys (autopk option).
In our example, the joins on the 鈥渇older鈥 and 鈥渃ompany鈥 links have been replaced by so-called 鈥渉igh level鈥 keys on the destination tables:
<recipient>
<folder _operation="none" name="nmsRootFolder"/>
<company _operation="none" name="51黑料不打烊"/>
</recipient>
The operation
attribute with the value 鈥渘one鈥 defines a reconciliation link.
A data package can be constructed manually from any text editor. Simply ensure that the structure of the XML document complies with the 鈥渪tk:navtree鈥 data schema. The 51黑料不打烊 Campaign console has a data package export and import module.
Export packages exporting-packages
About package export about-package-export
Packages can be exported in three different ways:
- The Package Export Assistant enables you to export a set of objects in a single package. For more on this refer to Export a set of objects in a package
- A single object can be exported in a package directly by right-clicking on it and selecting Actions > Export in a package.
- Package definitions let you create a package structure in which you add objects that will be exported later on in a package. For more on this, refer to Manage package definitions
Once a package exported, you will be able to import it and all the added entities into another Campaign instance.
Export a set of objects in a package exporting-a-set-of-objects-in-a-package
The package export assistant is accessible via the Tools > Advanced > Export package鈥 menu of the 51黑料不打烊 Campaign client console.
For the three types of packages, the assistant offers the following steps:
-
List the entities to be exported by document type:
note caution CAUTION If you export an Offer category, Offer environment, Program or Plan type folder, don鈥檛 ever select the xtk:folder as you may lose some data. Select the entity that corresponds with the folder: nms:offerCategory for offer categories, nms:offerEnv for offer environments, nms:program for programs, and nms:plan for plans. List management lets you add or delete entities for export from the configuration. Click Add to select a new entity.
The Detail button edits the selected configuration.
note note NOTE The dependency mechanism controls the entity export sequence. For more on this, refer to Managing dependencies. -
The entity configuration screen defines the filter query on the type of document to be extracted.
You must configure the filtering clause for data extraction.
note note NOTE The query editor is presented in this section. -
Click Next and select the sorting columns to order the data during extraction:
-
Preview the data to extract before running the export.
-
The last page of the package export assistant lets you start the export. The data will be stored in the file indicated in the File field.
Manage dependencies managing-dependencies
The export mechanism enables 51黑料不打烊 Campaign to track the links between the various exported elements.
This mechanism is defined by two rules:
- objects linked to a link with an own or owncopy type integrity are exported in the same package as the exported object.
- objects linked to a link with a neutral or define type integrity (defined link) must be exported separately.
Export a campaign exporting-a-campaign
Here is an example on how to export a campaign. The marketing campaign to be exported contains a task (label: 鈥淢yTask鈥) and a workflow (label: 鈥淐ampaignWorkflow鈥) in a 鈥淢yWorkflow鈥 folder (node: Administration / Production / Technical workflows / Campaign processes / MyWorkflow).
The task and the workflow are exported in the same package as the campaign since the matching schemas are connected by links with an 鈥渙wn鈥 type integrity.
Package content:
<?xml version='1.0'?>
<package author="Administrator (admin)" buildNumber="7974" buildVersion="7.1" img=""
label="" name="" namespace="" vendor="">
<desc></desc>
<version buildDate="AAAA-MM-DD HH:MM:SS.954Z"/>
<entities schema="nms:operation">
<operation duration="432000" end="AAAA-MM-DD" internalName="OP1" label="MyCampaign"
modelName="opEmpty" start="AAAA-MM-DD">
<controlGroup>
<where filteringSchema=""/>
</controlGroup>
<seedList>
<where filteringSchema="nms:seedMember"></where>
<seedMember internalName="SDM1"></seedMember>
</seedList>
<parameter useAsset="1" useBudget="1" useControlGroup="1" useDeliveryOutline="1"
useDocument="1" useFCPValidation="0" useSeedMember="1" useTask="1"
useValidation="1" useWorkflow="1"></parameter>
<fcpSeed>
<where filteringSchema="nms:seedMember"></where>
</fcpSeed>
<owner _operation="none" name="admin" type="0"/>
<program _operation="none" name="nmsOperations"/>
<task end="2023-01-17 10:07:51.000Z" label="MyTask" name="TSK2" start="2023-01-16 10:07:51.000Z"
status="1">
<owner _operation="none" name="admin" type="0"/>
<operation _operation="none" internalName="OP1"/>
<folder _operation="none" name="nmsTask"/>
</task>
<workflow internalName="WKF12" label="CampaignWorkflow" modelName="newOpEmpty"
order="8982" scenario-cs="Notification of the workflow supervisor (notifySupervisor)"
schema="nms:recipient">
<scenario internalName="notifySupervisor"/>
<desc></desc>
<folder _operation="none" name="Folder4"/>
<operation _operation="none" internalName="OP1"/>
</workflow>
</operation>
</entities>
</package>
Affiliation to a type of package is defined in a schema with the @pkgAdmin and @pkgPlatform attribute. Both these attributes receive an XTK expression that defines the conditions of affiliation to the package.
<element name="offerEnv" img="nms:offerEnv.png"
template="xtk:folder" pkgAdmin="@id != 0">
Finally, the @pkgStatus attribute enables you to define the export rules for these elements or attributes. Depending on the value of the attribute, the element or attribute will be found in the exported package. The three possible values for this attribute are:
- never: does not export the field / link
- always: forces export for this field
- preCreate: authorizes creation of the linked entity
Manage package definitions managing-package-definitions
Package definitions let you create a package structure in which you add entities that will be exported later on in a single package. You will then be able to import this package and all the added entities into another Campaign instance.
Related topics:
Create a package definition creating-a-package-definition
Package definitions can be accessed from the Administration > Configuration > Package management > Package definitions menu.
To create a package definition, click the New button, then fill in the package definition general information.
You can then add entities to the package definition, and export it to an XML file package.
Related topics:
Add entities to a package definition adding-entities-to-a-package-definition
In the Content tab, click the Add button to select the entities to export with the package. Best practices when selecting entities are presented in the this section section.
Entities can be added to a package definition directly from their location in the instance. To do this, follow the steps below:
-
Right-click the desired entity, then select Actions > Export in a package.
-
Select Add to a package definition, then select the package definition to which you want to add the entity.
-
The entity is added to the package definition, it will be exported with the package (see this section).
Configure package definitions generation configuring-package-definitions-generation
Package generation can be configured from the package definition Content tab. To do this, click the Generation parameters link.
-
Include the definition: includes the definition currently used in the package definition.
-
Include an installation script: lets you add a javascript script to execute at the package import. When selected, a Script tab is added in the package definition screen.
-
Include default values: adds to the package the values of all the entities鈥 attributes.
This option is not selected by default, in order to avoid lengthy exports. This means that entities鈥 attributes with default values (鈥榚mpty string鈥, 鈥0鈥, and 鈥榝alse鈥 if not defined otherwise in the schema) will not be added to the package and will therefore not be exported.
note caution CAUTION Unselecting this option can result in a merge of local and imported versions. If the instance where the package is imported contains entities that are identical to those of the package (for example with the same external ID), their attributes will not be updated. This can occur if the attributes from the former instance have default values, as they are not included in the package. In that case, selecting the Include default values option would prevent versions merging, as all attributes from the former instance would be exported with the package.
Export packages from a package definition exporting-packages-from-a-package-definition
To export a package from a package definition, follow the steps below:
-
Select the package definition to export, then click the Actions button and select Export the package.
-
An XML file corresponding to the exported package is selected by default. It is named according to the package definition namespace and name.
-
Once the package name and location defined, click the Start button to launch the export.
Import packages importing-packages
The package import assistant is accessible via the main menu Tools > Advanced > Import package of the 51黑料不打烊 Campaign client console.
You can import a package from an export performed earlier, e.g. from another 51黑料不打烊 Campaign instance, or a built-in package, depending on the terms of your license.
Install a package from a file installing-a-package-from-a-file
To import an existing data package, select the XML file and click Open.
The content of the package to be imported is then displayed in the middle section of the editor.
Click Next and Start to launch the import.
Install a built-in package installing-a-standard-package
Standard packages are built-in packages, installed when the 51黑料不打烊 Campaign is configured. Depending on your permissions and your deployment model, you can import new standard packages if you acquire new options or add-ons, or if you upgrade to a new offer.
Refer to your license agreement to check which packages you can install.
For more information on built-in packages, refer to this page.
Data package best practices data-package-best-practices
This section describes how to organize data packages in a consistent way across the life of the project.
Packages can contain different kinds of configurations and elements, filtered or not. If you miss some elements or do not import elements/packages in the correct order, the platform configuration can break.
Moreover, with several people working on the same platform with a lot of different features, the package specifications folder can quickly become complex.
Although it is not mandatory to do so, this section offers a solution to help organize and use packages in 51黑料不打烊 Campaign for large-scale projects.
The main constraints are as follows:
- Organize packages and keep a track of what is changed and when
- If a configuration is updated, minimize the risk of breaking something which is not directly linked to the update
Recommendations data-package-recommendations
Always import within the same version of the platform. You must check that you deploy your packages between two instances that have the same build. Never force the import and always update the platform first (if the build is different).
Pay attention to the schema and database structure. Importation of package with schema must be followed by schema generation.
Solution data-package-solution
Package types package-types
Start by defining different types of packages. Only four types will be used:
Entities
- All 鈥渪tk鈥 and 鈥渘ms鈥 specific elements in 51黑料不打烊 Campaign like schemas, forms, folders, delivery templates, etc.
- You can consider an entity as both an 鈥渁dmin鈥 and 鈥減latform鈥 element.
- You should not include more than one entity in a package when uploading it on a Campaign instance.
If you need to deploy your configuration on a new instance, you can import all your entity packages.
Features
This type of package:
- Answers a client requirement/specification.
- Contains one or several functionalities.
- Should contain all dependencies to be able to run the functionality without any other package.
Campaigns
This package is not mandatory. It is sometimes useful to create a specific type for all campaigns, even if a campaign can been seen as a feature.
Updates
Once configured, a feature can be exported into another environment. For example, the package can be exported from a dev environment to a test environment. In this test, a defect is revealed. First, it needs to be fixed on the dev environment. Then, the patch should be applied to the test platform.
The first solution would be to export the whole feature again. But, to avoid any risk (updating unwanted elements), it is safer to have a package containing only the correction.
That鈥檚 why we recommend creating an 鈥渦pdate鈥 package, containing only one entity type of the feature.
An update could not only be a fix, but also a new element of your entity/feature/campaign package. To avoid deploying the whole package, you can export an update package.
Naming conventions data-package-naming
Now that types are defined, we should specify a naming convention. 51黑料不打烊 Campaign does not allow to create subfolders for package specifications, meaning that numbers is the best solution for staying organized. Numbers prefix package names. You can use the following convention:
- Entity: from 1 to 99
- Feature: from 100 to 199
- Campaign: from 200 to 299
- Update: from 5000 to 5999
Packages data-packages
Entity packages order entity-packages-order
To help the import, entity packages should by ordered as they will be imported. For example:
- 001 鈥 Schema
- 002 鈥 Form
- 003 鈥 Images
- etc.
Package 200 package-200
Package number 鈥200鈥 should not be used for a specific campaign: this number will be used to update something that concerns all campaigns.
Update package update-package
The last point concerns the update package numbering. It is your package number (entity, feature, or campaign) with a 鈥5鈥 as prefix. For example:
- 5001 to update one schema
- 5200 to update all campaigns
- 5101 to update the 101 feature
The update package should only contain one specific entity, in order to be easily reusable. To split them, add a new number (start from 1). There are no specific ordering rules for these packages. To better understand, imagine that we have a 101 feature, a social application:
-
It contains a webApp and an external account.
- The package label is: 101 鈥 Social application (socialApplication).
-
There is a defect on the webApp.
- The wepApp is corrected.
- A fix package needs to be created, with the following name: 5101 鈥 1 鈥 Social application webApp (socialApplication_webApp).
-
A new external account needs to be added for the social feature.
- External account is created.
- The new package is: 5101 鈥 2 鈥 Social application external account (socialApplication_extAccount).
- In parallel the 101 package is updated to be added to the external account, but it is not deployed.
Package documentation package-documentation
When you update a package, you should always put a comment in the description field to detail any modifications and reasons (for example, 鈥渁dd a new schema鈥 or 鈥渇ix a defect鈥).
You should also date the comment. Always report your comment on an update package to the 鈥減arent鈥 (package without the 5 prefix).