{ "meta": { "instanceId": "workflow-a8769afb", "versionId": "1.0.0", "createdAt": "2025-09-29T07:07:49.025637", "updatedAt": "2025-09-29T07:07:49.025649", "owner": "n8n-user", "license": "MIT", "category": "automation", "status": "active", "priority": "high", "environment": "production" }, "nodes": [ { "id": "b9962fd6-af11-4a3a-935c-c168ac85eaa1", "name": "When clicking \"Test workflow\"", "type": "n8n-nodes-base.manualTrigger", "position": [ 80, 300 ], "parameters": {}, "typeVersion": 1, "notes": "This manualTrigger node performs automated tasks as part of the workflow." }, { "id": "2ba3fe3a-e4c5-4014-8cb2-80716f18b222", "name": "Get records", "type": "n8n-nodes-base.airtable", "position": [ 300, 300 ], "parameters": { "base": { "__rl": true, "mode": "list", "value": "appkkDhXu7vZCFspD", "cachedResultUrl": "{{ $env.WEBHOOK_URL }}", "cachedResultName": "n8n test" }, "limit": 10, "table": { "__rl": true, "mode": "list", "value": "tblMdmUiSTBrvrLq3", "cachedResultUrl": "{{ $env.WEBHOOK_URL }}", "cachedResultName": "SEO meta title & desc" }, "options": {}, "operation": "search", "returnAll": false, "filterByFormula": "=AND(url != \"\", {title tag} = \"\", {meta desc} = \"\")" }, "credentials": { "airtableTokenApi": { "id": "yw6pm1U4Hw8kKDhu", "name": "Airtable Personal Access Token account" } }, "typeVersion": 2, "notes": "This airtable node performs automated tasks as part of the workflow." }, { "id": "0f26bb3c-f2cc-476b-b1af-3d4cd98463ce", "name": "Get url content", "type": "n8n-nodes-base.httpRequest", "position": [ 500, 300 ], "parameters": { "url": "{{ $env.BASE_URL }}", "options": {} }, "typeVersion": 4.2, "notes": "This httpRequest node performs automated tasks as part of the workflow." }, { "id": "3c67c390-5144-44cb-8618-d7e7e6c6cae5", "name": "Extract title tag and meta description", "type": "n8n-nodes-base.html", "position": [ 700, 300 ], "parameters": { "options": {}, "operation": "extractHtmlContent", "extractionValues": { "values": [ { "key": "YOUR_CREDENTIAL_HERE", "cssSelector": "title" }, { "key": "YOUR_CREDENTIAL_HERE", "attribute": "content", "cssSelector": "meta[name=\"description\"]", "returnValue": "attribute" } ] } }, "typeVersion": 1.2, "notes": "This html node performs automated tasks as part of the workflow." }, { "id": "7028b7af-0959-4ed5-bc54-fceb2e224976", "name": "Update original record", "type": "n8n-nodes-base.airtable", "position": [ 940, 300 ], "parameters": { "base": { "__rl": true, "mode": "list", "value": "appkkDhXu7vZCFspD", "cachedResultUrl": "{{ $env.WEBHOOK_URL }}", "cachedResultName": "n8n test" }, "table": { "__rl": true, "mode": "list", "value": "tblMdmUiSTBrvrLq3", "cachedResultUrl": "{{ $env.WEBHOOK_URL }}", "cachedResultName": "SEO meta title & desc" }, "columns": { "value": { "id": "={{ $('Get records').item.json.id }}", "meta desc": "={{ $json.metaDesc }}", "title tag": "={{ $json.titleTag }}" }, "schema": [ { "id": "id", "type": "string", "display": true, "removed": false, "readOnly": true, "required": false, "displayName": "id", "defaultMatch": true }, { "id": "url", "type": "string", "display": true, "removed": false, "readOnly": false, "required": false, "displayName": "url", "defaultMatch": false, "canBeUsedToMatch": true }, { "id": "title tag", "type": "string", "display": true, "removed": false, "readOnly": false, "required": false, "displayName": "title tag", "defaultMatch": false, "canBeUsedToMatch": true }, { "id": "meta desc", "type": "string", "display": true, "removed": false, "readOnly": false, "required": false, "displayName": "meta desc", "defaultMatch": false, "canBeUsedToMatch": true }, { "id": "Created", "type": "string", "display": true, "removed": true, "readOnly": true, "required": false, "displayName": "Created", "defaultMatch": false, "canBeUsedToMatch": true }, { "id": "Calculation", "type": "string", "display": true, "removed": true, "readOnly": true, "required": false, "displayName": "Calculation", "defaultMatch": false, "canBeUsedToMatch": true } ], "mappingMode": "defineBelow", "matchingColumns": [ "id" ] }, "options": {}, "operation": "update" }, "credentials": { "airtableTokenApi": { "id": "yw6pm1U4Hw8kKDhu", "name": "Airtable Personal Access Token account" } }, "typeVersion": 2, "notes": "This airtable node performs automated tasks as part of the workflow." }, { "id": "5b518969-553e-462f-ad4f-eb07e9b17eef", "name": "Sticky Note", "type": "n8n-nodes-base.stickyNote", "position": [ 140, -60 ], "parameters": { "width": 862.7929292929296, "height": 316.6010101010099, "content": "## How to use the workflow\n1. Set a Base in Airtable with a table with the following structure:\n `url`, `title tag`, `meta desc`\n2. Connect Airtable to the nodes and, with the following formula, get all the records that miss `title tag` and `meta desc`.\n3. Put a bunch of url in the table in the field `url` and let the workflow work.\n\n## Extra\n\n* You can also calculate the length for title tag and meta desc using formula field inside Airtable. This is the formula:\n `LEN({title tag})` or `LEN({meta desc})`\n* You can automate the process calling a Webhook from Airtable. For this, you need an Airtable paid plan." }, "typeVersion": 1, "notes": "This stickyNote node performs automated tasks as part of the workflow." } ], "pinData": {}, "connections": { "0f26bb3c-f2cc-476b-b1af-3d4cd98463ce": { "main": [ [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-5b6e9b5e", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-96e818e7", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-24ad2931", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-f258b1cf", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-d6b48e79", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-3597bb33", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-840f10b6", "type": "main", "index": 0 } ], [ { "node": "error-handler-0f26bb3c-f2cc-476b-b1af-3d4cd98463ce-bb527ceb", "type": "main", "index": 0 } ] ] } }, "name": "Manualtrigger Workflow", "settings": { "executionOrder": "v1", "saveManualExecutions": true, "callerPolicy": "workflowsFromSameOwner", "errorWorkflow": null, "timezone": "UTC", "executionTimeout": 3600, "maxExecutions": 1000, "retryOnFail": true, "retryCount": 3, "retryDelay": 1000 }, "description": "Automated workflow: Manualtrigger Workflow. This workflow integrates 6 different services: stickyNote, httpRequest, airtable, stopAndError, manualTrigger. It contains 8 nodes and follows best practices for error handling and security.", "tags": [ "automation", "n8n", "production-ready", "excellent", "optimized" ], "notes": "Excellent quality workflow: Manualtrigger Workflow. This workflow has been optimized for production use with comprehensive error handling, security, and documentation." }