Workflow n8n

Automatisation Odoo avec n8n : chatbot AI pour ventes

Ce workflow n8n est conçu pour automatiser la gestion des ventes dans le module Odoo à l'aide d'un chatbot AI. Dans un contexte où les entreprises cherchent à optimiser leurs processus de vente, ce système permet d'extraire, de résumer et de traiter les opportunités de vente de manière efficace. Grâce à l'intégration de l'intelligence artificielle, les utilisateurs peuvent interagir avec le système pour obtenir des résumés et des analyses des données de vente en temps réel. Le workflow commence par un déclencheur programmé qui active le processus à intervalles réguliers. Ensuite, il utilise le nœud 'Get All Opportunities from Odoo' pour récupérer toutes les opportunités de vente. Ces données sont ensuite traitées par le nœud 'Summarize Opportunities', qui utilise un modèle de résumé AI pour générer des insights pertinents. Si un résumé existe déjà, le workflow le lit à partir d'un fichier pour éviter les doublons. Les résultats sont ensuite convertis en fichiers et sauvegardés pour une consultation ultérieure. Ce système offre une valeur ajoutée significative en réduisant le temps consacré à l'analyse manuelle des données et en fournissant des informations exploitables pour les équipes de vente.

Tags clés :automatisationOdoochatbot AIn8nventes
Catégorie: Scheduled · Tags: automatisation, Odoo, chatbot AI, n8n, ventes0

Workflow n8n Odoo, chatbot AI, ventes : vue d'ensemble

Schéma des nœuds et connexions de ce workflow n8n, généré à partir du JSON n8n.

Workflow n8n Odoo, chatbot AI, ventes : détail des nœuds

  • Window Buffer Memory

    Ce noeud gère la mémoire tampon de la fenêtre pour stocker les données de session.

  • OpenAI Chat Model

    Ce noeud utilise le modèle de chat d'OpenAI pour générer des réponses basées sur des entrées textuelles.

  • Calculator

    Ce noeud effectue des calculs mathématiques en utilisant les outils de calcul intégrés.

  • Schedule Trigger

    Ce noeud déclenche le workflow selon un calendrier défini.

  • Convert to File

    Ce noeud convertit des données en fichiers selon les options spécifiées.

  • Save Summary to File

    Ce noeud enregistre un résumé dans un fichier selon les paramètres fournis.

  • Get All Opportunities from Odoo

    Ce noeud récupère toutes les opportunités depuis Odoo en fonction des options spécifiées.

  • Read Summary From File

    Ce noeud lit un résumé à partir d'un fichier en utilisant le sélecteur de fichiers.

  • If Summary Exists

    Ce noeud vérifie si un résumé existe en fonction des conditions définies.

  • Merge Opportunities

    Ce noeud fusionne les opportunités en utilisant les options d'agrégation fournies.

  • Extract Text From File

    Ce noeud extrait du texte à partir d'un fichier selon l'opération spécifiée.

  • AI Conversational Agent

    Ce noeud agit comme un agent conversationnel AI, traitant le texte et générant des réponses.

  • Summarize Opportunities

    Ce noeud résume les opportunités en utilisant les options de résumé fournies.

  • OpenAI Summarization Model

    Ce noeud utilise le modèle de résumé d'OpenAI pour condenser des informations en un format plus court.

  • Sticky Note

    Ce noeud crée une note autocollante avec le contenu et les dimensions spécifiées.

  • Chat Trigger

    Ce noeud déclenche le workflow en fonction des messages reçus dans un chat.

Inscris-toi pour voir l'intégralité du workflow

Inscription gratuite

