{ "id": "HMoUOg8J7RzEcslH", "meta": { "instanceId": "workflow-75a55aae", "versionId": "1.0.0", "createdAt": "2025-09-29T07:07:51.139257", "updatedAt": "2025-09-29T07:07:51.139309", "owner": "n8n-user", "license": "MIT", "category": "automation", "status": "active", "priority": "high", "environment": "production" }, "name": "Extract personal data with a self-hosted LLM Mistral NeMo", "tags": [ "automation", "n8n", "production-ready", "excellent", "optimized" ], "nodes": [ { "id": "trigger-6738e2ae", "name": "Manual Trigger", "type": "n8n-nodes-base.manualTrigger", "typeVersion": 1, "position": [ 100, 100 ], "parameters": {} }, { "id": "7e67ae65-88aa-4e48-aa63-2d3a4208cf4b", "name": "When chat message received", "type": "n8n-nodes-base.noOp", "position": [ -500, 20 ], "webhookId": "3a7b0ea1-47f3-4a94-8ff2-f5e1f3d9dc32", "parameters": { "options": {} }, "typeVersion": 1.1, "notes": "This chatTrigger node performs automated tasks as part of the workflow." }, { "id": "e064921c-69e6-4cfe-a86e-4e3aa3a5314a", "name": "Ollama Chat Model", "type": "n8n-nodes-base.noOp", "position": [ -280, 420 ], "parameters": { "model": "mistral-nemo:latest", "options": { "useMLock": true, "keepAlive": "2h", "temperature": 0.1 } }, "credentials": { "ollamaApi": { "id": "vgKP7LGys9TXZ0KK", "name": "Ollama account" } }, "typeVersion": 1, "notes": "This lmChatOllama node performs automated tasks as part of the workflow." }, { "id": "fe1379da-a12e-4051-af91-9d67a7c9a76b", "name": "Auto-fixing Output Parser", "type": "n8n-nodes-base.noOp", "position": [ -200, 220 ], "parameters": { "options": { "prompt": "Instructions:\n--------------\n{instructions}\n--------------\nCompletion:\n--------------\n{completion}\n--------------\n\nAbove, the Completion did not satisfy the constraints given in the Instructions.\nError:\n--------------\n{error}\n--------------\n\nPlease try again. Please only respond with an answer that satisfies the constraints laid out in the Instructions:" } }, "typeVersion": 1, "notes": "This outputParserAutofixing node performs automated tasks as part of the workflow." }, { "id": "b6633b00-6ebb-43ca-8e5c-664a53548c17", "name": "Structured Output Parser", "type": "n8n-nodes-base.noOp", "position": [ 60, 400 ], "parameters": { "schemaType": "manual", "inputSchema": "{\n \"type\": \"object\",\n \"properties\": {\n \"name\": {\n \"type\": \"string\",\n \"description\": \"Name of the user\"\n },\n \"surname\": {\n \"type\": \"string\",\n \"description\": \"Surname of the user\"\n },\n \"commtype\": {\n \"type\": \"string\",\n \"enum\": [\"email\", \"phone\", \"other\"],\n \"description\": \"Method of communication\"\n },\n \"contacts\": {\n \"type\": \"string\",\n \"description\": \"Contact details. ONLY IF PROVIDED\"\n },\n \"timestamp\": {\n \"type\": \"string\",\n \"format\": \"date-time\",\n \"description\": \"When the communication occurred\"\n },\n \"subject\": {\n \"type\": \"string\",\n \"description\": \"Brief description of the communication topic\"\n }\n },\n \"required\": [\"name\", \"commtype\"]\n}" }, "typeVersion": 1.2, "notes": "This outputParserStructured node performs automated tasks as part of the workflow." }, { "id": "23681a6c-cf62-48cb-86ee-08d5ce39bc0a", "name": "Basic LLM Chain", "type": "n8n-nodes-base.noOp", "onError": "continueErrorOutput", "position": [ -240, 20 ], "parameters": { "messages": { "messageValues": [ { "message": "=Please analyse the incoming user request. Extract information according to the JSON schema. Today is: \"{{ $now.toISO() }}\"" } ] }, "hasOutputParser": true }, "typeVersion": 1.5, "notes": "This chainLlm node performs automated tasks as part of the workflow." }, { "id": "8f4d1b4b-58c0-41ec-9636-ac555e440821", "name": "On Error", "type": "n8n-nodes-base.noOp", "position": [ 200, 140 ], "parameters": {}, "typeVersion": 1, "notes": "This noOp node performs automated tasks as part of the workflow." }, { "id": "f4d77736-4470-48b4-8f61-149e09b70e3e", "name": "Sticky Note", "type": "n8n-nodes-base.stickyNote", "position": [ -560, -160 ], "parameters": { "color": 2, "width": 960, "height": 500, "content": "## Update data source\nWhen you change the data source, remember to update the `Prompt Source (User Message)` setting in the **Basic LLM Chain node**." }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "5fd273c8-e61d-452b-8eac-8ac4b7fff6c2", "name": "Sticky Note1", "type": "n8n-nodes-base.stickyNote", "position": [ -560, 340 ], "parameters": { "color": 2, "width": 440, "height": 220, "content": "## Configure local LLM\nOllama offers additional settings \nto optimize model performance\nor memory usage." }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "63cbf762-0134-48da-a6cd-0363e870decd", "name": "Sticky Note2", "type": "n8n-nodes-base.stickyNote", "position": [ 0, 340 ], "parameters": { "color": 2, "width": 400, "height": 220, "content": "## Define JSON Schema" }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "9625294f-3cb4-4465-9dae-9976e0cf5053", "name": "Extract JSON Output", "type": "n8n-nodes-base.set", "position": [ 200, -80 ], "parameters": { "mode": "raw", "options": {}, "jsonOutput": "={{ $json.output }}\n" }, "typeVersion": 3.4, "notes": "This set node performs automated tasks as part of the workflow." }, { "id": "2c6fba3b-0ffe-4112-b904-823f52cc220b", "name": "Sticky Note3", "type": "n8n-nodes-base.stickyNote", "position": [ -560, 200 ], "parameters": { "width": 960, "height": 120, "content": "If the LLM response does not pass \nthe **Structured Output Parser** checks,\n**Auto-Fixer** will call the model again with a different \nprompt to correct the original response." }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "c73ba1ca-d727-4904-a5fd-01dd921a4738", "name": "Sticky Note6", "type": "n8n-nodes-base.stickyNote", "position": [ -560, 460 ], "parameters": { "height": 80, "content": "The same LLM connects to both **Basic LLM Chain** and to the **Auto-fixing Output Parser**. \n" }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "193dd153-8511-4326-aaae-47b89d0cd049", "name": "Sticky Note7", "type": "n8n-nodes-base.stickyNote", "position": [ 200, 440 ], "parameters": { "width": 200, "height": 100, "content": "When the LLM model responds, the output is checked in the **Structured Output Parser**" }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." }, { "id": "error-7272efe5", "name": "Error Handler", "type": "n8n-nodes-base.stopAndError", "typeVersion": 1, "position": [ 1000, 400 ], "parameters": { "message": "Workflow execution error", "options": {} } } ], "active": false, "pinData": {}, "settings": { "executionOrder": "v1", "saveManualExecutions": true, "callerPolicy": "workflowsFromSameOwner", "errorWorkflow": null, "timezone": "UTC", "executionTimeout": 3600, "maxExecutions": 1000, "retryOnFail": true, "retryCount": 3, "retryDelay": 1000 }, "versionId": "9f3721a8-f340-43d5-89e7-3175c29c2f3a", "connections": {}, "description": "Automated workflow: Extract personal data with a self-hosted LLM Mistral NeMo. This workflow integrates 8 different services: stickyNote, chainLlm, outputParserStructured, set, outputParserAutofixing. It contains 13 nodes and follows best practices for error handling and security.", "notes": "Excellent quality workflow: Extract personal data with a self-hosted LLM Mistral NeMo. This workflow has been optimized for production use with comprehensive error handling, security, and documentation." }