Skip to main content

Create and approve social posts with Google Sheets, Slack and Gemini

Workflow preview

Workflow preview
100%
Create and approve social posts with Google Sheets, Slack and Gemini preview
Open on n8n.io

1. Workflow Overview

Quick Overview This workflow collects a social content brief, generates three strategy angles with Google Gemini and Serper web research, routes human approvals in Slack, then creates post copy plu...

Best for

  • Content Creation automation workflows
  • Multimodal AI automation workflows
  • advanced n8n builders looking for reusable templates

Tools used

n8n-nodes-base.stickynote, n8n-nodes-base.code, n8n-nodes-base.httprequesttool, n8n-nodes-base.formtrigger, n8n-nodes-base.set, @n8n/n8n-nodes-langchain.outputparserstructured, @n8n/n8n-nodes-langchain.agent, n8n-nodes-base.switch

Source and attribution

This workflow is cataloged by N8N Workflows and links back to its original n8n.io source page by Dave Sartori.

Original n8n.io source

1.1 Workflow description

Title
Create and approve social posts with Google Sheets, Slack and Gemini
Workflow name
Create and approve social posts with Google Sheets, Slack and Gemini

Quick Overview

This workflow collects a social content brief, generates three strategy angles with Google Gemini and Serper web research, routes human approvals in Slack, then creates post copy plus an image via fal.ai Recraft, and runs a final Anthropic-based review before logging outcomes to Google Sheets.

How it works

  1. Receives a new brief submission from an n8n Form and normalizes the fields (client, platform, content type, topic hint, tone note).
  2. Looks up the client profile in Google Sheets, emails IT via Gmail for approval if the client is missing, and otherwise generates a unique brief_id and logs the brief to a strategy tracking sheet.
  3. Uses a Google Gemini-powered agent with the Serper search tool (and Google Sheets retrieval for revisions) to produce three platform-specific post angles in structured JSON.
  4. Posts a Slack message with a link to an approval form where a strategist approves an angle, requests revisions (creating an incremented revised brief_id and regenerating angles), or cancels and logs the decision to Google Sheets.
  5. When an angle is approved, sends the selected angle and client context to a Marcus webhook, pulls platform specs from Google Sheets, and has a Google Gemini-powered agent draft the final post text and an image prompt (optionally retrieving prior versions for revision runs and using Tavily for visual research).
  6. Generates the single-image creative using fal.ai (Recraft text-to-image), logs the draft content to a Google Sheets “Post Content” tab, and requests human approval in Slack with an embedded preview.
  7. If approved, forwards the post and image URL to a Taylor webhook where an Anthropic agent reviews copy and image against client guidelines, then a final Slack form records the executive decision and logs approval, revision routing (back to Marcus or Sofia), or cancellation to Google Sheets.

Setup

  1. Connect Google Sheets OAuth2 credentials and update the document IDs/sheet tabs for the client database, social specs, strategy log, post content log, and post approval log.
  2. Add Slack API credentials, invite the Slack app to your target channel, and replace the hard-coded channel ID (for example, C0B5JFMJK6E) in all Slack message nodes.
  3. Add Gmail OAuth2 credentials and replace the placeholder recipient (YOUR_CUST_SERV_EMAIL) used for the “new client” escalation email.
  4. Add API credentials for Google Gemini (Google PaLM), Anthropic, Serper (HTTP Header Auth), Tavily (HTTP Header Auth), and fal.ai/Recraft (HTTP Header Auth) used for image generation.
  5. After importing, copy the generated webhook URLs for the Marcus and Taylor webhooks and paste them into the corresponding outbound HTTP request nodes (“To Marcus”, “To Taylor”, and the Marcus revision webhook call).

1.2 Logical Blocks

This catalog entry is organized from the workflow JSON. The node-level section below shows the executable blocks available for review before importing the template.

2. Block-by-Block Analysis

Block 1 - Sticky Note10

Type / Role
n8n-nodes-base.stickyNote - stickyNote
Config choices
Version 1

Block 2 - Generate brief_id

Type / Role
n8n-nodes-base.code - code
Config choices
Version 2

Block 3 - Serper

Type / Role
n8n-nodes-base.httpRequestTool - httpRequestTool
Config choices
Version 4.3

Block 4 - Brief Intake Form

Type / Role
n8n-nodes-base.formTrigger - formTrigger
Config choices
Version 2.2

Block 5 - Parse — Brief Fields