S'inscrire gratuitementBesoin d'aide ?
{
  "id": "n8cwEZfJLGn15Lqx",
  "meta": {
    "instanceId": "d40a25503b797861fe81ffcf2649da2a83b8677ac1ef2ee6b6872aa9b52454b8",
    "templateCredsSetupCompleted": true
  },
  "name": "ERP AI chatbot for Odoo sales module",
  "tags": [],
  "nodes": [
    {
      "id": "abe58519-f3fe-4438-b6d6-d67071c70f0b",
      "name": "Window Buffer Memory",
      "type": "@n8n/n8n-nodes-langchain.memoryBufferWindow",
      "position": [
        1360,
        700
      ],
      "parameters": {
        "sessionKey": "={{ $('Chat Trigger').item.json.sessionId }}",
        "sessionIdType": "customKey"
      },
      "typeVersion": 1.2
    },
    {
      "id": "35b63108-e40d-494f-a0dc-5c8ea296c75f",
      "name": "OpenAI Chat Model",
      "type": "@n8n/n8n-nodes-langchain.lmChatOpenAi",
      "position": [
        1240,
        700
      ],
      "parameters": {
        "options": {}
      },
      "credentials": {
        "openAiApi": {
          "id": "8F3dAS1qjFM6mYbD",
          "name": "OpenAi account"
        }
      },
      "typeVersion": 1
    },
    {
      "id": "91ff893c-917d-46c2-b27d-48e9799452a6",
      "name": "Calculator",
      "type": "@n8n/n8n-nodes-langchain.toolCalculator",
      "position": [
        1480,
        700
      ],
      "parameters": {},
      "typeVersion": 1
    },
    {
      "id": "b9c10744-c5b8-4949-a80f-d331746632fb",
      "name": "Schedule Trigger",
      "type": "n8n-nodes-base.scheduleTrigger",
      "position": [
        220,
        180
      ],
      "parameters": {
        "rule": {
          "interval": [
            {}
          ]
        }
      },
      "typeVersion": 1.2
    },
    {
      "id": "4fa016bf-3f4c-4bfd-8c11-0270002de533",
      "name": "Convert to File",
      "type": "n8n-nodes-base.convertToFile",
      "position": [
        1480,
        180
      ],
      "parameters": {
        "options": {},
        "operation": "toText",
        "sourceProperty": "response.text"
      },
      "typeVersion": 1.1
    },
    {
      "id": "f9f0f1ed-7ccf-4c97-8d28-91399b2a4440",
      "name": "Save Summary to File",
      "type": "n8n-nodes-base.readWriteFile",
      "position": [
        1700,
        180
      ],
      "parameters": {
        "options": {
          "append": false
        },
        "fileName": "cache.txt",
        "operation": "write"
      },
      "typeVersion": 1
    },
    {
      "id": "e9715c9d-7ebb-4f8c-b44e-a2ee69bf9618",
      "name": "Get All Opportunities from Odoo",
      "type": "n8n-nodes-base.odoo",
      "position": [
        460,
        180
      ],
      "parameters": {
        "options": {
          "fieldsList": [
            "won_status",
            "description",
            "email_from",
            "contact_name",
            "expected_revenue"
          ]
        },
        "resource": "opportunity",
        "operation": "getAll",
        "returnAll": true
      },
      "credentials": {
        "odooApi": {
          "id": "5XAxrqqPxY5dzcoP",
          "name": "Odoo account"
        }
      },
      "typeVersion": 1
    },
    {
      "id": "23b82fdb-656f-497f-84eb-4296581245ac",
      "name": "Read Summary From File",
      "type": "n8n-nodes-base.readWriteFile",
      "position": [
        540,
        540
      ],
      "parameters": {
        "options": {},
        "fileSelector": "cache.txt"
      },
      "typeVersion": 1,
      "alwaysOutputData": false
    },
    {
      "id": "8d702c53-9001-4f71-80c4-17786384caf0",
      "name": "If Summary Exists",
      "type": "n8n-nodes-base.if",
      "position": [
        760,
        540
      ],
      "parameters": {
        "options": {},
        "conditions": {
          "options": {
            "leftValue": "",
            "caseSensitive": true,
            "typeValidation": "strict"
          },
          "combinator": "and",
          "conditions": [
            {
              "id": "c65a538f-f6c8-41ff-bad3-a631a5063cbb",
              "operator": {
                "type": "string",
                "operation": "exists",
                "singleValue": true
              },
              "leftValue": "={{ $json.fileName }}",
              "rightValue": ""
            }
          ]
        }
      },
      "typeVersion": 2
    },
    {
      "id": "4007d6e3-2d6f-4edd-afee-7df3c7dd5236",
      "name": "Merge Opportunities",
      "type": "n8n-nodes-base.aggregate",
      "position": [
        700,
        180
      ],
      "parameters": {
        "options": {},
        "aggregate": "aggregateAllItemData"
      },
      "typeVersion": 1
    },
    {
      "id": "604de791-8351-47ed-897d-2b7fe7f0aa99",
      "name": "Extract Text From File",
      "type": "n8n-nodes-base.extractFromFile",
      "position": [
        1020,
        520
      ],
      "parameters": {
        "options": {},
        "operation": "text"
      },
      "typeVersion": 1
    },
    {
      "id": "ab68228c-7d02-4d36-8c43-10a387dc3085",
      "name": "AI Conversational Agent",
      "type": "@n8n/n8n-nodes-langchain.agent",
      "position": [
        1240,
        520
      ],
      "parameters": {
        "text": "={{ $('Chat Trigger').item.json.chatInput }}",
        "agent": "conversationalAgent",
        "options": {
          "humanMessage": "=TOOLS\n------\nAssistant can ask the user to use tools to look up information that may be helpful in answering the users original question. The tools the human can use are:\n\n{tools}\n\n{format_instructions}\n\nAnswer questions using only the following context: {{ $json.data }}.\n\n\nUSER'S INPUT\n--------------------\nHere is the user's input (remember to respond with a markdown code snippet of a json blob with a single action, and NOTHING else):\n\n{{input}} "
        },
        "promptType": "define"
      },
      "typeVersion": 1.6
    },
    {
      "id": "117af37c-7dda-4bba-a008-d67c876efa9d",
      "name": "Summarize Opportunities",
      "type": "@n8n/n8n-nodes-langchain.chainSummarization",
      "position": [
        1020,
        60
      ],
      "parameters": {
        "options": {
          "summarizationMethodAndPrompts": {
            "values": {
              "prompt": "=Write a summary of the following:\n\n\n{{ JSON.stringify($json.data) }}\n\nInclude important information such as won status and expected revenue for each opportunity. Also include a short description of each oppotunity and keep opportunities separate.\n\nCONCISE SUMMARY: ",
              "combineMapPrompt": "=Write a summary of the following:\n\n{{ JSON.stringify($json.data) }}\n\nInclude important information such as won status and expected revenue for each opportunity. Also include a short description of each oppotunity and keep opportunities separate.\n\nCONCISE SUMMARY: "
            }
          }
        }
      },
      "typeVersion": 2
    },
    {
      "id": "e6ae17c7-15db-4c9d-9ce9-4748eaf84359",
      "name": "OpenAI Summarization Model",
      "type": "@n8n/n8n-nodes-langchain.lmOpenAi",
      "position": [
        1000,
        220
      ],
      "parameters": {
        "model": {
          "__rl": true,
          "mode": "list",
          "value": "gpt-4-turbo",
          "cachedResultName": "gpt-4-turbo"
        },
        "options": {}
      },
      "credentials": {
        "openAiApi": {
          "id": "8F3dAS1qjFM6mYbD",
          "name": "OpenAi account"
        }
      },
      "typeVersion": 1
    },
    {
      "id": "0e3a0b55-62d0-43d0-a744-a7b7ab05c087",
      "name": "Sticky Note",
      "type": "n8n-nodes-base.stickyNote",
      "position": [
        200,
        -160
      ],
      "parameters": {
        "width": 446.44549763033154,
        "height": 261.8821936357484,
        "content": "# ERP chatbot for Odoo sales module\n\nSet up steps:\n* Configure the Odoo credentials\n* Configure OpenAI credentials\n* Toggle \"Make Chat Publicly Available\" from the Chat Trigger node."
      },
      "typeVersion": 1
    },
    {
      "id": "b9169b8d-7ff6-403f-b354-511c23d5da1c",
      "name": "Chat Trigger",
      "type": "@n8n/n8n-nodes-langchain.chatTrigger",
      "position": [
        220,
        540
      ],
      "webhookId": "09eea368-b78f-4209-9750-f28b706363c2",
      "parameters": {
        "public": true,
        "options": {}
      },
      "typeVersion": 1
    }
  ],
  "active": false,
  "pinData": {
    "Get All Opportunities from Odoo": [
      {
        "json": {
          "id": 6,
          "email_from": "contact@mihai.ltd",
          "won_status": "won",
          "description": "<p data-last-history-steps=\"1224754175503363,660472183033793\">\nAlex Mason, Procurement Manager at Innovative Solutions Inc., initially expressed strong interest in CloudConnect Pro for upcoming projects. They were impressed with its capabilities in cloud integration, data management, and flexibility. After successful discussions and negotiations, NovaTech Enterprises signed a contract for $19,000 to implement CloudConnect Pro for their enterprise-level needs. Project onboarding and deployment were completed successfully.\n\n<br></p>",
          "contact_name": false,
          "expected_revenue": 19000
        }
      },
      {
        "json": {
          "id": 5,
          "email_from": "contact@mihai.ltd",
          "won_status": "pending",
          "description": "<p>Mihai Farcas, Procurement Manager at Innovative Solutions Inc, is interested in incorporating CloudConnect Pro platform into their upcoming projects. They are impressed by its capabilities in cloud integration, data management, and flexibility. They request detailed information on pricing, implementation options, support services, and case studies for enterprise-level deployments. They are eager to learn more and hope for a mutually beneficial partnership. </p>",
          "contact_name": false,
          "expected_revenue": 17000
        }
      }
    ]
  },
  "settings": {
    "executionOrder": "v1"
  },
  "versionId": "315972c0-e19d-4978-88ea-9fe721de3631",
  "connections": {
    "Calculator": {
      "ai_tool": [
        [
          {
            "node": "AI Conversational Agent",
            "type": "ai_tool",
            "index": 0
          }
        ]
      ]
    },
    "Chat Trigger": {
      "main": [
        [
          {
            "node": "Read Summary From File",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Convert to File": {
      "main": [
        [
          {
            "node": "Save Summary to File",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Schedule Trigger": {
      "main": [
        [
          {
            "node": "Get All Opportunities from Odoo",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "If Summary Exists": {
      "main": [
        [
          {
            "node": "Extract Text From File",
            "type": "main",
            "index": 0
          }
        ],
        [
          {
            "node": "Get All Opportunities from Odoo",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "OpenAI Chat Model": {
      "ai_languageModel": [
        [
          {
            "node": "AI Conversational Agent",
            "type": "ai_languageModel",
            "index": 0
          }
        ]
      ]
    },
    "Merge Opportunities": {
      "main": [
        [
          {
            "node": "Summarize Opportunities",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Save Summary to File": {
      "main": [
        [
          {
            "node": "Read Summary From File",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Window Buffer Memory": {
      "ai_memory": [
        [
          {
            "node": "AI Conversational Agent",
            "type": "ai_memory",
            "index": 0
          }
        ]
      ]
    },
    "Extract Text From File": {
      "main": [
        [
          {
            "node": "AI Conversational Agent",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Read Summary From File": {
      "main": [
        [
          {
            "node": "If Summary Exists",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "Summarize Opportunities": {
      "main": [
        [
          {
            "node": "Convert to File",
            "type": "main",
            "index": 0
          }
        ]
      ]
    },
    "OpenAI Summarization Model": {
      "ai_languageModel": [
        [
          {
            "node": "Summarize Opportunities",
            "type": "ai_languageModel",
            "index": 0
          }
        ]
      ]
    },
    "Get All Opportunities from Odoo": {
      "main": [
        [
          {
            "node": "Merge Opportunities",
            "type": "main",
            "index": 0
          }
        ]
      ]
    }
  }
}

Workflow n8n Odoo, chatbot AI, ventes : pour qui est ce workflow ?

Ce workflow s'adresse aux entreprises utilisant Odoo pour la gestion de leurs ventes, ainsi qu'aux équipes commerciales cherchant à automatiser leurs processus. Il est idéal pour les PME et les grandes entreprises qui souhaitent intégrer des solutions d'intelligence artificielle sans nécessiter de compétences techniques avancées.

Workflow n8n Odoo, chatbot AI, ventes : problème résolu

Ce workflow résout le problème de la gestion manuelle des données de vente, qui peut être chronophage et sujet à des erreurs. En automatisant l'extraction et le résumé des opportunités de vente, il permet aux équipes de se concentrer sur des tâches à plus forte valeur ajoutée. Les utilisateurs bénéficient d'une meilleure visibilité sur leurs performances commerciales et d'une prise de décision plus rapide grâce à des insights pertinents fournis par le chatbot AI.

Workflow n8n Odoo, chatbot AI, ventes : étapes du workflow

Étape 1 : Le workflow est déclenché par un nœud 'Schedule Trigger' qui active le processus à des intervalles définis.

  • Étape 1 : Il récupère toutes les opportunités de vente à l'aide du nœud 'Get All Opportunities from Odoo'.
  • Étape 2 : Les données sont ensuite résumées grâce au nœud 'Summarize Opportunities', qui utilise un modèle AI pour générer des insights.
  • Étape 3 : Si un résumé existe déjà, le workflow le lit à partir d'un fichier avec le nœud 'Read Summary From File'.
  • Étape 4 : Les résultats sont convertis en fichiers et sauvegardés pour une utilisation future via le nœud 'Convert to File'.

Workflow n8n Odoo, chatbot AI, ventes : guide de personnalisation

Pour personnaliser ce workflow, vous pouvez ajuster les paramètres du nœud 'Schedule Trigger' pour définir la fréquence d'exécution selon vos besoins. Il est également possible de modifier les options du nœud 'Get All Opportunities from Odoo' pour cibler des données spécifiques. Si vous souhaitez intégrer d'autres outils, vous pouvez ajouter des nœuds supplémentaires pour enrichir le flux de travail. Assurez-vous de sécuriser le flux en configurant correctement les accès aux fichiers et aux données sensibles.