This workflow corresponds to n8n.io template #5338 — we link there as the canonical source.
This workflow follows the Agent → Google Sheets 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 →
{
"id": "4nYklCFRD6OxVDKN",
"meta": {
"templateCredsSetupCompleted": true
},
"name": "\ud83d\udca5 Generate AI Videos with Seedance & Blotato and Upload to TikTok, YouTube & Instagram - version II - vide",
"tags": [],
"nodes": [
{
"id": "b0bfcf76-242e-46b9-b70d-9d569d20136b",
"name": "Sticky Note10",
"type": "n8n-nodes-base.stickyNote",
"position": [
592,
464
],
"parameters": {
"color": 2,
"width": 880,
"height": 256,
"content": "## | Step 1: Generate Clips (Seedance)\n"
},
"typeVersion": 1
},
{
"id": "194bda13-961d-4209-91f9-b5bcc8969d39",
"name": "Sticky Note13",
"type": "n8n-nodes-base.stickyNote",
"position": [
1504,
464
],
"parameters": {
"color": 2,
"width": 640,
"height": 256,
"content": "## | Step 2: Generate Sounds (Fal AI)\n"
},
"typeVersion": 1
},
{
"id": "7c81a4b7-672f-4df4-9452-a205385028d7",
"name": "Sticky Note14",
"type": "n8n-nodes-base.stickyNote",
"position": [
592,
-96
],
"parameters": {
"color": 7,
"width": 1560,
"height": 540,
"content": "## | INPUT: Starting Idea Section"
},
"typeVersion": 1
},
{
"id": "bc65e9e0-1265-4013-9d6c-7a0a535d3996",
"name": "Sticky Note",
"type": "n8n-nodes-base.stickyNote",
"position": [
592,
752
],
"parameters": {
"color": 3,
"width": 1560,
"height": 260,
"content": "## | Step 3: Stitch Video (Fal AI)"
},
"typeVersion": 1
},
{
"id": "7325db24-3e91-422c-805f-4b20c9173231",
"name": "Sticky Note2",
"type": "n8n-nodes-base.stickyNote",
"disabled": true,
"position": [
592,
1040
],
"parameters": {
"color": 4,
"width": 1560,
"height": 760,
"content": "## | Step 4 \u2014 Publish Video to Social Media\n"
},
"typeVersion": 1
},
{
"id": "a9ec7bac-5dcb-452c-b326-5caf7ba239ef",
"name": "Trigger: Start Daily Content Generation",
"type": "n8n-nodes-base.scheduleTrigger",
"position": [
640,
0
],
"parameters": {
"rule": {
"interval": [
{}
]
}
},
"typeVersion": 1.2
},
{
"id": "ff405b6a-9d01-4a5b-8b96-322cdac61d55",
"name": "Tool: Inject Creative Perspective (Idea)",
"type": "@n8n/n8n-nodes-langchain.toolThink",
"position": [
1088,
288
],
"parameters": {},
"typeVersion": 1
},
{
"id": "58e66ae7-debf-45c2-aa99-8b507b5d56cb",
"name": "Parse AI Output (Idea, Environment, Sound)",
"type": "@n8n/n8n-nodes-langchain.outputParserStructured",
"position": [
1248,
288
],
"parameters": {
"jsonSchemaExample": "[\n {\n \"Caption\": \"Diver Removes Nets Off Whale \ud83d\udc0b #whalerescue #marinelife #oceanrescue #seahelpers #love #nature #instagood #explore #viral #savenature #oceanguardians #cleanoceans\",\n \"Idea\": \"Diver carefully cuts tangled net from distressed whale in open sea\",\n \"Environment\": \"Open ocean, sunlight beams through water, diver and whale, cinematic realism\",\n \"Sound\": \"Primary sound description under 15 words\",\n \"Status\": \"for production\"\n }\n]\n"
},
"typeVersion": 1.2
},
{
"id": "ad438d7b-b0f5-4801-87df-e313bfb9c83f",
"name": "Save Idea & Metadata to Google Sheets",
"type": "n8n-nodes-base.googleSheets",
"position": [
1424,
0
],
"parameters": {
"columns": {
"value": {
"id": "==ROW()-1",
"idea": "={{ $json.output[0].Idea }}",
"caption": "={{ $json.output[0].Caption }}",
"production": "={{ $json.output[0].Status }}",
"sound_prompt": "={{ $json.output[0].Sound }}",
"environment_prompt": "={{ $json.output[0].Environment }}"
},
"schema": [
{
"id": "id",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "id",
"defaultMatch": true,
"canBeUsedToMatch": true
},
{
"id": "idea",
"type": "string",
"display": true,
"required": false,
"displayName": "idea",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "caption",
"type": "string",
"display": true,
"required": false,
"displayName": "caption",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "production",
"type": "string",
"display": true,
"required": false,
"displayName": "production",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "environment_prompt",
"type": "string",
"display": true,
"required": false,
"displayName": "environment_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "sound_prompt",
"type": "string",
"display": true,
"required": false,
"displayName": "sound_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "final_output",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "final_output",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"id"
],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "append",
"sheetName": {
"__rl": true,
"mode": "id",
"value": "="
},
"documentId": {
"__rl": true,
"mode": "id",
"value": "="
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"name": "<your credential>"
}
},
"typeVersion": 4.5
},
{
"id": "1d465451-7574-446b-b69f-94b5acc68e93",
"name": "LLM: Draft Video Prompt Details (GPT-4.1)",
"type": "@n8n/n8n-nodes-langchain.lmChatOpenAi",
"position": [
1664,
288
],
"parameters": {
"model": {
"__rl": true,
"mode": "list",
"value": "gpt-4.1",
"cachedResultName": "gpt-4.1"
},
"options": {}
},
"credentials": {
"openAiApi": {
"name": "<your credential>"
}
},
"typeVersion": 1.2
},
{
"id": "7de105c4-c5d4-4b53-8453-2a396b172027",
"name": "Tool: Refine and Validate Prompts1",
"type": "@n8n/n8n-nodes-langchain.toolThink",
"position": [
1840,
288
],
"parameters": {},
"typeVersion": 1
},
{
"id": "0f0c5fbd-5051-4e11-a9a1-5f4fca652084",
"name": "Parse Structured Video Prompt Output",
"type": "@n8n/n8n-nodes-langchain.outputParserStructured",
"position": [
2000,
288
],
"parameters": {
"jsonSchemaExample": "{\n \"Idea\": \"An obsidian rock being sliced with a shimmering knife\",\n \"Environment\": \"Clean studio table, subtle light reflections\",\n \"Sound\": \"Crisp slicing, deep grinding, and delicate crumbling\",\n \"Scene 1\": \"Extreme macro shot: a razor-sharp, polished knife blade presses into the dark, granular surface of an obsidian rock, just beginning to indent.\",\n \"Scene 2\": \"Close-up: fine, iridescent dust particles erupt from the point of contact as the blade cuts deeper into the obsidian, catching the studio light.\",\n \"Scene 3\": \"Mid-shot: the knife, held perfectly steady, has formed a shallow, clean groove across the obsidian's shimmering surface, revealing a new, smooth texture.\"\n}"
},
"typeVersion": 1.2
},
{
"id": "a5b35e3b-6dfe-4148-afd7-6eaf25a76658",
"name": "Extract Individual Scene Descriptions",
"type": "n8n-nodes-base.code",
"position": [
688,
544
],
"parameters": {
"jsCode": "function findSceneEntries(obj) {\n const scenes = [];\n\n for (const [key, value] of Object.entries(obj)) {\n if (key.toLowerCase().startsWith(\"scene\") && typeof value === \"string\") {\n scenes.push(value);\n } else if (typeof value === \"object\" && value !== null) {\n scenes.push(...findSceneEntries(value));\n }\n }\n\n return scenes;\n}\n\nlet output = [];\n\ntry {\n const inputData = items[0].json;\n const scenes = findSceneEntries(inputData);\n\n if (scenes.length === 0) {\n throw new Error(\"No scene keys found at any level.\");\n }\n\n output = scenes.map(scene => ({ description: scene }));\n} catch (e) {\n throw new Error(\"Could not extract scenes properly. Details: \" + e.message);\n}\n\nreturn output;\n"
},
"typeVersion": 2
},
{
"id": "08abfd2d-8b1f-43d2-8cec-e65755184060",
"name": "Wait for Clip Generation (Wavespeed AI)",
"type": "n8n-nodes-base.wait",
"position": [
1088,
544
],
"parameters": {
"unit": "minutes",
"amount": 4
},
"typeVersion": 1.1
},
{
"id": "1a9bc668-9f94-46d5-b615-8d2fc0f189aa",
"name": "Retrieve Video Clips",
"type": "n8n-nodes-base.httpRequest",
"position": [
1280,
544
],
"parameters": {
"url": "=https://api.wavespeed.ai/api/v3/predictions/{{ $json.data.id }}/result",
"options": {},
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "97119070-cee3-44e3-aea7-b3c74dbc63d9",
"name": "Generate ASMR Sound (Fal AI)",
"type": "n8n-nodes-base.httpRequest",
"position": [
1568,
544
],
"parameters": {
"url": "https://queue.fal.run/fal-ai/mmaudio-v2 ",
"method": "POST",
"options": {
"batching": {
"batch": {
"batchSize": 1,
"batchInterval": 2000
}
}
},
"jsonBody": "={\n \"prompt\": \"ASMR Soothing sound effects. {{$('Generate Detailed Video Prompts').item.json.output.Sound}}\",\n \"duration\": 10,\n \"video_url\": \"{{$json.data.outputs[0]}}\"\n}\n",
"sendBody": true,
"specifyBody": "json",
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "a7c6bedd-d091-464d-ba9c-63fa5fcaad0e",
"name": "Wait for Sound Generation (Fal AI)",
"type": "n8n-nodes-base.wait",
"position": [
1760,
544
],
"parameters": {
"unit": "minutes",
"amount": 4
},
"typeVersion": 1.1
},
{
"id": "98b705bc-7209-4f63-ac20-29e32fa8745d",
"name": "Retrieve Final Sound Output",
"type": "n8n-nodes-base.httpRequest",
"position": [
1968,
544
],
"parameters": {
"url": "=https://queue.fal.run/fal-ai/mmaudio-v2/requests/{{ $json.request_id }}",
"options": {},
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "d5d687e8-2043-4c0a-83fa-216e02810f68",
"name": "List Clip URLs for Stitching",
"type": "n8n-nodes-base.code",
"position": [
688,
800
],
"parameters": {
"jsCode": "return [\n {\n video_urls: items.map(item => item.json.video.url)\n }\n];"
},
"typeVersion": 2
},
{
"id": "bd5d153b-9636-4939-b13a-6f9119ff7f91",
"name": "Merge Clips into Final Video (Fal AI)",
"type": "n8n-nodes-base.httpRequest",
"position": [
880,
800
],
"parameters": {
"url": "https://queue.fal.run/fal-ai/ffmpeg-api/compose",
"body": "={\n \"tracks\": [\n {\n \"id\": \"1\",\n \"type\": \"video\",\n \"keyframes\": [\n { \"url\": \"{{ $json.video_urls[0] }}\", \"timestamp\": 0, \"duration\": 10 },\n { \"url\": \"{{ $json.video_urls[1] }}\", \"timestamp\": 10, \"duration\": 10 },\n { \"url\": \"{{ $json.video_urls[2] }}\", \"timestamp\": 20, \"duration\": 10 }\n ]\n }\n ]\n}",
"method": "POST",
"options": {
"batching": {
"batch": {
"batchSize": 1,
"batchInterval": 2000
}
}
},
"sendBody": true,
"contentType": "raw",
"authentication": "genericCredentialType",
"rawContentType": "application/json",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "5d63981d-857a-4912-bab2-8c5023e4b6f7",
"name": "Wait for Video Rendering (Fal AI)",
"type": "n8n-nodes-base.wait",
"position": [
1088,
800
],
"parameters": {
"unit": "minutes",
"amount": 4
},
"typeVersion": 1.1
},
{
"id": "a2325f16-6c9a-4e31-aacc-fec98bdf30ac",
"name": "Retrieve Final Merged Video",
"type": "n8n-nodes-base.httpRequest",
"position": [
1280,
800
],
"parameters": {
"url": "=https://queue.fal.run/fal-ai/ffmpeg-api/requests/{{ $json.request_id }}",
"options": {},
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "cc0c7ce6-f77e-4a72-b317-e2196e4894c5",
"name": "URL Final Video",
"type": "n8n-nodes-base.googleSheets",
"position": [
1968,
800
],
"parameters": {
"columns": {
"value": {
"idea": "={{ $('Save Idea & Metadata to Google Sheets').first().json.idea }}",
"production": "done",
"final_output": "={{ $json.video_url }}"
},
"schema": [
{
"id": "id",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "id",
"defaultMatch": true,
"canBeUsedToMatch": true
},
{
"id": "idea",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "idea",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "caption",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "caption",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "production",
"type": "string",
"display": true,
"required": false,
"displayName": "production",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "environment_prompt",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "environment_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "sound_prompt",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "sound_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "final_output",
"type": "string",
"display": true,
"required": false,
"displayName": "final_output",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "row_number",
"type": "number",
"display": true,
"removed": true,
"readOnly": true,
"required": false,
"displayName": "row_number",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"idea"
],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "update",
"sheetName": {
"__rl": true,
"mode": "id",
"value": "="
},
"documentId": {
"__rl": true,
"mode": "id",
"value": "="
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"name": "<your credential>"
}
},
"typeVersion": 4.5
},
{
"id": "25073052-c9f9-49a2-89c9-3fda74f9cef8",
"name": "Sticky Note11",
"type": "n8n-nodes-base.stickyNote",
"position": [
-128,
-96
],
"parameters": {
"color": 6,
"width": 700,
"height": 1892,
"content": "# \ud83c\udfac Generate AI Videos with Seedance & Blotato, Upload to TikTok, YouTube & Instagram \n\n---\n\n## \ud83c\udfa5 Full Tutorial \n\n## [Video Tutorial](https://youtu.be/AzOgpdn8ngY) \n@[youtube](AzOgpdn8ngY)\n\n---\n\n## \ud83d\udcd8 Documentation \nAccess detailed instructions, API guides, platform connections, and workflow customization: \n\n\ud83d\udcce [Open full documentation on Notion](https://automatisation.notion.site/Generate-AI-Videos-with-Seedance-Blotato-and-Upload-to-TikTok-YouTube-Instagram-version-II-21d3d6550fd980218096d84f31bfae2d?source=copy_link)\n\n---\n\n## \u2699\ufe0f Requirements\n\n1. \u2705 **OpenAI API Key** (added in LLM nodes) \n2. \ud83c\udfa8 **Seedance AI & Wavespeed AI credentials** (for prompt and video clip generation) \n3. \ud83d\udd0a **Fal AI API Key** (for sound effects + stitching via ffmpeg API) \n4. \ud83d\udce6 **n8n installed** (latest version recommended) \n5. \ud83d\udcdd **Google Sheets connected** (used to log ideas and outputs) \n \ud83d\udc49 [Google Sheet to copy](https://docs.google.com/spreadsheets/d/1Vd4XjcKZR_8cJ-2uqhOMZGc6GOULuHh_K3iDPvovw9E/copy) \n6. \u2601\ufe0f **Blotato API Key + configured social accounts** (TikTok, YouTube, Instagram, etc.) \n7. \u23f0 **Schedule Trigger setup** to define generation/publishing frequency \n\n---\n\n## \ud83d\udcdd Workflow Steps in n8n\n\n1. **Trigger / Start Node** \n Example: scheduled trigger or manual execution. \n\n2. **Content Creation** \n - OpenAI + LangChain generate creative ideas. \n - Seedance produces detailed video prompts. \n - Wavespeed AI generates video clips. \n - Fal AI adds sound + final editing (ffmpeg API). \n\n3. **Logging & Upload** \n - Metadata + links saved in Google Sheets. \n - Automatic upload via **Blotato**. \n - Publish to TikTok, YouTube, Instagram, etc. \n\n---\n\n## \ud83c\udf9b Need help customizing?\n\n**Contact me for consulting and support:** [LinkedIn](https://www.linkedin.com/in/dr-firas/) / [YouTube](https://www.youtube.com/@DRFIRASS) \n"
},
"typeVersion": 1
},
{
"id": "95548f68-3784-4cfa-8f26-88672710982a",
"name": "Generate Creative Video Idea",
"type": "@n8n/n8n-nodes-langchain.agent",
"position": [
960,
0
],
"parameters": {
"text": "Generate a creative concept involving:\n\n[[\nA solid, hard material or element being sliced cleanly with a sharp blade. Your response must follow this structure:\n\n\"(Color) (Material) shaped like a (random everyday object)\"\n\nFor inspiration, imagine examples like: obsidian shaped like a chess piece, quartz shaped like a coffee mug, sapphire shaped like a seashell, or titanium shaped like a leaf.\n\n]]\n\nReflect carefully before answering to ensure originality and visual appeal.\n\nUse the Think tool to review your output",
"options": {
"systemMessage": "=**Role:** \nYou are an AI designed to generate **one immersive, realistic idea** based on a user-provided topic. Your output must be formatted as a **single-line JSON array** and follow the rules below exactly.\n\n---\n\n### RULES\n\n1. **Number of ideas** \n - Return **only one idea**.\n\n2. **Topic** \n - The user will provide a keyword (e.g., \u201cglass cutting ASMR,\u201d \u201cwood carving sounds,\u201d \u201csatisfying rock splits\u201d).\n\n3. **Idea** \n - Maximum 13 words. \n - Describe a viral-worthy, original, or surreal moment related to the topic.\n\n4. **Caption** \n - Short, punchy, viral-friendly. \n - Include **one emoji**. \n - Exactly **12 hashtags** in this order: \n 1. 4 topic-relevant hashtags \n 2. 4 all-time most popular hashtags \n 3. 4 currently trending hashtags (based on live research) \n - All in lowercase.\n\n5. **Environment** \n - Maximum 20 words. \n - Must match the action in the Idea exactly. \n - Specify location (studio table, natural terrain, lab bench\u2026), visual details (dust particles, polished surface, subtle reflections\u2026), and style (macro close-up, cinematic slow-motion, minimalist\u2026).\n\n6. **Sound** \n - Maximum 15 words. \n - Describe the primary sound for the scene (to feed into an audio model).\n\n7. **Status** \n - Always set to `\"for production\"`.\n\n---\n\n### OUTPUT FORMAT (single-line JSON array)\n\n```json\n[\n {\n \"Caption\": \"Your short viral title with emoji #4_topic_hashtags #4_all_time_popular_hashtags #4_trending_hashtags\",\n \"Idea\": \"Your idea under 13 words\",\n \"Environment\": \"Your vivid setting under 20 words matching the action\",\n \"Sound\": \"Your primary sound description under 15 words\",\n \"Status\": \"for production\"\n }\n]\n"
},
"promptType": "define",
"hasOutputParser": true
},
"typeVersion": 1.9
},
{
"id": "3d72df45-beca-4a5b-b0dd-1a8ed583d952",
"name": "Generate Detailed Video Prompts",
"type": "@n8n/n8n-nodes-langchain.agent",
"position": [
1760,
0
],
"parameters": {
"text": "=Give me 3 video prompts based on the previous idea\n\nUse the Think tool to review your output",
"options": {
"systemMessage": "=Role: You are a prompt-generation AI specializing in cinematic, ASMR-style video prompts. Your task is to generate a multi-scene video sequence that vividly shows a sharp knife actively cutting through a specific object in a clean, high-detail setting.\n\nYour writing must follow this style:\n\nSharp, precise cinematic realism.\n\nMacro-level detail with tight focus on the blade interacting with the object.\n\nThe knife must always be in motion \u2014 slicing, splitting, or gliding through the material. Never idle or static.\n\nCamera terms are allowed (e.g. macro view, tight angle, over-the-blade shot).\n\nEach scene must contain all of the following, expressed through detailed visual language:\n\n\u2705 The main object or subject (from the Idea)\n\n\u2705 The cutting environment or surface (from the Environment)\n\n\u2705 The texture, structure, and behavior of the material as it\u2019s being cut\n\n\u2705 A visible, sharp blade actively cutting\n\nDescriptions should show:\n\nThe physical makeup of the material \u2014 is it translucent, brittle, dense, reflective, granular, fibrous, layered, or fluid-filled?\n\nHow the material responds to the blade \u2014 resistance, cracking, tearing, smooth separation, tension, vibration.\n\nThe interaction between the blade and the surface \u2014 light reflection, buildup of particles, contact points, residue or dust.\n\nAny ASMR-relevant sensory cues like particle release, shimmer, or subtle movement, but always shown visually \u2014 not narrated.\n\nTone:\n\nClean, clinical, visual.\n\nNo poetic metaphors, emotion, or storytelling.\n\nAvoid fantasy or surreal imagery.\n\nAll description must feel physically grounded and logically accurate.\n\nLength:\n\nEach scene must be between 1,000 and 2,000 characters.\n\nNo shallow or repetitive scenes \u2014 each must be immersive, descriptive, and specific.\n\nEach scene should explore a distinct phase of the cutting process, a different camera perspective, or a new behavior of the material under the blade.\n\nInputs:\n\nIdea: \"{{ $json.idea }}\"\nEnvironment: \"{{ $json.environment_prompt }}\"\nSound: \"{{ $json.sound_prompt }}\"\n\nFormat:\n\nIdea: \"...\"\nEnvironment: \"...\"\nSound: \"...\"\n\nScene 1: \"...\"\nScene 2: \"...\"\nScene 3: \"...\"\nScene 4: \"...\"\nScene 5: \"...\"\nScene 6: \"...\"\nScene 7: \"...\"\nScene 8: \"...\"\nScene 9: \"...\"\nScene 10: \"...\"\nScene 11: \"...\"\nScene 12: \"...\"\nScene 13: \"...\"\n\n"
},
"promptType": "define",
"hasOutputParser": true
},
"typeVersion": 1.9
},
{
"id": "d31597c6-f9e3-48d6-8a61-9a4424ef7021",
"name": "Generate Video Clips (seedance)",
"type": "n8n-nodes-base.httpRequest",
"position": [
880,
544
],
"parameters": {
"url": "https://api.wavespeed.ai/api/v3/bytedance/seedance-v1-pro-t2v-480p",
"method": "POST",
"options": {
"batching": {
"batch": {
"batchSize": 1,
"batchInterval": 3000
}
}
},
"jsonBody": "={\n \"aspect_ratio\": \"9:16\",\n \"duration\": 10,\n \"prompt\": \"VIDEO THEME: {{$('Generate Detailed Video Prompts').item.json.output.Idea}} | WHAT HAPPENS IN THE VIDEO: {{$json.description}} | WHERE THE VIDEO IS SHOT: {{$('Generate Detailed Video Prompts').item.json.output.Environment}}\"\n}\n",
"sendBody": true,
"specifyBody": "json",
"authentication": "genericCredentialType",
"genericAuthType": "httpHeaderAuth"
},
"credentials": {
"httpHeaderAuth": {
"name": "<your credential>"
}
},
"typeVersion": 4.2
},
{
"id": "6c89b710-f5b6-43d8-b5d6-19ee65a21178",
"name": "Upload Video to BLOTATO",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
688,
1568
],
"parameters": {
"mediaUrl": "={{ $json.final_output }}",
"resource": "media"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "dc0d81e5-e79f-4cac-8f70-2f3cb0245a4f",
"name": "Youtube",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1504,
1360
],
"parameters": {
"options": {},
"platform": "youtube",
"accountId": {
"__rl": true,
"mode": "list",
"value": "8047",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/8047",
"cachedResultName": "DR FIRASS (Dr. Firas)"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}",
"postCreateYoutubeOptionTitle": "={{ $('Save Idea & Metadata to Google Sheets').first().json.idea }}",
"postCreateYoutubeOptionPrivacyStatus": "private",
"postCreateYoutubeOptionShouldNotifySubscribers": false
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "72b01b16-ec37-4213-b373-61ff189be5ce",
"name": "Tiktok",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1136,
1184
],
"parameters": {
"options": {},
"platform": "tiktok",
"accountId": {
"__rl": true,
"mode": "list",
"value": "2079",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/2079",
"cachedResultName": "elitecybzcs"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "ecefa11f-55e1-47ca-8f1a-6e8fc4a6e1da",
"name": "Merge",
"type": "n8n-nodes-base.merge",
"position": [
1792,
1264
],
"parameters": {
"mode": "chooseBranch",
"numberInputs": 9
},
"typeVersion": 3.2
},
{
"id": "9b1c4354-4710-4e01-bc39-357da758fc1e",
"name": "Update Status to \"DONE\"",
"type": "n8n-nodes-base.googleSheets",
"position": [
1968,
1376
],
"parameters": {
"columns": {
"value": {
"idea": "={{ $('Save Idea & Metadata to Google Sheets').first().json.idea }}",
"production": "Publish"
},
"schema": [
{
"id": "id",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "id",
"defaultMatch": true,
"canBeUsedToMatch": true
},
{
"id": "idea",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "idea",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "caption",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "caption",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "production",
"type": "string",
"display": true,
"removed": false,
"required": false,
"displayName": "production",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "environment_prompt",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "environment_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "sound_prompt",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "sound_prompt",
"defaultMatch": false,
"canBeUsedToMatch": true
},
{
"id": "final_output",
"type": "string",
"display": true,
"removed": true,
"required": false,
"displayName": "final_output",
"defaultMatch": false,
"canBeUsedToMatch": true
}
],
"mappingMode": "defineBelow",
"matchingColumns": [
"idea"
],
"attemptToConvertTypes": false,
"convertFieldsToString": false
},
"options": {},
"operation": "appendOrUpdate",
"sheetName": {
"__rl": true,
"mode": "id",
"value": "="
},
"documentId": {
"__rl": true,
"mode": "id",
"value": "="
}
},
"credentials": {
"googleSheetsOAuth2Api": {
"name": "<your credential>"
}
},
"typeVersion": 4.5
},
{
"id": "aa5e2e2a-4796-4227-acbc-f35ed12d1f84",
"name": "Linkedin",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1328,
1184
],
"parameters": {
"options": {},
"platform": "linkedin",
"accountId": {
"__rl": true,
"mode": "list",
"value": "1446",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/1446",
"cachedResultName": "Samuel Amalric"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "0e0bf2c4-fba7-47f8-976b-8ac59e7e7c2a",
"name": "Facebook",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1504,
1184
],
"parameters": {
"options": {},
"platform": "facebook",
"accountId": {
"__rl": true,
"mode": "list",
"value": "1759",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/1759",
"cachedResultName": "Firass Ben"
},
"facebookPageId": {
"__rl": true,
"mode": "list",
"value": "101603614680195",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/1759/subaccounts/101603614680195",
"cachedResultName": "Dr. Firas"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "e7c07757-8d72-41bd-bb00-da0faed38e8a",
"name": "Instagram",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1136,
1360
],
"parameters": {
"options": {},
"accountId": {
"__rl": true,
"mode": "list",
"value": "11892",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/11892",
"cachedResultName": "doc.firass"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "d2e3223b-8355-42e1-a145-fbf6888725ef",
"name": "Threads",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1136,
1568
],
"parameters": {
"options": {},
"platform": "threads",
"accountId": {
"__rl": true,
"mode": "list",
"value": "2280",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/2280",
"cachedResultName": "doc.firass"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "03ef5dad-624d-49fa-85f8-767bdcd3f5ac",
"name": "Bluesky",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1328,
1568
],
"parameters": {
"options": {},
"platform": "bluesky",
"accountId": {
"__rl": true,
"mode": "list",
"value": "6012",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/6012",
"cachedResultName": "formationinternet.bsky.social"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "cdf84688-a254-4288-9cbc-b5c66f09cea0",
"name": "Pinterest",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1504,
1568
],
"parameters": {
"options": {},
"platform": "pinterest",
"accountId": {
"__rl": true,
"mode": "list",
"value": "363",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/363",
"cachedResultName": "formationinternet2022"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"pinterestBoardId": {
"__rl": true,
"mode": "id",
"value": "1146658823815436667"
},
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "9576e941-bd26-4b47-ae0d-4ec50350d9a3",
"name": "Twitter (X)",
"type": "@blotato/n8n-nodes-blotato.blotato",
"position": [
1328,
1360
],
"parameters": {
"options": {},
"platform": "twitter",
"accountId": {
"__rl": true,
"mode": "list",
"value": "1289",
"cachedResultUrl": "https://backend.blotato.com/v2/accounts/1289",
"cachedResultName": "Docteur_Firas"
},
"postContentText": "={{ $('Save Idea & Metadata to Google Sheets').first().json.caption }}",
"postContentMediaUrls": "={{ $json.url }}"
},
"credentials": {
"blotatoApi": {
"name": "<your credential>"
}
},
"typeVersion": 2
},
{
"id": "3912175b-5ccd-4b8e-8092-943ee7952434",
"name": "LLM: Generate Raw Idea (GPT-5)",
"type": "@n8n/n8n-nodes-langchain.lmChatOpenAi",
"position": [
912,
288
],
"parameters": {
"model": {
"__rl": true,
"mode": "list",
"value": "gpt-5-mini",
"cachedResultName": "gpt-5-mini"
},
"options": {}
},
"credentials": {
"openAiApi": {
"name": "<your credential>"
}
},
"typeVersion": 1.2
}
],
"active": false,
"settings": {
"executionOrder": "v1"
},
"versionId": "527f2751-2d7e-4749-87ed-7df50bb3da1b",
"connections": {
"Merge": {
"main": [
[
{
"node": "Update Status to \"DONE\"",
"type": "main",
"index": 0
}
]
]
},
"Tiktok": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 0
}
]
]
},
"Bluesky": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 7
}
]
]
},
"Threads": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 6
}
]
]
},
"Youtube": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 5
}
]
]
},
"Facebook": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 2
}
]
]
},
"Linkedin": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 1
}
]
]
},
"Instagram": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 3
}
]
]
},
"Pinterest": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 8
}
]
]
},
"Twitter (X)": {
"main": [
[
{
"node": "Merge",
"type": "main",
"index": 4
}
]
]
},
"URL Final Video": {
"main": [
[
{
"node": "Upload Video to BLOTATO",
"type": "main",
"index": 0
}
]
]
},
"Retrieve Video Clips": {
"main": [
[
{
"node": "Generate ASMR Sound (Fal AI)",
"type": "main",
"index": 0
}
]
]
},
"Update Status to \"DONE\"": {
"main": [
[]
]
},
"Upload Video to BLOTATO": {
"main": [
[
{
"node": "Tiktok",
"type": "main",
"index": 0
},
{
"node": "Linkedin",
"type": "main",
"index": 0
},
{
"node": "Facebook",
"type": "main",
"index": 0
},
{
"node": "Instagram",
"type": "main",
"index": 0
},
{
"node": "Twitter (X)",
"type": "main",
"index": 0
},
{
"node": "Youtube",
"type": "main",
"index": 0
},
{
"node": "Threads",
"type": "main",
"index": 0
},
{
"node": "Bluesky",
"type": "main",
"index": 0
},
{
"node": "Pinterest",
"type": "main",
"index": 0
}
]
]
},
"Retrieve Final Merged Video": {
"main": [
[
{
"node": "URL Final Video",
"type": "main",
"index": 0
}
]
]
},
"Retrieve Final Sound Output": {
"main": [
[
{
"node": "List Clip URLs for Stitching",
"type": "main",
"index": 0
}
]
]
},
"Generate ASMR Sound (Fal AI)": {
"main": [
[
{
"node": "Wait for Sound Generation (Fal AI)",
"type": "main",
"index": 0
}
]
]
},
"Generate Creative Video Idea": {
"main": [
[
{
"node": "Save Idea & Metadata to Google Sheets",
"type": "main",
"index": 0
}
]
]
},
"List Clip URLs for Stitching": {
"main": [
[
{
"node": "Merge Clips into Final Video (Fal AI)",
"type": "main",
"index": 0
}
]
]
},
"LLM: Generate Raw Idea (GPT-5)": {
"ai_languageModel": [
[
{
"node": "Generate Creative Video Idea",
"type": "ai_languageModel",
"index": 0
}
]
]
},
"Generate Detailed Video Prompts": {
"main": [
[
{
"node": "Extract Individual Scene Descriptions",
"type": "main",
"index": 0
}
]
]
},
"Generate Video Clips (seedance)": {
"main": [
[
{
"node": "Wait for Clip Generation (Wavespeed AI)",
"type": "main",
"index": 0
}
]
]
},
"Wait for Video Rendering (Fal AI)": {
"main": [
[
{
"node": "Retrieve Final Merged Video",
"type": "main",
"index": 0
}
]
]
},
"Tool: Refine and Validate Prompts1": {
"ai_tool": [
[
{
"node": "Generate Detailed Video Prompts",
"type": "ai_tool",
"index": 0
}
]
]
},
"Wait for Sound Generation (Fal AI)": {
"main": [
[
{
"node": "Retrieve Final Sound Output",
"type": "main",
"index": 0
}
]
]
},
"Parse Structured Video Prompt Output": {
"ai_outputParser": [
[
{
"node": "Generate Detailed Video Prompts",
"type": "ai_outputParser",
"index": 0
}
]
]
},
"Extract Individual Scene Descriptions": {
"main": [
[
{
"node": "Generate Video Clips (seedance)",
"type": "main",
"index": 0
}
]
]
},
"Merge Clips into Final Video (Fal AI)": {
"main": [
[
{
"node": "Wait for Video Rendering (Fal AI)",
"type": "main",
"index": 0
}
]
]
},
"Save Idea & Metadata to Google Sheets": {
"main": [
[
{
"node": "Generate Detailed Video Prompts",
"type": "main",
"index": 0
}
]
]
},
"Trigger: Start Daily Content Generation": {
"main": [
[
{
"node": "Generate Creative Video Idea",
"type": "main",
"index": 0
}
]
]
},
"Wait for Clip Generation (Wavespeed AI)": {
"main": [
[
{
"node": "Retrieve Video Clips",
"type": "main",
"index": 0
}
]
]
},
"Tool: Inject Creative Perspective (Idea)": {
"ai_tool": [
[
{
"node": "Generate Creative Video Idea",
"type": "ai_tool",
"index": 0
}
]
]
},
"LLM: Draft Video Prompt Details (GPT-4.1)": {
"ai_languageModel": [
[
{
"node": "Generate Detailed Video Prompts",
"type": "ai_languageModel",
"index": 0
}
]
]
},
"Parse AI Output (Idea, Environment, Sound)": {
"ai_outputParser": [
[
{
"node": "Generate Creative Video Idea",
"type": "ai_outputParser",
"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.
blotatoApigoogleSheetsOAuth2ApihttpHeaderAuthopenAiApi
For the full experience including quality scoring and batch install features for each workflow upgrade to Pro
About this workflow
This template is ideal for creators, content marketers, social media managers, and AI enthusiasts who want to automate the production of short-form, visually captivating videos for platforms like TikTok, YouTube Shorts, and Instagram Reels — all without manual editing or…
Source: https://n8n.io/workflows/5338/ — 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.
This n8n workflow is a fully automated pipeline that takes a creative concept and transforms it into a polished, platform-ready short-form video. It ideates, generates video and audio using AI, merges
This workflow contains community nodes that are only compatible with the self-hosted version of n8n.
Automate your cross-platform publishing workflow by automatically uploading Instagram videos to YouTube with AI-optimized titles and tags. 🚀🎬 This workflow runs every six hours, fetches newly posted I
Youtube Video Creator. Uses googleSheets, chainLlm, lmChatOpenAi, outputParserStructured. Scheduled trigger; 21 nodes.
What It Does