Cas dʼutilisation : transmission dynamique de collections à l’aide d’actions personnalisées passing-collection
Vous pouvez transmettre une collection dans des paramètres d’action personnalisés qui seront renseignés dynamiquement au moment de l’exécution. Deux types de collections sont pris en charge :
-
collections simples : tableaux de types de données simples, par exemple avec une listString :
code language-none { "deviceTypes": [ "android", "ios" ] }
-
collections d’objets : tableau d’objets JSON, par exemple :
code language-none { "products":[ { "id":"productA", "name":"A", "price":20.1 }, { "id":"productB", "name":"B", "price":10.0 }, { "id":"productC", "name":"C", "price":5.99 } ] }
Limites limitations
-
Les tableaux d’objets imbriqués dans un tableau d’objets ne sont pas pris en charge pour l’instant. Par exemple :
code language-none { "products":[ { "id":"productA", "name":"A", "price":20, "locations": [{"name": "Paris"}, {"name": "London"}] }, ] }
-
Pour tester les collections à l’aide du mode test, vous devez utiliser le mode Affichage du code. Le mode Affichage du code n’est pas pris en charge pour les événements métier pour l’instant. Vous ne pouvez envoyer qu’une collection avec un seul élément.
Procédure générale general-procedure
Dans cette section, nous utiliserons l’exemple de payload JSON ci-après. Il s’agit d’un tableau d’objets avec un champ qui est une collection simple.
{
"ctxt": {
"products": [
{
"id": "productA",
"name": "A",
"price": 20.1,
"color":"blue",
"locations": [
"Paris",
"London"
]
},
{
"id": "productB",
"name": "B",
"price": 10.99
}
]
}
}
Vous pouvez voir que « products » est un tableau de deux objets. Vous devez avoir au moins un objet.
-
Créez votre action personnalisée. Voir cette page.
-
Dans la section Paramètres d’action, collez l’exemple JSON. La structure affichée est statique : lorsque vous collez la payload, tous les champs sont définis comme des constantes.
-
Si nécessaire, ajustez les types de champs. Les types de champs suivants sont pris en charge pour les collections : listString, listInteger, listDecimal, listBoolean, listDateTime, listDateTimeOnly, listDateOnly, listObject
note note NOTE Le type de champ est automatiquement déduit en fonction de l’exemple de payload. -
Si vous souhaitez transmettre des objets de façon dynamique, vous devez les définir en tant que variables. Dans cet exemple, nous définissons « products » comme variable. Tous les champs d’objet inclus dans l’objet sont automatiquement définis sur des variables.
note note NOTE Le premier objet de l’exemple de payload est utilisé pour définir les champs. -
Pour chaque champ, définissez le libellé qui sera affiché dans la zone de travail du parcours.
-
Créez votre parcours et ajoutez l’action personnalisée que vous avez créée. Voir cette page.
-
Dans la section Paramètres d’action, définissez le paramètre de tableau (« products » dans notre exemple) à l’aide de l’éditeur d’expression avancé.
-
Pour chacun des champs d’objet suivants, saisissez le nom de champ correspondant à partir du schéma XDM source. Si les noms sont identiques, cela n’est pas nécessaire. Dans notre exemple, il nous suffit de définir « product id » et « color ».
Pour le champ de tableau, vous pouvez également utiliser l’éditeur d’expression avancé pour effectuer une manipulation de données. Dans l’exemple suivant, nous utilisons les fonctions filter et intersect :
Cas particuliers examples
Pour les types et les tableaux de tableaux hétérogènes, le tableau est défini avec le type listAny. Vous pouvez uniquement mapper des éléments individuels, mais ne pouvez pas modifier le tableau en variable.
Exemple de type hétérogène :
{
"data_mixed-types": [
"test",
"test2",
null,
0
]
}
Exemple de tableau de tableaux :
{
"data_multiple-arrays": [
[
"test",
"test1",
"test2"
]
]
}
Rubrique connexe
Utilisation d’actions personnalisées