Automatisation n8n : gestion des erreurs et réponses Slack
- Ce workflow n8n est conçu pour automatiser la gestion des erreurs et des réponses via Slack, offrant ainsi une solution efficace pour les équipes qui souhaitent améliorer leur communication et leur réactivité. Dans un environnement professionnel où chaque minute compte, ce type d'automatisation permet de réduire les temps d'attente et d'assurer un suivi rapide des incidents. Les cas d'usage incluent la notification d'erreurs lors de l'exécution de processus, ce qui est essentiel pour maintenir la fluidité des opérations.
- Le workflow débute avec un déclencheur de type Webhook, permettant de recevoir des données en temps réel. Ensuite, il utilise des noeuds tels que 'Extract From File' pour traiter les fichiers entrants, suivi par des noeuds de type 'Switch' pour diriger le flux en fonction des conditions définies. En cas d'erreur, le noeud 'Send to Error Channel' envoie une notification sur Slack, tandis que les noeuds 'Success Response' et 'Error Response' gèrent les réponses appropriées. Les noeuds d'agrégation permettent de compiler les données nécessaires pour une analyse approfondie, garantissant que toutes les informations pertinentes sont disponibles.
- Les bénéfices de cette automatisation n8n sont multiples : elle permet de gagner du temps, d'améliorer la communication au sein des équipes et de réduire le risque d'erreurs humaines. En intégrant des notifications Slack, les utilisateurs peuvent réagir rapidement aux problèmes, ce qui améliore la satisfaction client et l'efficacité opérationnelle.
Workflow n8n Slack, gestion des erreurs, communication : vue d'ensemble
Schéma des nœuds et connexions de ce workflow n8n, généré à partir du JSON n8n.
Workflow n8n Slack, gestion des erreurs, communication : détail des nœuds
Inscris-toi pour voir l'intégralité du workflow
Inscription gratuite
S'inscrire gratuitementBesoin d'aide ?{
"nodes": [
{
"id": "b73fed9b-d56c-4175-a310-8c09ed51acd2",
"name": "Sticky Note1",
"type": "n8n-nodes-base.stickyNote",
"position": [
80,
60
],
"parameters": {
"width": 464,
"height": 303,
"content": "## Testing \n\nTesting can be done with CURL or similar.\n\nFor File posting using Form Data\ncurl -X POST \"https://yoururl.com/webhook-test/tool/csv-to-json\" \\\n -H \"Content-Type: text/csv\" \\\n --data-binary @path/to/your/file.csv\n\n\nThis can also be tested using the Test workflow"
},
"typeVersion": 1
},
{
"id": "6ed4b2cc-444f-44e2-ab91-34337acd7a9b",
"name": "Sticky Note3",
"type": "n8n-nodes-base.stickyNote",
"position": [
1680,
580
],
"parameters": {
"color": 4,
"width": 396,
"height": 256,
"content": "## Response\nWhere possible we will be returning a binary object.\n```\nIf there is an error\n```\n{\n \"status\": \"error\",\n \"data\": \"error message to display\"\n}\n```"
},
"typeVersion": 1
},
{
"id": "4eff962e-e636-4704-835a-672ccd705e16",
"name": "Extract From File",
"type": "n8n-nodes-base.extractFromFile",
"onError": "continueErrorOutput",
"position": [
680,
80
],
"parameters": {
"options": {},
"binaryPropertyName": "data0"
},
"typeVersion": 1
},
{
"id": "ccc66f1e-e000-4048-a492-b80fbf8c8fce",
"name": "Error Response",
"type": "n8n-nodes-base.respondToWebhook",
"onError": "continueErrorOutput",
"position": [
1900,
900
],
"parameters": {
"options": {
"responseCode": 500
},
"respondWith": "json",
"responseBody": "{\n \"status\": \"error\",\n \"data\": \"There was a problem converting your CSV. Please refresh the page and try again.\"\n}"
},
"typeVersion": 1
},
{
"id": "a7d34aba-6ded-4cc8-8866-7d4aa6ae3255",
"name": "Success Response",
"type": "n8n-nodes-base.respondToWebhook",
"onError": "continueErrorOutput",
"position": [
1920,
220
],
"parameters": {
"options": {
"responseCode": 200
},
"respondWith": "json",
"responseBody": "={\n \"status\": \"OK\",\n \"data\": {{ JSON.stringify($json.jsondata) }}\n}"
},
"typeVersion": 1
},
{
"id": "3484b148-4ba5-4b54-9401-44010ac31178",
"name": "Change Field",
"type": "n8n-nodes-base.set",
"onError": "continueErrorOutput",
"position": [
680,
320
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "b2e3bec3-221e-4f1d-b439-f75174f68ed1",
"name": "csv",
"type": "string",
"value": "={{ $json.body }}"
}
]
}
},
"typeVersion": 3.3
},
{
"id": "f35635fe-8943-486b-b5fa-4f566dd8f938",
"name": "Sticky Note4",
"type": "n8n-nodes-base.stickyNote",
"position": [
60,
40
],
"parameters": {
"color": 7,
"width": 2298,
"height": 1027,
"content": ""
},
"typeVersion": 1
},
{
"id": "cede2fad-f0ee-4082-a403-81f6d8eb188e",
"name": "Switch",
"type": "n8n-nodes-base.switch",
"position": [
340,
400
],
"parameters": {
"rules": {
"values": [
{
"outputKey": "File",
"conditions": {
"options": {
"version": 1,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"operator": {
"type": "object",
"operation": "notEmpty",
"singleValue": true
},
"leftValue": "={{ $binary }}",
"rightValue": ""
}
]
},
"renameOutput": true
},
{
"outputKey": "Data/Text",
"conditions": {
"options": {
"version": 1,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "8930ce1a-a4cc-4094-b08f-a23a13dec40c",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.headers['content-type'] }}",
"rightValue": "text/plain"
}
]
},
"renameOutput": true
},
{
"outputKey": "appJSON",
"conditions": {
"options": {
"version": 1,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "e3108952-daa2-425c-8c70-7d2ce0949e0c",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.headers['content-type'] }}",
"rightValue": "=application/json"
}
]
},
"renameOutput": true
}
]
},
"options": {
"fallbackOutput": "extra"
}
},
"typeVersion": 3
},
{
"id": "a2d92aeb-25eb-4d3c-82ad-16d2124099a8",
"name": "Send to Error Channel",
"type": "n8n-nodes-base.slack",
"position": [
2380,
880
],
"webhookId": "d8e1201d-cbcc-4153-a164-51d7b3e17c84",
"parameters": {
"text": ":interrobang: Error in XML to JSON tool",
"select": "channel",
"blocksUi": "={\n\t\"blocks\": [\n{\n\t\t\t\"type\": \"section\",\n\t\t\t\"text\": {\n\t\t\t\t\"type\": \"mrkdwn\",\n\t\t\t\t\"text\": \":interrobang: Error in CSV to JSON tool\"\n\t\t\t}\n\t\t},\n\t\t{\n\t\t\t\"type\": \"section\",\n\t\t\t\"text\": {\n\t\t\t\t\"type\": \"mrkdwn\",\n\t\t\t\t\"text\": \"*Time:*\\n{{ $now.format('dd/MM/yyyy HH:mm:ss') }}\\n*Execution ID:*\\n{{ $execution.id }}\\n\"\n\t\t\t},\n\t\t\t\"accessory\": {\n\t\t\t\t\"type\": \"button\",\n\t\t\t\t\"text\": {\n\t\t\t\t\t\"type\": \"plain_text\",\n\t\t\t\t\t\"text\": \"Go to Error\",\n\t\t\t\t\t\"emoji\": true\n\t\t\t\t},\n\t\t\t\t\"value\": \"error\",\n\t\t\t\t\"url\": \"[insert URL here]{{ $workflow.id }}/executions/{{ $execution.id }}\",\n\t\t\t\t\"action_id\": \"button-action\",\n\t\t\t\t\"style\": \"primary\"\n\t\t\t}\n\t\t}\n\t]\n}",
"channelId": {
"__rl": true,
"mode": "id",
"value": "C0832GBAEN4"
},
"messageType": "block",
"otherOptions": {},
"authentication": "oAuth2"
},
"typeVersion": 2.1
},
{
"id": "b21c88d1-6f21-4ada-95ef-8ea91463e7ad",
"name": "Convert Raw Text To CSV",
"type": "n8n-nodes-base.code",
"onError": "continueRegularOutput",
"position": [
940,
300
],
"parameters": {
"jsCode": "const csvData = $input.all()[0]?.json?.csv;\n\n// Use a regex to split on either ',' or ';'\nconst lines = csvData.split(\"\\n\");\nconst headers = lines[0].split(/,|;/);\n\nconst jsonData = lines.slice(1).map((line) => {\n // Split on ',' or ';' for each line\n const data = line.split(/,|;/);\n let obj = {};\n headers.forEach((header, i) => {\n obj[header] = data[i];\n });\n return obj;\n});\n\nif (jsonData.length === 0) {\n throw new Error(\"No data to process\");\n}\n\nreturn jsonData;\n"
},
"typeVersion": 2,
"alwaysOutputData": true
},
{
"id": "a9803789-0397-4f5f-9cd2-cb630f983efc",
"name": "Sticky Note",
"type": "n8n-nodes-base.stickyNote",
"position": [
2380,
40
],
"parameters": {
"color": 7,
"width": 700,
"height": 600,
"content": "## Sample of Raw CSV Data Send\nUse the HTTP request node below to see how to send the Raw CSV data into this workflow. Don't forget to include the \\n's "
},
"typeVersion": 1
},
{
"id": "8fb97224-706b-41de-a7ab-cbe2191436e9",
"name": "Check if Value",
"type": "n8n-nodes-base.if",
"position": [
1180,
300
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "d8d4cfda-f384-4154-8ad2-c3eabcb8c7ce",
"operator": {
"type": "string",
"operation": "notExists",
"singleValue": true
},
"leftValue": "={{ $json.error }}",
"rightValue": ""
}
]
}
},
"typeVersion": 2.2
},
{
"id": "4484f424-429b-449f-85c2-dd6a135972a0",
"name": "Send Raw CSV",
"type": "n8n-nodes-base.httpRequest",
"position": [
2480,
200
],
"parameters": {
"url": "[insert URL here]",
"body": "album, year, US_peak_chart_post\nThe White Stripes, 1999, -\nDe Stijl, 2000, -\nWhite Blood Cells, 2001, 61\nElephant, 2003, 6\nGet Behind Me Satan, 2005, 3\nIcky Thump, 2007, 2\nUnder Great White Northern Lights, 2010, 11\nLive in Mississippi, 2011, -\nLive at the Gold Dollar, 2012, -\nNine Miles from the White City, 2013, -\n",
"method": "POST",
"options": {
"response": {
"response": {
"responseFormat": "file"
}
}
},
"sendBody": true,
"contentType": "raw",
"rawContentType": "text/plain"
},
"typeVersion": 4.2
},
{
"id": "70a46bce-32da-4868-a960-3ee1cefbed1f",
"name": "POST",
"type": "n8n-nodes-base.webhook",
"position": [
140,
420
],
"webhookId": "add125c9-1591-4e1c-b68c-8032b99b6010",
"parameters": {
"path": "tool/csv-to-json",
"options": {
"binaryPropertyName": "data"
},
"httpMethod": "POST",
"responseMode": "responseNode"
},
"typeVersion": 1.1
},
{
"id": "116cfc2c-6e5f-4367-8c80-e1341e7d196a",
"name": "Aggregate",
"type": "n8n-nodes-base.aggregate",
"position": [
1580,
220
],
"parameters": {
"options": {},
"aggregate": "aggregateAllItemData",
"destinationFieldName": "jsondata"
},
"typeVersion": 1
},
{
"id": "967dc555-2599-4fb0-b3e1-00164bae4120",
"name": "Aggregate1",
"type": "n8n-nodes-base.aggregate",
"position": [
1580,
360
],
"parameters": {
"options": {},
"aggregate": "aggregateAllItemData",
"destinationFieldName": "jsondata"
},
"typeVersion": 1
},
{
"id": "51c77def-cdf7-41da-bfd1-e585f0553672",
"name": "Success Response2",
"type": "n8n-nodes-base.respondToWebhook",
"onError": "continueErrorOutput",
"position": [
1900,
400
],
"parameters": {
"options": {
"responseCode": 200
},
"respondWith": "json",
"responseBody": "={{ JSON.stringify($json.jsondata) }}"
},
"typeVersion": 1
}
],
"pinData": {},
"connections": {
"POST": {
"main": [
[
{
"node": "Switch",
"type": "main",
"index": 0
}
]
]
},
"Switch": {
"main": [
[
{
"node": "Extract From File",
"type": "main",
"index": 0
}
],
[
{
"node": "Change Field",
"type": "main",
"index": 0
}
],
[
{
"node": "Error Response",
"type": "main",
"index": 0
}
],
[
{
"node": "Error Response",
"type": "main",
"index": 0
}
]
]
},
"Aggregate": {
"main": [
[
{
"node": "Success Response",
"type": "main",
"index": 0
}
]
]
},
"Aggregate1": {
"main": [
[
{
"node": "Success Response2",
"type": "main",
"index": 0
}
]
]
},
"Change Field": {
"main": [
[
{
"node": "Convert Raw Text To CSV",
"type": "main",
"index": 0
}
],
[
{
"node": "Error Response",
"type": "main",
"index": 0
}
]
]
},
"Check if Value": {
"main": [
[
{
"node": "Aggregate1",
"type": "main",
"index": 0
}
],
[
{
"node": "Error Response",
"type": "main",
"index": 0
}
]
]
},
"Error Response": {
"main": [
[
{
"node": "Send to Error Channel",
"type": "main",
"index": 0
}
],
[
{
"node": "Send to Error Channel",
"type": "main",
"index": 0
}
]
]
},
"Success Response": {
"main": [
[],
[
{
"node": "Send to Error Channel",
"type": "main",
"index": 0
}
]
]
},
"Extract From File": {
"main": [
[
{
"node": "Aggregate",
"type": "main",
"index": 0
}
],
[
{
"node": "Error Response",
"type": "main",
"index": 0
}
]
]
},
"Success Response2": {
"main": [
[],
[
{
"node": "Send to Error Channel",
"type": "main",
"index": 0
}
]
]
},
"Convert Raw Text To CSV": {
"main": [
[
{
"node": "Check if Value",
"type": "main",
"index": 0
}
]
]
}
}
}Workflow n8n Slack, gestion des erreurs, communication : pour qui est ce workflow ?
Ce workflow s'adresse aux équipes techniques et aux responsables de projets dans les entreprises de taille moyenne à grande, cherchant à optimiser leur communication interne et à automatiser la gestion des erreurs. Un niveau technique intermédiaire est recommandé pour la mise en place et la personnalisation du workflow.
Workflow n8n Slack, gestion des erreurs, communication : problème résolu
Ce workflow résout le problème de la gestion des erreurs en automatisant les notifications sur Slack, ce qui permet d'éviter des retards dans la réponse aux incidents. En éliminant le besoin de surveillance manuelle, il réduit le risque d'erreurs humaines et garantit que les équipes sont toujours informées des problèmes en temps réel. Les utilisateurs bénéficient d'une meilleure réactivité et d'une communication plus fluide, ce qui se traduit par une efficacité accrue dans la gestion des opérations.
Workflow n8n Slack, gestion des erreurs, communication : étapes du workflow
Étape 1 : Le workflow est déclenché par un Webhook qui reçoit des données.
- Étape 1 : Les données sont extraites d'un fichier à l'aide du noeud 'Extract From File'.
- Étape 2 : Un noeud 'Switch' détermine le chemin à suivre en fonction des conditions définies.
- Étape 3 : En cas d'erreur, le noeud 'Send to Error Channel' envoie une notification sur Slack.
- Étape 4 : Les noeuds 'Success Response' et 'Error Response' gèrent les réponses appropriées selon le résultat du traitement.
- Étape 5 : Les noeuds d'agrégation compilent les données pour une analyse approfondie.
Workflow n8n Slack, gestion des erreurs, communication : guide de personnalisation
Pour personnaliser ce workflow, vous pouvez modifier l'URL du Webhook dans le noeud 'POST' pour l'adapter à votre application. Les paramètres du noeud 'Send to Error Channel' permettent de choisir le canal Slack où les notifications seront envoyées. Vous pouvez également ajuster les conditions dans le noeud 'Check if Value' pour définir des critères spécifiques qui déclenchent les notifications. Enfin, si vous souhaitez intégrer d'autres outils, envisagez d'ajouter des noeuds supplémentaires pour enrichir le flux de données.