Automatisation Docsify avec n8n : gestion de documents simplifiée
- Ce workflow n8n est conçu pour automatiser la gestion de documents en utilisant Docsify. Il permet aux utilisateurs de créer, modifier et extraire des fichiers de manière fluide, tout en intégrant des fonctionnalités avancées comme le traitement de texte et l'interaction avec des modèles de langage. Dans un contexte professionnel où la gestion documentaire est cruciale, ce workflow répond aux besoins des équipes qui cherchent à optimiser leur productivité et à réduire les erreurs humaines. Par exemple, une entreprise peut automatiser la création de rapports ou la mise à jour de documents en fonction des données entrantes.
- Le workflow commence par un déclencheur de type Webhook, qui active le processus lorsque des données sont reçues. Ensuite, il utilise des noeuds pour configurer les options nécessaires, convertir des fichiers, et vérifier si un fichier est présent. Si un fichier est détecté, il est extrait et traité pour en extraire les informations pertinentes. Les utilisateurs peuvent également interagir avec le workflow via des réponses en HTML ou Markdown, facilitant ainsi la communication des résultats. Les noeuds de traitement de texte, comme le modèle OpenAI Chat, permettent d'enrichir le contenu des documents générés.
- Les bénéfices de cette automatisation n8n sont multiples : réduction des délais de traitement, minimisation des erreurs, et amélioration de la collaboration au sein des équipes. En intégrant ce workflow, les entreprises peuvent se concentrer sur des tâches à plus forte valeur ajoutée tout en assurant une gestion documentaire efficace et fiable.
Workflow n8n Docsify, gestion de documents : vue d'ensemble
Schéma des nœuds et connexions de ce workflow n8n, généré à partir du JSON n8n.
Workflow n8n Docsify, gestion de documents : détail des nœuds
Inscris-toi pour voir l'intégralité du workflow
Inscription gratuite
S'inscrire gratuitementBesoin d'aide ?{
"id": "VY4TXYGmqth57Een",
"meta": {
"instanceId": "fb924c73af8f703905bc09c9ee8076f48c17b596ed05b18c0ff86915ef8a7c4a",
"templateCredsSetupCompleted": true
},
"name": "Docsify example",
"tags": [],
"nodes": [
{
"id": "f41906c3-ee4c-4333-bfd5-426f82ba4bd9",
"name": "CONFIG",
"type": "n8n-nodes-base.set",
"position": [
660,
60
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "b48986ec-f58d-4a7f-afba-677edcb28d31",
"name": "project_path",
"type": "string",
"value": "./.n8n/test_docs"
},
{
"id": "cf632419-f839-4045-922c-03784bb3ae07",
"name": "instance_url",
"type": "string",
"value": "={{$env[\"N8N_PROTOCOL\"]}}://{{$env[\"N8N_HOST\"]}}"
},
{
"id": "7a7c70a6-1853-4ca7-b5b1-e36bb0e190d0",
"name": "HTML_headers",
"type": "string",
"value": "= <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge,chrome=1\" />\n <meta name=\"viewport\" content=\"width=device-width,initial-scale=1\" />\n <meta charset=\"UTF-8\" />\n <link rel=\"stylesheet\" href=\"//cdn.jsdelivr.net/npm/docsify@4/themes/vue.css\" />\n <script src=\"https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js\"></script>"
},
{
"id": "1e785afe-f05f-4e51-a164-f341da81ccac",
"name": "HTML_styles_editor",
"type": "string",
"value": "= <style>\n body {\n margin: 0;\n padding: 0;\n overflow: hidden;\n }\n \n .container {\n display: flex;\n flex-direction: column;\n height: 100vh;\n margin: 0;\n }\n\n .button-container {\n display: flex;\n justify-content: center;\n gap: 10px;\n padding: 10px;\n background: #f8f8f8;\n border-bottom: 1px solid #eee;\n width: 50%;\n }\n\n .button {\n padding: 8px 16px;\n border: none;\n border-radius: 4px;\n cursor: pointer;\n font-size: 14px;\n }\n\n .save-button {\n background: #42b983;\n color: white;\n }\n\n .cancel-button {\n background: #666;\n color: white;\n }\n\n .editor-preview-container {\n display: flex;\n flex: 1;\n overflow: hidden;\n }\n \n #editor {\n width: 50%;\n height: 100%;\n resize: none;\n padding: 20px;\n box-sizing: border-box;\n font-family: monospace;\n border: none;\n border-right: 1px solid #eee;\n }\n \n .preview-container {\n width: 50%;\n height: 100%;\n overflow-y: auto;\n }\n\n /* Remove width from main */\n main {\n width: auto !important;\n }\n\n /* Fix code block wrapping */\n .markdown-section pre > code {\n white-space: pre-wrap !important;\n }\n </style>"
},
{
"id": "37e22865-7b6b-438d-83a0-dc680d4775cc",
"name": "HTML_docsify_include",
"type": "string",
"value": "= <script src=\"//cdn.jsdelivr.net/npm/docsify@4\"></script>"
}
]
},
"includeOtherFields": true
},
"typeVersion": 3.4
},
{
"id": "75cdf7fc-3dfa-49c1-bdbf-01d8be08aaa4",
"name": "Convert to File",
"type": "n8n-nodes-base.convertToFile",
"position": [
4020,
1600
],
"parameters": {
"options": {},
"operation": "toText",
"sourceProperty": "workflowdata"
},
"typeVersion": 1.1
},
{
"id": "3868011e-8374-496a-b3f5-4cbf7bde4e56",
"name": "HasFile?",
"type": "n8n-nodes-base.if",
"position": [
2400,
880
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "2d9feb22-49d1-4354-9b0b-b82da2b20678",
"operator": {
"type": "number",
"operation": "gt"
},
"leftValue": "={{ Object.keys($json).length }}",
"rightValue": 0
}
]
}
},
"typeVersion": 2.2
},
{
"id": "0bf2317b-2534-4022-9a16-395d4b44680c",
"name": "Extract from File",
"type": "n8n-nodes-base.extractFromFile",
"position": [
2660,
860
],
"parameters": {
"options": {},
"operation": "text",
"destinationKey": "workflowdata"
},
"typeVersion": 1
},
{
"id": "4b44a7f3-09bf-46a8-9520-247993af654b",
"name": "Main Page",
"type": "n8n-nodes-base.html",
"position": [
4660,
-100
],
"parameters": {
"html": "<!DOCTYPE html>\n<html>\n <head>\n{{ $('CONFIG').first().json.HTML_headers }}\n <body>\n <div data-app id=\"main\">Please wait...</div>\n <script>\n \n mermaid.initialize({\n startOnLoad: false,\n });\n let svgCounter = 0;\n\n window.$docsify = {\n el: '#main',\n auto2top: true,\n loadSidebar: 'summary.md',\n basePath: '{{ $json.webhookUrl.split($json.webhookUrl.extractDomain())[1] }}/',\n name: 'All Workflows',\n markdown: {\n renderer: {\n code(code, lang) {\n if (lang === \"mermaid\") {\n const svgName = `mermaid-svg-${svgCounter++}`;\n const MERMAID_CONTAINER_ID = `${svgName}-container`;\n mermaid.render(svgName, code).then(({ svg }) => {\n const containerElement = document.querySelector(\n `#${MERMAID_CONTAINER_ID}`\n );\n if (containerElement) {\n containerElement.innerHTML = svg;\n } else {\n console.error(`Error: #${MERMAID_CONTAINER_ID} not found`);\n }\n });\n return `<div class=\"mermaid\" id=\"${MERMAID_CONTAINER_ID}\"></div>`;\n }\n return this.origin.code.apply(this, arguments);\n },\n },\n }, \n plugins: [\n function(hook, vm) {\n hook.ready(function() {\n // Check if URL doesn't end with slash but also isn't a file path\n if (!window.location.pathname.endsWith('/') && !window.location.pathname.includes('.')) {\n // Use history.replaceState to avoid adding to browser history\n const newUrl = window.location.pathname + '/' + window.location.hash;\n window.history.replaceState(null, null, newUrl);\n }\n });\n }\n ], \n };\n </script>\n{{ $('CONFIG').first().json.HTML_docsify_include }}\n </body>\n</html>"
},
"typeVersion": 1.2
},
{
"id": "28c29cec-7efd-4f05-bf53-ac08cc3834a1",
"name": "Instance overview",
"type": "n8n-nodes-base.html",
"position": [
4660,
160
],
"parameters": {
"html": "# Your n8n instance workflows:\n\n| Workflow | Status | Docs | Created | Updated | Nodes | Triggers |\n|----------|:------:|------|---------|---------|-------|----------|\n{{ $jmespath($input.all(),'[].json.content').join('\\n') }}"
},
"executeOnce": true,
"typeVersion": 1.2
},
{
"id": "3e8eb52e-8d35-4aa3-a485-6674d67720dc",
"name": "Sort-workflows",
"type": "n8n-nodes-base.sort",
"position": [
2080,
160
],
"parameters": {
"options": {},
"sortFieldsUi": {
"sortField": [
{
"order": "descending",
"fieldName": "updatedAt"
}
]
}
},
"typeVersion": 1
},
{
"id": "2178e1cf-90b8-4779-9b5c-3d6180823c95",
"name": "doc action",
"type": "n8n-nodes-base.switch",
"position": [
1740,
1080
],
"parameters": {
"rules": {
"values": [
{
"outputKey": "view",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "ee386c7d-1abe-4864-bb3a-a19d3816c906",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "view"
}
]
},
"renameOutput": true
},
{
"outputKey": "edit",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "aa1a33ee-ac38-4ea4-9a4c-d355e7de1312",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "edit"
}
]
},
"renameOutput": true
},
{
"outputKey": "recreate",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "676c36e1-4c88-4314-9317-abc877ff3d17",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "recreate"
}
]
},
"renameOutput": true
},
{
"outputKey": "save",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "164314cf-7d99-4716-9949-b9196ce47959",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "save"
}
]
},
"renameOutput": true
}
]
},
"options": {
"fallbackOutput": "extra"
}
},
"typeVersion": 3.2
},
{
"id": "7f4aab9b-b7e8-4920-98e8-af8f504a1333",
"name": "Empty Set",
"type": "n8n-nodes-base.set",
"position": [
2000,
960
],
"parameters": {
"options": {}
},
"typeVersion": 3.4
},
{
"id": "1f35bc3e-29d7-47a2-a1c7-cf6052d99993",
"name": "Load Doc File",
"type": "n8n-nodes-base.readWriteFile",
"position": [
1900,
860
],
"parameters": {
"options": {},
"fileSelector": "={{ $('CONFIG').first().json.project_path }}/{{ $json.params.file }}"
},
"typeVersion": 1,
"alwaysOutputData": true
},
{
"id": "c0805f50-8f8c-49ba-b0c7-6768bf89798c",
"name": "Respond with markdown",
"type": "n8n-nodes-base.respondToWebhook",
"position": [
4920,
1040
],
"parameters": {
"options": {
"responseCode": 200,
"responseHeaders": {
"entries": [
{
"name": "Content-Type",
"value": "text/markdown"
}
]
}
},
"respondWith": "text",
"responseBody": "={{ $json.html }}"
},
"typeVersion": 1.1
},
{
"id": "9c7a18b9-a081-4162-94f4-e125d666cbcc",
"name": "Respond with HTML",
"type": "n8n-nodes-base.respondToWebhook",
"position": [
4920,
860
],
"parameters": {
"options": {
"responseCode": 200,
"responseHeaders": {
"entries": [
{
"name": "Content-Type",
"value": "text/html"
}
]
}
},
"respondWith": "text",
"responseBody": "={{ $json.html }}"
},
"typeVersion": 1.1
},
{
"id": "50944148-eb7c-4c28-99c5-478ddb2596f2",
"name": "Save New Doc File",
"type": "n8n-nodes-base.readWriteFile",
"position": [
4180,
1600
],
"parameters": {
"options": {},
"fileName": "={{ $('CONFIG').first().json.project_path }}/{{ $('CONFIG').first().json.params.file }}",
"operation": "write"
},
"typeVersion": 1,
"alwaysOutputData": true
},
{
"id": "6d7e0dcf-d12b-4428-9c5e-ef7fb2c6be28",
"name": "Blank Doc File",
"type": "n8n-nodes-base.set",
"position": [
4000,
1080
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "b168d9b1-1a13-4915-b59b-8a17258fd9cc",
"name": "workflowdata",
"type": "string",
"value": "=# {{ $json.name }}\n\n## Workflow Description\n!> Please write what is this workflow doing\n\n## Workflow schematic\n\n```mermaid\n{{ $json.mermaidChart }}\n```\n\n## Any further information\n\n> You can also add tables like this:\n\n| Parameter | Value |\n|-----------|-------|\n| Created | {{ $json.createdAt }} |\n| Last updated | {{ $json.updatedAt }} |\n| Author | {{ $json.shared[0].project.name }} |\n\n"
}
]
},
"includeOtherFields": true
},
"typeVersion": 3.4
},
{
"id": "778a97eb-f7a2-4537-81fc-979dc6c674a2",
"name": "Fetch Single Workflow1",
"type": "n8n-nodes-base.n8n",
"position": [
2820,
1200
],
"parameters": {
"operation": "get",
"workflowId": {
"__rl": true,
"mode": "id",
"value": "={{ $('CONFIG').first().json.params.file.replaceAll('docs_','').split('.md')[0] }}"
},
"requestOptions": {}
},
"credentials": {
"n8nApi": {
"id": "eW7IdTFt4ARJbEwR",
"name": "Ted n8n account"
}
},
"typeVersion": 1
},
{
"id": "092b8c67-77f9-4d4b-aa26-8f0e3ea3ed29",
"name": "Fill Workflow Table",
"type": "n8n-nodes-base.set",
"position": [
2280,
160
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "3bed44f3-7fa6-4d28-8a6e-7074ca354cd6",
"name": "content",
"type": "string",
"value": "=| [{{ `${$json.name.replace(/[|\\\\[\\]`_*{}()<>#+-]/g, '\\\\$&')}` }}]({{ `${$('CONFIG').first().json.instance_url}/workflow/${$json.id}` }} \"Click to open workflow in n8n\") | {{ $json.active ? '[:green_circle:](# \"Active\")' : '[:white_circle:](# \"Inactive\")' }} | <nobr>[:book:]({{ `docs_${$json.id}?action=view` }} \"View docs\") [:memo:]({{ `docs_${$json.id}.md?action=edit` }} \":ignore Edit\") [:arrows_counterclockwise:]({{ `docs_${$json.id}?action=recreate` }} \"Recreate docs\")</nobr> | <nobr>{{ `${new Date($json.createdAt).toISOString().replace('T', ' ').slice(0, 16)}` }}</nobr> | <nobr>{{ `${new Date($json.updatedAt).toISOString().replace('T', ' ').slice(0, 16)}` }}</nobr> | {{ $json.nodes.length }} | {{ $json.nodes.filter(n => n.type.includes('Trigger')).length }} |"
}
]
}
},
"executeOnce": false,
"typeVersion": 3.4
},
{
"id": "18c58a09-0dfe-4cb4-ae7f-503957eabadb",
"name": "Basic LLM Chain",
"type": "@n8n/n8n-nodes-langchain.chainLlm",
"onError": "continueRegularOutput",
"position": [
3480,
1200
],
"parameters": {
"text": "=Here's the workflow data:\n{{Object.assign(\n Object.fromEntries(Object.entries($json).filter(([key]) => !['staticData', 'pinData'].includes(key))),\n {nodes: $json.nodes.map(node => Object.fromEntries(Object.entries(node).filter(([key]) => !['id', 'position'].includes(key))))}\n).toJsonString() }}",
"messages": {
"messageValues": [
{
"message": "=Your task is to generate simple workflow documentation for the n8n workflows. The user will provide a JSON structure. Reply \nin JSON format in 2 sections: workflow_desription and nodes_settings. Important! Each json key should be a simple markdown text without any additional comments or remarks from your end.\n\nInstruction for `workflow_desription`:\n```\n## Section header with H2\n\\n\n> subline with who created workflow and when, when it was last edited and the status (active / inactive as the green / grey round emoji). Also, when the documentation was generated. Now is: {{ $now }}.\n\\n\\n\nShould contain a description of the workflow. in a couple of paragraphs. Use direct voice without the fluff\n```\n\nInstruction for `nodes_settings`:\n```\n## Section header with H2.\n\\n\n### Node 1 name as H3 title\n - For each node make a bullet list with the main node configs. Ignore irrelevant configs. Enclose each config value in code backticks (`). Look:\n - Parameter 1 name: `Parameter 1 value`\n - Parameter 2 name: `Parameter 2 value`\n\\n\\n\n### Node 2 name as H3 title\n - For each node make a bullet list with the main node configs. Ignore irrelevant configs. Enclose each config value in code backticks (`). Look:\n - Parameter 1 name: `Parameter 1 value`\n - Parameter 2 name: `Parameter 2 value`\n\\n\\n\n```"
}
]
},
"promptType": "define",
"hasOutputParser": true
},
"typeVersion": 1.4,
"alwaysOutputData": false
},
{
"id": "9bc58cd3-a55e-4cda-95b5-7fa8dc0e7076",
"name": "OpenAI Chat Model",
"type": "@n8n/n8n-nodes-langchain.lmChatOpenAi",
"position": [
3480,
1360
],
"parameters": {
"model": "gpt-4-turbo",
"options": {
"timeout": 120000,
"temperature": 0.2
}
},
"credentials": {
"openAiApi": {
"id": "rveqdSfp7pCRON1T",
"name": "Ted's Tech Talks OpenAi"
}
},
"typeVersion": 1
},
{
"id": "38fb6192-b8ce-4241-a9fe-aebda09aa8d5",
"name": "Structured Output Parser",
"type": "@n8n/n8n-nodes-langchain.outputParserStructured",
"position": [
3820,
1360
],
"parameters": {
"jsonSchemaExample": "{\n\t\"workflow_description\": \"## Workflow overview\\n\\n>some additiona info\\n\\nWorkflow desctiption\",\n\t\"nodes_settings\": \"## Nodes settings\\n\\n###Node name 1\\n\\n- Setting 1\\n- Setting 2###Node name 2\\n\\n- Setting 1\\n- Setting 2\"\n}"
},
"typeVersion": 1.2
},
{
"id": "29261bbb-dbbb-44df-b99d-bb084df7d846",
"name": "Auto-fixing Output Parser",
"type": "@n8n/n8n-nodes-langchain.outputParserAutofixing",
"position": [
3580,
1360
],
"parameters": {
"options": {}
},
"typeVersion": 1
},
{
"id": "086a57cf-a2b4-4f32-8ca6-38546e4856c1",
"name": "Respond with main page HTML",
"type": "n8n-nodes-base.respondToWebhook",
"position": [
4920,
-100
],
"parameters": {
"options": {
"responseCode": 200,
"responseHeaders": {
"entries": [
{
"name": "Content-Type",
"value": "text/html"
}
]
}
},
"respondWith": "text",
"responseBody": "={{ $json.html }}"
},
"typeVersion": 1.1
},
{
"id": "fdbfe60b-e677-4897-ab1a-9a9f506bba27",
"name": "Workflow Tags",
"type": "n8n-nodes-base.html",
"position": [
4660,
500
],
"parameters": {
"html": "- **Click to filter by tag:**\n{{ [...new Set($jmespath($input.all(),'[].json.tags[].name'))].map(tag => `- [${tag}](tag-${encodeURIComponent(tag)})`).join('\\n') }}"
},
"executeOnce": true,
"typeVersion": 1.2
},
{
"id": "94a258ed-c07c-42d4-8d37-3395fad205b0",
"name": "No Operation, do nothing",
"type": "n8n-nodes-base.noOp",
"position": [
1740,
1880
],
"parameters": {},
"typeVersion": 1
},
{
"id": "c35ca075-52e7-4c2f-9891-f709afe36e52",
"name": "Merge",
"type": "n8n-nodes-base.merge",
"position": [
3140,
1100
],
"parameters": {
"mode": "combine",
"options": {},
"combineBy": "combineByPosition",
"numberInputs": 3
},
"typeVersion": 3
},
{
"id": "55a1e32f-b20c-4b1f-9d6f-9bc4ec221fab",
"name": "Fallback file name",
"type": "n8n-nodes-base.html",
"position": [
4660,
1900
],
"parameters": {
"html": "> File: {{ $json.params.file }}"
},
"typeVersion": 1.2
},
{
"id": "3eef159b-99ad-4c9a-82f4-13bf16972521",
"name": "mkdir",
"type": "n8n-nodes-base.executeCommand",
"position": [
2100,
1060
],
"parameters": {
"command": "=mkdir -p {{$('CONFIG').first().json.project_path}}"
},
"typeVersion": 1
},
{
"id": "15fda233-925b-4a4d-964e-1916c0cd39a2",
"name": "Merge1",
"type": "n8n-nodes-base.merge",
"position": [
2240,
880
],
"parameters": {
"mode": "chooseBranch"
},
"typeVersion": 3
},
{
"id": "3e6c9243-d5f7-4f04-8231-9994963df36d",
"name": "Edit Page",
"type": "n8n-nodes-base.html",
"position": [
4660,
860
],
"parameters": {
"html": "<!DOCTYPE html>\n<html>\n <head>\n{{ $('CONFIG').first().json.HTML_headers }}\n{{ $('CONFIG').first().json.HTML_styles_editor }}\n </head>\n <body>\n <div class=\"container\">\n <div class=\"button-container\">\n <button class=\"button save-button\" onclick=\"saveContent()\">Save</button>\n <button class=\"button cancel-button\" onclick=\"closeWindow()\">Cancel</button>\n </div>\n <div class=\"editor-preview-container\">\n <textarea id=\"editor\">{{ $json.workflowdata }}</textarea>\n <div class=\"preview-container\">\n <div id=\"preview\"></div>\n </div>\n </div>\n </div>\n \n<script>\n const editor = document.getElementById('editor');\n let vm;\n\n mermaid.initialize({\n startOnLoad: false,\n });\n\n let svgCounter = 0;\n\n // Function to save content\n async function saveContent() {\n try {\n const response = await fetch(window.location.pathname + '?action=save', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n body: JSON.stringify({\n content: editor.value\n })\n });\n \n if (response.ok) {\n alert('Successfully saved!');\n } else {\n alert('Failed to save content');\n }\n } catch (error) {\n console.error('Error saving content:', error);\n alert('Error saving content');\n }\n }\n \n // Function to close window\n function closeWindow() {\n window.close();\n }\n \n window.$docsify = {\n el: '#preview',\n loadSidebar: false,\n loadNavbar: false,\n basePath: '/',\n hideSidebar: true,\n markdown: {\n renderer: {\n code(code, lang) {\n if (lang === \"mermaid\") {\n const svgName = `mermaid-svg-${svgCounter++}`;\n const MERMAID_CONTAINER_ID = `${svgName}-container`;\n mermaid.render(svgName, code).then(({ svg }) => {\n const containerElement = document.querySelector(\n `#${MERMAID_CONTAINER_ID}`\n );\n if (containerElement) {\n containerElement.innerHTML = svg;\n } else {\n console.error(`Error: #${MERMAID_CONTAINER_ID} not found`);\n }\n });\n return `<div class=\"mermaid\" id=\"${MERMAID_CONTAINER_ID}\"></div>`;\n }\n return this.origin.code.apply(this, arguments);\n },\n },\n },\n plugins: [\n function(hook, _vm) {\n vm = _vm;\n \n hook.beforeEach(function(content) {\n return editor.value;\n });\n }\n ]\n };\n \nlet timeout;\nfunction updatePreview() {\n clearTimeout(timeout);\n timeout = setTimeout(() => {\n if (vm) {\n const markdownSection = document.querySelector('.markdown-section');\n if (markdownSection) {\n const compiler = new window.DocsifyCompiler({\n basePath: '/',\n relativePath: false,\n fallbackLanguages: [],\n nameLink: '/',\n routerMode: 'hash'\n }, vm.router);\n \n const html = compiler.compile(editor.value);\n markdownSection.innerHTML = html;\n window.Prism.highlightAll();\n\n // Re-render all mermaid diagrams\n const mermaidDivs = markdownSection.querySelectorAll('pre[data-lang=\"mermaid\"] code');\n mermaidDivs.forEach((div, index) => {\n const code = div.textContent;\n const svgName = `mermaid-svg-${svgCounter++}`;\n const MERMAID_CONTAINER_ID = `${svgName}-container`;\n \n // Replace the <pre> element with our container\n const container = document.createElement('div');\n container.className = 'mermaid';\n container.id = MERMAID_CONTAINER_ID;\n div.parentElement.replaceWith(container);\n \n // Render the diagram\n mermaid.render(svgName, code).then(({ svg }) => {\n const containerElement = document.getElementById(MERMAID_CONTAINER_ID);\n if (containerElement) {\n containerElement.innerHTML = svg;\n }\n });\n });\n }\n }\n }, 500);\n};\n \n editor.addEventListener('input', updatePreview);\n</script>\n{{ $('CONFIG').first().json.HTML_docsify_include }}\n </body>\n</html>"
},
"typeVersion": 1.2
},
{
"id": "71e136d5-bb5b-4eab-8cab-bfc50ea2a5a5",
"name": "Workflow md content",
"type": "n8n-nodes-base.html",
"position": [
4660,
1040
],
"parameters": {
"html": "{{ $json.workflowdata }}"
},
"executeOnce": true,
"typeVersion": 1.2
},
{
"id": "6cb6f3b8-de65-43a5-9df3-48299ba7fcce",
"name": "Is Action Edit?1",
"type": "n8n-nodes-base.if",
"position": [
3300,
1100
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "856cdb3b-a187-4db5-b77b-43ee086780ee",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "edit"
}
]
}
},
"typeVersion": 2.2
},
{
"id": "aff9ed71-bb49-4170-9ae3-5f05f89bab05",
"name": "Is Action Edit?2",
"type": "n8n-nodes-base.if",
"position": [
4180,
880
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "e3648023-8cb7-4b82-bd35-1ba196458327",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.query.action }}",
"rightValue": "edit"
}
]
}
},
"typeVersion": 2.2
},
{
"id": "7b3d31a9-ee01-4bce-bc5b-78161536999d",
"name": "Generate Mermaid Chart",
"type": "n8n-nodes-base.code",
"position": [
3000,
1260
],
"parameters": {
"jsCode": "const workflow = $input.first().json;\n\n// Extract nodes from the workflow\nconst nodes = workflow.nodes || [];\n\n// Node types to exclude\nconst excludedNodeTypes = ['n8n-nodes-base.stickyNote'];\n\n// Define shapes and their corresponding brackets\n// https://mermaid.js.org/syntax/flowchart.html\nconst shapes = {\n 'rect': ['[', ']'],\n 'rhombus': ['{', '}'],\n 'circle': ['((', '))'],\n 'hexagon': ['{{', '}}'],\n 'subroutine': ['[[', ']]'],\n 'parallelogram': ['[\\/', '\\/]'],\n 'wait': ['(', ')']\n // Add more shapes here as needed\n};\n\n// Define special shapes for specific node types\nconst specialShapes = {\n 'n8n-nodes-base.if': 'rhombus',\n 'n8n-nodes-base.switch': 'rhombus',\n 'n8n-nodes-base.code': 'subroutine',\n 'n8n-nodes-base.executeWorkflow': 'subroutine',\n 'n8n-nodes-base.httpRequest':'parallelogram',\n 'n8n-nodes-base.wait':'wait'\n // List more special node types\n};\n\n// Function to get the shape for a node type\nfunction getNodeShape(nodeType) {\n return specialShapes[nodeType] || 'rect';\n}\n\n// Create a map of node names to their \"EL<N>\" identifiers, disabled status, and shape\nconst nodeMap = {};\nlet nodeCounter = 1;\nnodes.forEach((node) => {\n if (!excludedNodeTypes.includes(node.type)) {\n const shape = getNodeShape(node.type);\n nodeMap[node.name] = {\n id: `EL${nodeCounter}`,\n disabled: node.disabled || false,\n shape: shape,\n brackets: shapes[shape] || shapes['rect'] // Default to rect if shape not found\n };\n nodeCounter++;\n }\n});\n\n// Function to convert special characters to HTML entities\nfunction convertToHTMLEntities(str) {\n return str.replaceAll('\"',\"'\").replace(/[^\\w\\s-]/g, function(char) {\n return '&#' + char.charCodeAt(0) + ';';\n });\n}\n\n// Function to format node text (with strike-through if disabled)\nfunction formatNodeText(nodeName, isDisabled) {\n const escapedName = convertToHTMLEntities(nodeName);\n return isDisabled ? `<s>${escapedName}</s>` : escapedName;\n}\n\n// Generate connections and isolated nodes\nconst connections = [];\nconst isolatedNodes = new Set(Object.keys(nodeMap));\n\nif (workflow.connections) {\n Object.entries(workflow.connections).forEach(([sourceName, targetConnections]) => {\n Object.entries(targetConnections).forEach(([connectionType, targets]) => {\n targets.forEach(targetArray => {\n targetArray.forEach(target => {\n const sourceNode = nodeMap[sourceName];\n const targetNode = nodeMap[target.node];\n if (sourceNode && targetNode) {\n let connectionLine = ` ${sourceNode.id}${sourceNode.brackets[0]}${formatNodeText(sourceName, sourceNode.disabled)}${sourceNode.brackets[1]}`;\n if (connectionType === 'main') {\n connectionLine += ` -->`;\n } else {\n connectionLine += ` -.- |${connectionType}|`;\n }\n connectionLine += ` ${targetNode.id}${targetNode.brackets[0]}${formatNodeText(target.node, targetNode.disabled)}${targetNode.brackets[1]}`;\n connections.push(connectionLine);\n isolatedNodes.delete(sourceName);\n isolatedNodes.delete(target.node);\n }\n });\n });\n });\n });\n}\n\n// Add isolated nodes to the connections array\nisolatedNodes.forEach(nodeName => {\n const node = nodeMap[nodeName];\n connections.push(` ${node.id}${node.brackets[0]}${formatNodeText(nodeName, node.disabled)}${node.brackets[1]}`);\n});\n\n// Generate the Mermaid flowchart string\nconst mermaidChart = `---\nconfig:\n look: neo\n theme: default\n---\nflowchart LR\n${connections.join('\\n')}`;\n\n// Output the result\nreturn {\n json: {\n mermaidChart: mermaidChart\n }\n};"
},
"typeVersion": 2
},
{
"id": "77a35cd5-cb8f-4ac5-a699-dff5e65cda09",
"name": "Merge2",
"type": "n8n-nodes-base.merge",
"position": [
3840,
1140
],
"parameters": {
"mode": "combine",
"options": {},
"combineBy": "combineByPosition"
},
"typeVersion": 3
},
{
"id": "f8119590-e9d7-4513-9da4-fa911165baff",
"name": "Generated Doc",
"type": "n8n-nodes-base.set",
"position": [
4000,
1240
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "7693348d-5129-4a07-809d-b0619b9fc44b",
"name": "workflowdata",
"type": "string",
"value": "=# {{ $json.name }}\n\n{{ $json?.output?.workflow_description || \"## <SORRY, COULD NOT GENERATE WORKFLOW DESCRIPTION>\" }}\n\n## Workflow schematic\n\n```mermaid\n{{ $json.mermaidChart }}\n```\n\n{{ $json?.output?.nodes_settings || \"## <SORRY, COULD NOT GENERATE DOCS FOR NODE SETTING>\" }}"
}
]
}
},
"typeVersion": 3.4
},
{
"id": "92565206-6cf2-4243-9143-4f6def4b524d",
"name": "Passthrough",
"type": "n8n-nodes-base.noOp",
"position": [
2100,
1240
],
"parameters": {},
"typeVersion": 1
},
{
"id": "73081fc3-9554-4a12-b985-da02b356616f",
"name": "Merge3",
"type": "n8n-nodes-base.merge",
"position": [
3140,
880
],
"parameters": {
"mode": "combine",
"options": {},
"combineBy": "combineByPosition"
},
"typeVersion": 3
},
{
"id": "f50e72f8-9027-4ca7-9df7-700e828f48eb",
"name": "Merge4",
"type": "n8n-nodes-base.merge",
"position": [
960,
-100
],
"parameters": {
"mode": "combine",
"options": {},
"combineBy": "combineByPosition"
},
"typeVersion": 3
},
{
"id": "306820ac-7c87-45c2-b76f-55d772ac7300",
"name": "Merge5",
"type": "n8n-nodes-base.merge",
"position": [
960,
240
],
"parameters": {
"mode": "combine",
"options": {},
"combineBy": "combineByPosition"
},
"typeVersion": 3
},
{
"id": "96fd7265-7920-453f-8309-bdbd10880d03",
"name": "Edit Fields",
"type": "n8n-nodes-base.set",
"position": [
2100,
1600
],
"parameters": {
"options": {},
"assignments": {
"assignments": [
{
"id": "8bc55c5b-e09a-459b-bbb6-ed5f70d4f353",
"name": "workflowdata",
"type": "string",
"value": "={{ $json.body.content }}"
}
]
},
"includeOtherFields": true
},
"typeVersion": 3.4
},
{
"id": "2fffb547-1c11-4663-aed5-29b9557e8738",
"name": "Is Action Save?",
"type": "n8n-nodes-base.if",
"position": [
4540,
1600
],
"parameters": {
"options": {},
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "e3648023-8cb7-4b82-bd35-1ba196458327",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json?.query?.action }}",
"rightValue": "save"
},
{
"id": "a44c9cc5-5717-4c34-978b-e644219a9cc1",
"operator": {
"type": "string",
"operation": "exists",
"singleValue": true
},
"leftValue": "={{ $json?.query?.action }}",
"rightValue": ""
}
]
}
},
"typeVersion": 2.2
},
{
"id": "15825037-a8e2-4fbc-b529-2bf89810a116",
"name": "Merge6",
"type": "n8n-nodes-base.merge",
"position": [
4360,
1700
],
"parameters": {
"mode": "chooseBranch",
"useDataOfInput": 2
},
"typeVersion": 3
},
{
"id": "b47f18a4-9b59-4278-890d-b6f6c596c554",
"name": "Respond OK on Save",
"type": "n8n-nodes-base.respondToWebhook",
"position": [
4920,
1580
],
"parameters": {
"options": {
"responseCode": 200
},
"respondWith": "noData"
},
"typeVersion": 1.1
},
{
"id": "273dfd58-abef-49b7-8f12-5abc3d3515a6",
"name": "single workflow",
"type": "n8n-nodes-base.webhook",
"position": [
240,
240
],
"webhookId": "135bc21f-c7d0-4afe-be73-f984d444b43b",
"parameters": {
"path": "/:file",
"options": {},
"responseMode": "responseNode",
"multipleMethods": true
},
"typeVersion": 2
},
{
"id": "a7d7ee50-1420-475b-9028-0c80e1ae2241",
"name": "Sticky Note",
"type": "n8n-nodes-base.stickyNote",
"position": [
140,
-242.54375384615383
],
"parameters": {
"width": 296.5956923076922,
"height": 277.9529846153844,
"content": "## Main Docsify webhook\nIn response, n8n serves the main html page with the [Docsify JS library](https://docsify.js.org/)"
},
"typeVersion": 1
},
{
"id": "b7c4b82a-9722-48ae-ab6a-4335981356ad",
"name": "Sticky Note1",
"type": "n8n-nodes-base.stickyNote",
"position": [
-77.62340912473337,
108.96056004923076
],
"parameters": {
"width": 509.1040245093486,
"height": 287.9568584558579,
"content": "## Single page requests\n* Docsify may request default pages (i.e. `readme.md` or a `summary.md`)\n* GET request for the workflow documentation pages\n* POST request for saving manually edited doc page"
},
"typeVersion": 1
},
{
"id": "18e1f4c5-3652-4244-9a09-cd7a498a9310",
"name": "Sticky Note2",
"type": "n8n-nodes-base.stickyNote",
"position": [
460,
-240.54580345183416
],
"parameters": {
"color": 3,
"width": 489.50636350106504,
"height": 462.9720128227216,
"content": "## EDIT THIS!\n* `project_path` to link to a writable directory that is accessible to n8n\n* update `instance_url` when running in the cloud version. If using in self-hosted mode, make sure N8N_PROTOCOL and N8N_HOST .env variables are correct"
},
"typeVersion": 1
},
{
"id": "d505d2ec-33e9-4983-8265-ff55f0df3da8",
"name": "file types",
"type": "n8n-nodes-base.switch",
"position": [
1180,
240
],
"parameters": {
"rules": {
"values": [
{
"outputKey": ".md",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"operator": {
"type": "string",
"operation": "endsWith"
},
"leftValue": "={{ $json.params.file.toLowerCase() }}",
"rightValue": ".md"
}
]
},
"renameOutput": true
}
]
},
"options": {
"fallbackOutput": "extra",
"renameFallbackOutput": "unknown"
}
},
"typeVersion": 3.2
},
{
"id": "59362792-4a3e-4f97-95e2-d7b33b870e1d",
"name": "Sticky Note3",
"type": "n8n-nodes-base.stickyNote",
"position": [
4620,
-245.7696645512633
],
"parameters": {
"width": 446.67466982248516,
"height": 309.89805271694365,
"content": "## Construct main HTML page and send it back to the user\n* `HTML_headers` and `HTML_docsify_include` are stored in the CONFIG node for the page simplicity"
},
"typeVersion": 1
},
{
"id": "83189146-4d1f-454e-9591-bdbfda676683",
"name": "Get All Workflows",
"type": "n8n-nodes-base.n8n",
"position": [
1880,
160
],
"parameters": {
"filters": {
"tags": "={{ decodeURIComponent(($json.params.file?.match(/^tag-(.+)\\.md$/))?.[1] || '') }}"
},
"requestOptions": {}
},
"credentials": {
"n8nApi": {
"id": "eW7IdTFt4ARJbEwR",
"name": "Ted n8n account"
}
},
"typeVersion": 1,
"alwaysOutputData": true
},
{
"id": "39aa6017-a0ef-4f05-81b8-cfc9bb2fcc20",
"name": "Sticky Note4",
"type": "n8n-nodes-base.stickyNote",
"position": [
1780,
20.913927466176517
],
"parameters": {
"width": 820.1843305645202,
"height": 307.51990359708003,
"content": "## Serve main Markdown table with the workflow overview\n*NOTE! Here we don't reply with HTML content. Only Markdown elements are sent back and processed by the JS library*\n* Create an overall table when `README.md` (the home page) is requested\n* Create a table with a subset of workflows when a tag from a navigation pane is selected"
},
"typeVersion": 1
},
{
"id": "2d087c25-b998-4abc-b0ce-ede8e62e28b4",
"name": "md files",
"type": "n8n-nodes-base.switch",
"position": [
1440,
180
],
"parameters": {
"rules": {
"values": [
{
"outputKey": "README.md",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"operator": {
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.params.file }}",
"rightValue": "README.md"
}
]
},
"renameOutput": true
},
{
"outputKey": "docs",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "c1c1aecc-8faa-47ea-b831-4674c3c0db61",
"operator": {
"type": "string",
"operation": "contains"
},
"leftValue": "={{ $json.params.file }}",
"rightValue": "docs_"
}
]
},
"renameOutput": true
},
{
"outputKey": "summary.md",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "fde643c9-31cd-4cbd-b4de-99a8ad6202af",
"operator": {
"name": "filter.operator.equals",
"type": "string",
"operation": "equals"
},
"leftValue": "={{ $json.params.file }}",
"rightValue": "summary.md"
}
]
},
"renameOutput": true
},
{
"outputKey": "tags",
"conditions": {
"options": {
"version": 2,
"leftValue": "",
"caseSensitive": true,
"typeValidation": "strict"
},
"combinator": "and",
"conditions": [
{
"id": "df4bc9f8-9285-49a6-b31c-d7173bf42901",
"operator": {
"type": "string",
"operation": "startsWith"
},
"leftValue": "={{ $json.params.file }}",
"rightValue": "tag-"
}
]
},
"renameOutput": true
}
]
},
"options": {
"fallbackOutput": "extra"
}
},
"typeVersion": 3.2
},
{
"id": "08524df2-d555-42ca-8440-57ca5a780b74",
"name": "Get Workflow tags",
"type": "n8n-nodes-base.n8n",
"position": [
1880,
500
],
"parameters": {
"filters": {},
"requestOptions": {}
},
"credentials": {
"n8nApi": {
"id": "eW7IdTFt4ARJbEwR",
"name": "Ted n8n account"
}
},
"typeVersion": 1
},
{
"id": "06e383dc-b1ea-4c97-9ee4-c07084ffc4cc",
"name": "Sticky Note5",
"type": "n8n-nodes-base.stickyNote",
"position": [
1780,
360
],
"parameters": {
"width": 817.6163848212657,
"height": 288.20835077550953,
"content": "## Serve left pane content\n* Here all workflows are fetched again when `summary.md` file is requested.\n\nIt contains Markdown for the left navigation pane: a list of all tags"
},
"typeVersion": 1
},
{
"id": "c28ae282-7d83-42dd-8714-30d26b0f20af",
"name": "Sticky Note6",
"type": "n8n-nodes-base.stickyNote",
"position": [
1700,
1780
],
"parameters": {
"width": 367.8950651848079,
"height": 262.5093167050718,
"content": "## Handle missing pages\nServe the Markdown content with the requested file name for edge cases, i.e. any unexpected files"
},
"typeVersion": 1
},
{
"id": "6441cf8f-dace-45fb-984e-aa9e0589e495",
"name": "Sticky Note7",
"type": "n8n-nodes-base.stickyNote",
"position": [
1020,
729
],
"parameters": {
"color": 6,
"width": 4161.578473434268,
"height": 1142.0268674813442,
"content": "# Main functionality here\n\n## * View existing documentation\n## * Auto-generate doc page if no file available\n## * Re-created autodoc page\n## * Edit doc page: LIVE Markdown editor included!\n## * Save edited file. WARNING! No authentication"
},
"typeVersion": 1
},
{
"id": "9116a4eb-18c6-4ec2-84e8-9a0b920d5c19",
"name": "Sticky Note8",
"type": "n8n-nodes-base.stickyNote",
"position": [
4460,
751
],
"parameters": {
"width": 652.3100890494833,
"height": 268.0620091282372,
"content": "## Custom markdown editor\nThis is another HTML page for the live Markdown editor\n* `Mermaid.js` is supported\n* Docsify preview on edit\n* Save or Cancel buttons"
},
"typeVersion": 1
},
{
"id": "920c1edb-29ad-4952-9e30-9020146ed88a",
"name": "Sticky Note9",
"type": "n8n-nodes-base.stickyNote",
"position": [
4000,
1501
],
"parameters": {
"width": 522.870786668288,
"height": 348.0868581511653,
"content": "## Save new file\nOnce the doc page is generated or edited manually, a Markdown files is saved in the directory"
},
"typeVersion": 1
},
{
"id": "cff4d2be-f627-4c7d-9f7a-093f6f9b2c27",
"name": "Sticky Note10",
"type": "n8n-nodes-base.stickyNote",
"position": [
1887,
758
],
"parameters": {
"width": 639.8696984316115,
"height": 429.7891698152571,
"content": "## Load existing doc file\nCheck the existing file when the View or Edit button is pressed\n"
},
"typeVersion": 1
},
{
"id": "b7f01785-99c7-47b2-967a-b7456bb8f562",
"name": "Sticky Note11",
"type": "n8n-nodes-base.stickyNote",
"position": [
2786.9421822644376,
1023
],
"parameters": {
"width": 1369.2986733206085,
"height": 466.42237140646773,
"content": "## If the file is not available, then:\n* either auto-generate new doc\n* prepare a basic template for editing"
},
"typeVersion": 1
},
{
"id": "6953bf0c-3122-4d80-9e74-1c07a892bf31",
"name": "docsify",
"type": "n8n-nodes-base.webhook",
"position": [
240,
-100
],
"webhookId": "8b719afe-8be3-4cd5-84ed-aca521b31a89",
"parameters": {
"path": "135bc21f-c7d0-4afe-be73-f984d444b43b",
"options": {},
"responseMode": "responseNode"
},
"typeVersion": 2
}
],
"active": true,
"pinData": {},
"settings": {
"callerPolicy": "workflowsFromSameOwner",
"executionOrder": "v1",
"executionTimeout": 120,
"saveManualExecutions": true,
"saveDataSuccessExecution": "all"
},
"versionId": "eee9144a-c7a0-4947-874b-728d9e8618b7",
"connections": {
"Merge": {
"main": [
[
{
"node": "Is Action Edit?1",
"type": "main",
"index": 0
}
]
]
},
"mkdir": {
"main": [
[
{
"node": "Merge1",
"type": "main",
"index": 1
}
]
]
},
"CONFIG": {
"main": [
[
{
"node": "Merge4",
"type": "main",
"index": 1
},
{
"node": "Merge5",
"type": "main",
"index": 0
}
]
]
},
"Merge1": {
"main": [
[
{
"node": "HasFile?",
"type": "main",
"index": 0
}
]
]
},
"Merge2": {
"main": [
[
{
"node": "Generated Doc",
"type": "main",
"index": 0
}
]
]
},
"Merge3": {
"main": [
[
{
"node": "Is Action Edit?2",
"type": "main",
"index": 0
}
]
]
},
"Merge4": {
"main": [
[
{
"node": "Main Page",
"type": "main",
"index": 0
}
]
]
},
"Merge5": {
"main": [
[
{
"node": "file types",
"type": "main",
"index": 0
}
]
]
},
"Merge6": {
"main": [
[
{
"node": "Is Action Save?",
"type": "main",
"index": 0
}
]
]
},
"docsify": {
"main": [
[
{
"node": "CONFIG",
"type": "main",
"index": 0
},
{
"node": "Merge4",
"type": "main",
"index": 0
}
]
]
},
"HasFile?": {
"main": [
[
{
"node": "Extract from File",
"type": "main",
"index": 0
}
],
[
{
"node": "Fetch Single Workflow1",
"type": "main",
"index": 0
}
]
]
},
"md files": {
"main": [
[
{
"node": "Get All Workflows",
"type": "main",
"index": 0
}
],
[
{
"node": "doc action",
"type": "main",
"index": 0
}
],
[
{
"node": "Get Workflow tags",
"type": "main",
"index": 0
}
],
[
{
"node": "Get All Workflows",
"type": "main",
"index": 0
}
],
[
{
"node": "No Operation, do nothing",
"type": "main",
"index": 0
}
]
]
},
"Edit Page": {
"main": [
[
{
"node": "Respond with HTML",
"type": "main",
"index": 0
}
]
]
},
"Empty Set": {
"main": [
[
{
"node": "Merge1",
"type": "main",
"index": 0
}
]
]
},
"Main Page": {
"main": [
[
{
"node": "Respond with main page HTML",
"type": "main",
"index": 0
}
]
]
},
"doc action": {
"main": [
[
{
"node": "mkdir",
"type": "main",
"index": 0
},
{
"node": "Load Doc File",
"type": "main",
"index": 0
},
{
"node": "Passthrough",
"type": "main",
"index": 0
}
],
[
{
"node": "mkdir",
"type": "main",
"index": 0
},
{
"node": "Load Doc File",
"type": "main",
"index": 0
},
{
"node": "Passthrough",
"type": "main",
"index": 0
}
],
[
{
"node": "mkdir",
"type": "main",
"index": 0
},
{
"node": "Empty Set",
"type": "main",
"index": 0
},
{
"node": "Passthrough",
"type": "main",
"index": 0
}
],
[
{
"node": "Edit Fields",
"type": "main",
"index": 0
}
]
]
},
"file types": {
"main": [
[
{
"node": "md files",
"type": "main",
"index": 0
}
]
]
},
"Edit Fields": {
"main": [
[
{
"node": "Convert to File",
"type": "main",
"index": 0
},
{
"node": "Merge6",
"type": "main",
"index": 1
}
]
]
},
"Passthrough": {
"main": [
[
{
"node": "Merge3",
"type": "main",
"index": 1
},
{
"node": "Merge",
"type": "main",
"index": 0
}
]
]
},
"Generated Doc": {
"main": [
[
{
"node": "Convert to File",
"type": "main",
"index": 0
},
{
"node": "Is Action Edit?2",
"type": "main",
"index": 0
}
]
]
},
"Load Doc File": {
"main": [
[
{
"node": "Merge1",
"type": "main",
"index": 0
}
]
]
},
"Workflow Tags": {
"main": [
[
{
"node": "Respond with markdown",
"type": "main",
"index": 0
}
]
]
},
"Blank Doc File": {
"main": [
[
{
"node": "Is Action Edit?2",
"type": "main",
"index": 0
}
]
]
},
"Sort-workflows": {
"main": [
[
{
"node": "Fill Workflow Table",
"type": "main",
"index": 0
}
]
]
},
"Basic LLM Chain": {
"main": [
[
{
"node": "Merge2",
"type": "main",
"index": 1
}
]
]
},
"Convert to File": {
"main": [
[
{
"node": "Save New Doc File",
"type": "main",
"index": 0
}
]
]
},
"Is Action Save?": {
"main": [
[
{
"node": "Respond OK on Save",
"type": "main",
"index": 0
}
]
]
},
"single workflow": {
"main": [
[
{
"node": "CONFIG",
"type": "main",
"index": 0
},
{
"node": "Merge5",
"type": "main",
"index": 1
}
],
[
{
"node": "CONFIG",
"type": "main",
"index": 0
},
{
"node": "Merge5",
"type": "main",
"index": 1
}
]
]
},
"Is Action Edit?1": {
"main": [
[
{
"node": "Blank Doc File",
"type": "main",
"index": 0
}
],
[
{
"node": "Basic LLM Chain",
"type": "main",
"index": 0
},
{
"node": "Merge2",
"type": "main",
"index": 0
}
]
]
},
"Is Action Edit?2": {
"main": [
[
{
"node": "Edit Page",
"type": "main",
"index": 0
}
],
[
{
"node": "Workflow md content",
"type": "main",
"index": 0
}
]
]
},
"Extract from File": {
"main": [
[
{
"node": "Merge3",
"type": "main",
"index": 0
}
]
]
},
"Get All Workflows": {
"main": [
[
{
"node": "Sort-workflows",
"type": "main",
"index": 0
}
]
]
},
"Get Workflow tags": {
"main": [
[
{
"node": "Workflow Tags",
"type": "main",
"index": 0
}
]
]
},
"Instance overview": {
"main": [
[
{
"node": "Respond with markdown",
"type": "main",
"index": 0
}
]
]
},
"OpenAI Chat Model": {
"ai_languageModel": [
[
{
"node": "Basic LLM Chain",
"type": "ai_languageModel",
"index": 0
},
{
"node": "Auto-fixing Output Parser",
"type": "ai_languageModel",
"index": 0
}
]
]
},
"Save New Doc File": {
"main": [
[
{
"node": "Merge6",
"type": "main",
"index": 0
}
]
]
},
"Fallback file name": {
"main": [
[
{
"node": "Respond with markdown",
"type": "main",
"index": 0
}
]
]
},
"Fill Workflow Table": {
"main": [
[
{
"node": "Instance overview",
"type": "main",
"index": 0
}
]
]
},
"Workflow md content": {
"main": [
[
{
"node": "Respond with markdown",
"type": "main",
"index": 0
}
]
]
},
"Fetch Single Workflow1": {
"main": [
[
{
"node": "Generate Mermaid Chart",
"type": "main",
"index": 0
},
{
"node": "Merge",
"type": "main",
"index": 1
}
]
]
},
"Generate Mermaid Chart": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 2
}
]
]
},
"No Operation, do nothing": {
"main": [
[
{
"node": "Fallback file name",
"type": "main",
"index": 0
}
]
]
},
"Structured Output Parser": {
"ai_outputParser": [
[
{
"node": "Auto-fixing Output Parser",
"type": "ai_outputParser",
"index": 0
}
]
]
},
"Auto-fixing Output Parser": {
"ai_outputParser": [
[
{
"node": "Basic LLM Chain",
"type": "ai_outputParser",
"index": 0
}
]
]
}
}
}Workflow n8n Docsify, gestion de documents : pour qui est ce workflow ?
Ce workflow s'adresse aux entreprises et équipes qui gèrent régulièrement des documents, notamment dans les secteurs de la communication, du marketing et de la gestion de projet. Il est conçu pour des utilisateurs ayant un niveau technique intermédiaire, souhaitant automatiser leurs processus documentaires.
Workflow n8n Docsify, gestion de documents : problème résolu
Ce workflow résout le problème de la gestion manuelle des documents, souvent source d'erreurs et de perte de temps. En automatisant la création et la mise à jour des fichiers, il permet aux utilisateurs de se concentrer sur des tâches plus stratégiques. De plus, il réduit les risques liés à la manipulation manuelle des données, garantissant ainsi une meilleure précision et une efficacité accrue dans le traitement de l'information.
Workflow n8n Docsify, gestion de documents : étapes du workflow
Étape 1 : Le workflow est déclenché par un Webhook qui reçoit des données.
- Étape 1 : Les options sont configurées pour préparer le traitement des fichiers.
- Étape 2 : Le workflow vérifie si un fichier est présent à l'aide d'un noeud conditionnel.
- Étape 3 : Si un fichier est trouvé, il est extrait et traité pour en extraire les informations nécessaires.
- Étape 4 : Les résultats sont formatés et renvoyés sous forme de réponses HTML ou Markdown, permettant une communication claire des résultats.
- Étape 5 : Les utilisateurs peuvent également interagir avec le modèle de langage pour enrichir le contenu des documents générés.
Workflow n8n Docsify, gestion de documents : guide de personnalisation
Pour personnaliser ce workflow, vous pouvez modifier les paramètres du Webhook pour l'adapter à votre système. Il est également possible de changer les options de conversion de fichier selon vos besoins spécifiques. Si vous souhaitez intégrer d'autres outils, vous pouvez ajouter des noeuds supplémentaires pour interagir avec des API externes. Assurez-vous de vérifier les permissions d'accès aux fichiers et de configurer les options de sécurité pour protéger vos données. Pour un suivi efficace, vous pouvez également intégrer des outils de monitoring pour surveiller l'exécution du workflow.