Point de terminaison des planifications
Les planifications sont un outil qui peut être utilisé pour exécuter automatiquement des tâches de segmentation par lots une fois par jour. Vous pouvez utiliser le point de terminaison /config/schedules
pour récupérer une liste de planifications, créer une planification, récupérer les détails d’une planification spécifique, mettre à jour une planification spécifique ou supprimer une planification spécifique.
Commencer
Les points de terminaison utilisés dans ce guide font partie de l’API Adobe Experience Platform Segmentation Service. Avant de poursuivre, consultez le guide de prise en main pour obtenir des informations importantes à connaître afin d’effectuer avec succès des appels vers l’API, y compris les en-têtes requis et comment lire des exemples d’appels API.
Obtention d’une liste de plannings retrieve-list
Vous pouvez récupérer une liste de tous les plannings de votre organisation en envoyant une requête de GET au point de terminaison /config/schedules
.
Format d’API
Le point d’entrée /config/schedules
prend en charge plusieurs paramètres de requête pour vous aider à filtrer vos résultats. Bien que ces paramètres soient facultatifs, leur utilisation est vivement recommandée pour réduire les frais généraux élevés. Un appel à ce point de terminaison sans paramètres permet de récupérer toutes les plannings disponibles pour votre organisation. Plusieurs paramètres peuvent être inclus et séparés par des esperluettes (&
).
GET /config/schedules
GET /config/schedules?{QUERY_PARAMETERS}
Paramètres de requête
table 0-row-3 1-row-3 2-row-3 | ||
---|---|---|
Paramètre | Description | Exemple |
start |
Spécifie la page à partir de laquelle le décalage commencera. Par défaut, cette valeur sera définie sur 0. | start=5 |
limit |
Indique le nombre de plannings renvoyés. Par défaut, cette valeur sera définie sur 100. | limit=20 |
Requête
La requête suivante récupère les dix derniers plannings publiés au sein de votre organisation.
code language-shell |
---|
|
Réponse
Une réponse réussie renvoie un état HTTP 200 avec une liste de plannings pour l’organisation spécifiée comme JSON.
code language-json |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 7-row-2 8-row-2 | |
---|---|
Propriété | Description |
_page.totalCount |
Nombre total de plannings renvoyés. |
_page.pageSize |
Taille de la page des plannings. |
children.name |
Nom du planning sous forme de chaîne. |
children.type |
Type de tâche sous forme de chaîne. Les deux types pris en charge sont "batch_segmentation" et "export". |
children.properties |
Objet contenant des propriétés supplémentaires liées au planning. |
children.properties.segments |
L’utilisation de ["*"] permet de s’assurer que tous les segments sont inclus. |
children.schedule |
Chaîne contenant le planning de la tâche. L’exécution des tâches ne peut être planifiée qu’une fois par jour, ce qui signifie que vous ne pouvez pas planifier l’exécution de plusieurs tâches sur une période de 24 heures. Pour plus d’informations sur les plannings cron, veuillez lire l’annexe sur le format d’expression cron. Dans cet exemple, "0 0 1 * *" signifie que cette planification s’exécutera à 1h00 tous les jours. |
children.state |
Chaîne contenant l’état du planning. Les deux états pris en charge sont "actif" et "inactif". Par défaut, l’état est défini sur "inactif". |
Création d’un nouveau planning create
Vous pouvez créer un nouveau planning en effectuant une requête POST au point d’entrée /config/schedules
.
Format d’API
POST /config/schedules
Requête
code language-shell |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 | |
---|---|
Propriété | Description |
name |
Obligatoire. Nom du planning sous forme de chaîne. |
type |
Obligatoire. Type de tâche sous forme de chaîne. Les deux types pris en charge sont "batch_segmentation" et "export". |
properties |
Obligatoire. Objet contenant des propriétés supplémentaires liées au planning. |
properties.segments |
Obligatoire lorsque type est égal à "batch_segmentation". L’utilisation de ["*"] permet de s’assurer que tous les segments sont inclus. |
schedule |
Facultatif. Chaîne contenant le planning de la tâche. L’exécution des tâches ne peut être planifiée qu’une fois par jour, ce qui signifie que vous ne pouvez pas planifier l’exécution de plusieurs tâches sur une période de 24 heures. Pour plus d’informations sur les plannings cron, veuillez lire l’annexe sur le format d’expression cron. Dans cet exemple, "0 0 1 * *" signifie que cette planification s’exécutera à 1h00 tous les jours. Si cette chaîne n’est pas fournie, un planning généré par le système sera automatiquement généré. |
state |
Facultatif. Chaîne contenant l’état du planning. Les deux états pris en charge sont "actif" et "inactif". Par défaut, l’état est défini sur "inactif". |
Réponse
Une réponse réussie renvoie un état HTTP 200 avec les détails de votre nouveau planning.
code language-json |
---|
|
Récupération d’un planning spécifique get
Vous pouvez récupérer des informations détaillées sur un planning spécifique en envoyant une requête GET au point de terminaison /config/schedules
et en fournissant l’identifiant du planning que vous souhaitez récupérer dans le chemin d’accès de la requête.
Format d’API
GET /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
du planning que vous souhaitez récupérer.Requête
code language-shell |
---|
|
Réponse
Une réponse réussie renvoie un état HTTP 200 avec des informations détaillées sur le planning spécifié.
code language-json |
---|
|
table 0-row-2 1-row-2 2-row-2 3-row-2 4-row-2 5-row-2 6-row-2 | |
---|---|
Propriété | Description |
name |
Nom du planning sous forme de chaîne. |
type |
Type de tâche sous forme de chaîne. Les deux types pris en charge sont batch_segmentation et export . |
properties |
Objet contenant des propriétés supplémentaires liées au planning. |
properties.segments |
L’utilisation de ["*"] permet de s’assurer que tous les segments sont inclus. |
schedule |
Chaîne contenant le planning de la tâche. Vous ne pouvez planifier qu’une seule exécution de tâche par jour, ce qui signifie que vous ne pouvez pas planifier l’exécution d’une tâche plus d’une fois au cours d’une période de 24 heures. Pour plus d’informations sur les plannings cron, veuillez lire l’annexe sur le format d’expression cron. Dans cet exemple, "0 0 1 * *" signifie que cette planification s’exécutera à 1h00 tous les jours. |
state |
Chaîne contenant l’état du planning. Les deux états pris en charge sont active et inactive . Par défaut, l’état est défini sur inactive . |
Mise à jour des détails d’un planning spécifique update
Vous pouvez mettre à jour un planning spécifique en envoyant une requête de PATCH au point de terminaison /config/schedules
et en fournissant l’identifiant du planning que vous essayez de mettre à jour dans le chemin d’accès de la requête.
La requête du PATCH vous permet de mettre à jour state ou la planification cron pour une planification individuelle.
Format d’API
PATCH /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
du planning que vous souhaitez mettre à jour.Vous pouvez utiliser une opération de correctif JSON pour mettre à jour l’état du planning. Pour mettre à jour l’état, vous déclarez la propriété path
comme /state
et définissez value
sur active
ou inactive
. Pour plus d’informations sur le correctif JSON, consultez la documentation JSON Patch .
Requête
accordion | ||
---|---|---|
Exemple de requête pour mettre à jour l’état du planning. | ||
|
table 0-row-2 1-row-2 2-row-2 | |
---|---|
Propriété | Description |
path |
Chemin d’accès de la valeur que vous souhaitez mettre à jour. Dans ce cas, puisque vous mettez à jour l’état du planning, vous devez définir la valeur de path sur "/state". |
value |
Valeur mise à jour de l’état du planning. Cette valeur peut être définie sur "actif" ou "inactif" pour activer ou désactiver le planning. Notez que vous ne pouvez pas désactiver un planning si l’organisation a été activée pour la diffusion en continu. |
Réponse
Une réponse réussie renvoie un état HTTP 204 (No Content).
path
comme /schedule
et définissez value
sur un planning cron valide. Pour plus d’informations sur le correctif JSON, consultez la documentation JSON Patch . Pour plus d’informations sur les plannings cron, veuillez lire l’annexe sur le format d’expression cron.Requête
code language-shell |
---|
|
table 0-row-2 1-row-2 2-row-2 | |
---|---|
Propriété | Description |
path |
Chemin d’accès de la valeur que vous souhaitez mettre à jour. Dans ce cas, puisque vous mettez à jour le planning cron, vous devez définir la valeur de path sur /schedule . |
value |
La valeur mise à jour du planning cron. Cette valeur doit se présenter sous la forme d’un planning cron. Dans cet exemple, le planning se déroulera le deuxième jour de chaque mois. |
Réponse
Une réponse réussie renvoie un état HTTP 204 (No Content).
Suppression d’un planning spécifique
Vous pouvez demander la suppression d’un planning spécifique en envoyant une requête de DELETE au point de terminaison /config/schedules
et en fournissant l’identifiant du planning que vous souhaitez supprimer dans le chemin d’accès de la requête.
Format d’API
DELETE /config/schedules/{SCHEDULE_ID}
{SCHEDULE_ID}
id
du planning que vous souhaitez supprimer.Requête
code language-shell |
---|
|
Réponse
Une réponse réussie renvoie un état HTTP 204 (No Content).
Étapes suivantes
Après avoir lu ce guide, vous comprenez mieux le fonctionnement des plannings.
Annexe appendix
L’annexe suivante explique le format des expressions cron utilisées dans les plannings.
Format
Une expression cron est une chaîne composée de 6 ou 7 champs. L’expression ressemble à ce qui suit :
0 0 12 * * ?
Dans une chaîne d’expression cron, le premier champ représente les secondes, le second les minutes, le troisième les heures, le quatrième le jour du mois, le cinquième le mois et le sixième le jour de la semaine. Vous pouvez également inclure un septième champ, qui représente l’année.
, - * /
, - * /
, - * /
, - * ? / L W
, - * /
, - * ? / L #
, - * /
SUN
équivaut à utiliser sun
.Les caractères spéciaux autorisés représentent les significations suivantes :
*
*
dans le champ des heures signifierait toutes les heures.?
3
dans le champ du jour du mois et ?
dans le champ du jour de la semaine.-
9-15
dans le champ "heures", cela signifie que les heures comprennent 9, 10, 11, 12, 13, 14 et 15.,
MON, FRI, SAT
dans le champ jour de la semaine, cela signifie que les jours de la semaine comprennent le lundi, le vendredi et le samedi./
/
détermine son incrément, tandis que la valeur placée après le /
détermine son incrémentation. Par exemple, si vous placez 1/7
dans le champ minutes, cela signifie que les minutes comprennent 1, 8, 15, 22, 29, 36, 43, 50 et 57.L
Last
et a une signification différente selon le champ utilisé. S’il est utilisé avec le champ jour du mois, il représente le dernier jour du mois. S’il est utilisé seul avec le champ Jour de la semaine, il représente le dernier jour de la semaine, qui est samedi (SAT
). S’il est utilisé avec le champ Jour de la semaine, conjointement avec une autre valeur, il représente le dernier jour de ce type pour le mois. Par exemple, si vous placez 5L
dans le champ jour de la semaine, uniquement inclut le dernier vendredi du mois.W
18W
dans le champ du jour du mois et que le 18 du mois était un samedi, il se déclenche le vendredi 17, qui est le jour de semaine le plus proche. Si le 18 de ce mois était un dimanche, il se déclencherait le lundi 19, qui est le jour de semaine le plus proche. Notez que si vous placez 1W
dans le champ Jour du mois et que le jour de semaine le plus proche se trouve dans le mois précédent, l’événement se déclenche toujours le jour de semaine le plus proche du mois actif.De plus, vous pouvez combiner
L
et W
pour créer LW
, ce qui spécifie le dernier jour de semaine du mois.#
#
représente le jour de la semaine, tandis que la valeur placée après le #
représente l’occurrence du mois qu’elle est. Par exemple, si vous mettez 1#3
, l’événement se déclenche le troisième dimanche du mois. Notez que si vous mettez X#5
et qu’il n’y a pas de cinquième occurrence de ce jour de la semaine ce mois-ci, l’événement sera et non déclenché. Par exemple, si vous mettez 1#5
et qu’il n’y a pas cinq dimanches pendant ce mois, l’événement sera not déclenché.Exemples
Le tableau suivant présente des exemples de chaînes d’expression cron et explique leur signification.
0 0 13 * * ?
0 30 9 * * ? 2022
0 * 18 * * ?
0 0/10 17 * * ?
0 13,38 5 ? 6 WED
0 30 12 ? * 4#3
0 30 12 ? * 6L
0 45 11 ? * MON-THU