Type / Role
n8n-nodes-base.set - set
Config choices
Version 3.4

Block 6 - Structured Output Parser

Type / Role
@n8n/n8n-nodes-langchain.outputParserStructured - outputParserStructured
Config choices
Version 1.3

Block 7 - Sofia AI

Type / Role
@n8n/n8n-nodes-langchain.agent - agent
Config choices
Version 1.7

Block 8 - New Client?

Type / Role
n8n-nodes-base.switch - switch
Config choices
Version 3.2

Block 9 - Email to IT - New Client

Type / Role
n8n-nodes-base.gmail - gmail
Config choices
Version 2.1

Block 10 - IT Mssg

Type / Role
n8n-nodes-base.slack - slack
Config choices
Version 2.4

Block 11 - Approve Form

Type / Role
n8n-nodes-base.wait - wait
Config choices
Version 1.1

Block 12 - Approved Mssg

Type / Role
n8n-nodes-base.slack - slack
Config choices
Version 2.4

Block 13 - Cancelled Mssg

Type / Role
n8n-nodes-base.slack - slack
Config choices
Version 2.4

Block 14 - Get Post Angles

Type / Role
n8n-nodes-base.googleSheetsTool - googleSheetsTool
Config choices
Version 4.7

Block 15 - If Revision

Type / Role
n8n-nodes-base.if - if
Config choices
Version 2.3

Block 16 - DB - Log Brief

Type / Role
n8n-nodes-base.googleSheets - googleSheets
Config choices
Version 4.5

Block 17 - DB - Lookup Client

Type / Role
n8n-nodes-base.googleSheets - googleSheets
Config choices
Version 4.5

Block 18 - DB - Log Approved

Type / Role
n8n-nodes-base.googleSheets - googleSheets
Config choices
Version 4.5

Block 19 - DB - Log Cancel

Type / Role
n8n-nodes-base.googleSheets - googleSheets
Config choices
Version 4.5

Block 20 - Route Decision

Type / Role
n8n-nodes-base.switch - switch
Config choices
Version 3.2

Block 21 - parse

Type / Role
@n8n/n8n-nodes-langchain.outputParserStructured - outputParserStructured
Config choices
Version 1.3

Block 22 - Marcus AI

Type / Role
@n8n/n8n-nodes-langchain.agent - agent
Config choices
Version 1.7

Block 23 - Approve Form1

Type / Role
n8n-nodes-base.wait - wait
Config choices
Version 1.1

Block 24 - Approved Mssg1

Type / Role
n8n-nodes-base.slack - slack
Config choices
Version 2.4

Showing the first 24 of 114 workflow blocks. Download the JSON for the full node graph.

3. Summary Table

Workflow Create and approve social posts with Google Sheets, Slack and Gemini
Complexity advanced
Nodes 114
Categories Content Creation, Multimodal AI
Author Dave Sartori
Published 07 Jun 2026

4. Reproducing the Workflow from Scratch

  1. 1. Download the workflow JSON

    Use the JSON export at /data/workflows/16161/16161.json as the source template for this automation.

  2. 2. Import the template into n8n

    Open n8n, import the downloaded JSON, and review each node before activating the workflow.

  3. 3. Configure credentials and variables

    Replace placeholder credentials, API keys, webhook URLs, account IDs, and environment-specific values with your own settings.

  4. 4. Test with sample data

    Run the workflow manually or in a staging workspace, inspect node output, and confirm downstream systems receive the expected data.

  5. 5. Activate and monitor

    Enable the workflow only after testing, then monitor executions, errors, and rate limits during the first production runs.

5. General Notes & Resources

Review imported nodes carefully before activation. This catalog entry is intended to help you inspect the workflow structure, understand required services, and find related templates faster.

Node names, credentials, schedules, webhook paths, and external service limits may need adjustment for your workspace.

Frequently asked questions

What does Create and approve social posts with Google Sheets, Slack and Gemini do?

Quick Overview This workflow collects a social content brief, generates three strategy angles with Google Gemini and Serper web research, routes human approvals in Slack, then creates post copy plu...

What do I need before importing this workflow?

Review the workflow JSON, configure any required credentials in n8n, and test the automation in a safe workspace before using it in production.

Can I customize this workflow?

Yes. Use the block-by-block analysis and the downloadable JSON to inspect each node, then adjust credentials, prompts, schedules, filters, or destinations for your Content Creation, Multimodal AI use case.