This workflow follows the Airtable → HTTP Request recipe pattern — see all workflows that pair these two integrations.
The workflow JSON
Copy or download the full n8n JSON below. Paste it into a new n8n workflow, add your credentials, activate. Full import guide →
{
"nodes": [
{
"id": "b9962fd6-af11-4a3a-935c-c168ac85eaa1",
"name": "When clicking \"Test workflow\"",
"type": "n8n-nodes-base.manualTrigger",
"position": [
80,
300
],
"parameters": {},
"typeVersion": 1
},
{
"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": "https://airtable.com/appkkDhXu7vZCFspD",
"cachedResultName": "n8n test"
},
"limit": 10,
"table": {
"__rl": true,
"mode": "list",
"value": "tblMdmUiSTBrvrLq3",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD/tblMdmUiSTBrvrLq3",
"cachedResultName": "SEO meta title & desc"
},
"options": {},
"operation": "search",
"returnAll": false,
"filterByFormula": "=AND(url != \"\", {title tag} = \"\", {meta desc} = \"\")"
},
"credentials": {
"airtableTokenApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "0f26bb3c-f2cc-476b-b1af-3d4cd98463ce",
"name": "Get url content",
"type": "n8n-nodes-base.httpRequest",
"position": [
500,
300
],
"parameters": {
"url": "={{ $json.url }}",
"options": {}
},
"typeVersion": 4.2
},
{
"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": "titleTag",
"cssSelector": "title"
},
{
"key": "metaDesc",
"attribute": "content",
"cssSelector": "meta[name=\"description\"]",
"returnValue": "attribute"
}
]
}
},
"typeVersion": 1.2
},
{
"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": "https://airtable.com/appkkDhXu7vZCFspD",
"cachedResultName": "n8n test"
},
"table": {
"__rl": true,
"mode": "list",
"value": "tblMdmUiSTBrvrLq3",
"cachedResultUrl": "https://airtable.com/appkkDhXu7vZCFspD/tblMdmUiSTBrvrLq3",
"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": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"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
}
],
"connections": {
"Get records": {
"main": [
[
{
"node": "Get url content",
"type": "main",
"index": 0
}
]
]
},
"Get url content": {
"main": [
[
{
"node": "Extract title tag and meta description",
"type": "main",
"index": 0
}
]
]
},
"When clicking \"Test workflow\"": {
"main": [
[
{
"node": "Get records",
"type": "main",
"index": 0
}
]
]
},
"Extract title tag and meta description": {
"main": [
[
{
"node": "Update original record",
"type": "main",
"index": 0
}
]
]
}
}
}
Credentials you'll need
Each integration node will prompt for credentials when you import. We strip credential IDs before publishing — you'll add your own.
airtableTokenApi
For the full experience including quality scoring and batch install features for each workflow upgrade to Pro
About this workflow
Manual Http. Uses manualTrigger, airtable, httpRequest, html. Event-driven trigger; 6 nodes.
Source: https://github.com/Zie619/n8n-workflows — original creator credit. Request a take-down →
Related workflows
Workflows that share integrations, category, or trigger type with this one. All free to copy and import.
Splitout Code. Uses airtable, formTrigger, form, splitOut. Event-driven trigger; 34 nodes.
This n8n template showcases a cool feature of n8n Forms where the form itself can be defined dynamically using the form fields schema.
Code. Uses googleDrive, httpRequest, googleDriveTrigger, airtable. Event-driven trigger; 18 nodes.
Dynamically create tables in Airtable for your Webflow form submissions. Uses webflowTrigger, httpRequest, airtable, stickyNote. Event-driven trigger; 17 nodes.
Effortlessly convert any text into stunningly realistic, high-quality audio with this powerful n8n workflow. Leveraging Google's advanced Text-to-Speech (TTS) AI, this template provides a complete, en