Appeler un webservice
Généralités
L'action « Webservice » permet d'appeler un système tiers et, éventuellement, de lui transmettre des données, dont celles issues de formulaires de demandes d'usagers ayant atteint le statut qui contient cette action.
Édition
Les étapes d'édition de l'action « Webservice » sont les suivantes :
-
Indiquer le libellé de l'appel du webservice.
-
Saisir l'URL du webservice sollicité.
- Le champ « URL » est obligatoire.
- L'URL peut contenir des variables, pour afficher une information particulière. Dans « Données à envoyer en paramètres à l'URL », on peut spécifier un couple clé/valeur. Par exemple en utilisant email et {{session_user_email}}, on va pouvoir former une URL qui sera https://www.example.net/notify?email={{session_user_email}}
-
Choisir la méthode utilisée
-
GET : pour récupérer un élément
-
POST : Pour envoyer un élément
-
PUT : Pour créer un élément
-
PATCH : Pour mettre à jour un élément
-
DELETE : pour effacer un élément
Si aucune donnée n'est indiquée et que le formulaire ne doit pas être transmis, alors la requête HTTP effectuée est un GET sur l'URL. -
-
Dé/Cocher la case « Envoyer les données du formulaire ».
Ce choix est proposé si méthode POST, PUT ou PATCH choisie. Cochée, la case indique que l'ensemble des données du formulaire doit être transmis, avec un appel dont le contenu correspondra au formulaire encodé au format JSON, comme décrit sur cette page sur l'API.
Si la case « Envoyer les données du formulaire » est cochée et que des « Données à envoyer dans le corps de la requête » sont indiquées, alors ces dernières sont ajoutées dans le JSON du formulaire, dans une clé « extra ». -
« Données à envoyer dans le corps de la requête » permet d'indiquer les données qui seront transmises sous la forme d'un dictionnaire clé-valeur au format JSON.
-
Sur chaque ligne, la colonne de gauche est le nom de la clé, celle de droite, la valeur.
Exemple
Ce tableau de valeurs :
code_appel
w.c.s.
form_number
{{form_number}}
formera ce JSON :
{ "code_appel": "w.c.s.", "form_number": "4" }
-
Le paramètre « Identifiant » permet d'enregistrer le résultat retourné par l'appel dans une variable du type {{ form_workflow_data_IDENTIFIANT_response_XXX }} . Quand la réponse correspond au format classique des API Publik, on aura :
-
{{ form_workflow_data_IDENTIFIANT_response_data }} pour récupérer les données retournées en JSON,
- {{ form_workflow_data_IDENTIFIANT_response_data.0 }} pour récupérer le premier enregistrement d'un tableau JSON,
- {{ form_workflow_data_IDENTIFIANT_response_data.0.NOM-COLONNE }} pour récupérer la valeur d'une colonne du tableau pour un enregistrement donné,
-
{{ form_workflow_data_IDENTIFIANT_status }} pour récupérer le statut http de la requête (200 signifie qu'elle s'est bien passée),
- {{ form_workflow_data_IDENTIFIANT_response_err }} pour récupérer les erreurs (1 signifie qu'il y a eu une erreur, 0 signifie qu'il n'y en a pas eu)
-
{{ form_workflow_data_IDENTIFIANT_response_data }} mais plutôt dans
{{ form_workflow_data_IDENTIFIANT_response_results }}