ETL pipeline for text processing
This workflow allows you to collect tweets, store them in MongoDB, analyse their sentiment, insert them into a Postgres database, and post positive tweets in a Slack channel.
Cron node: Schedule the workflow to run every day
Twitter node: Collect tweets
MongoDB node: Insert the collected tweets in MongoDB
Google Cloud Natural Language node: Analyse the sentiment of the collected tweets
Set node: Extract the sentiment score and magnitude
Postgres node: Insert the tweets and their sentiment score and magnitude in a Posgres database
IF node: Filter tweets with positive and negative sentiment scores
Slack node: Post tweets with a positive sentiment score in a Slack channel
NoOp node: Ignore tweets with a negative sentiment score
n8n ETL Pipeline for Text Processing
This n8n workflow provides a robust ETL (Extract, Transform, Load) pipeline for processing text data, incorporating natural language analysis, conditional logic, and database storage, with optional notifications. It's designed to be triggered on a schedule, fetch data from a database, analyze it, make decisions based on the analysis, and then store or notify as needed.
What it does
This workflow automates the following steps:
- Schedules Execution: The workflow is triggered periodically by a Cron job.
- Extracts Data from MongoDB: It connects to a MongoDB database to retrieve text data.
- Extracts Data from PostgreSQL: It also retrieves data from a PostgreSQL database.
- Analyzes Text with Google Cloud Natural Language: The extracted text data is sent to Google Cloud Natural Language for sentiment analysis or other text processing.
- Transforms Data: A Set node is used to manipulate or prepare the data, likely combining or reformatting the results from the database queries and natural language processing.
- Applies Conditional Logic: An If node evaluates the processed data (e.g., sentiment scores) to determine the next steps.
- Performs No Operation (Placeholder): If the condition in the If node evaluates to
false, a "No Operation" node is executed, indicating that no further action is taken for that specific data item. - Sends Notifications (Conditional): If the condition in the If node evaluates to
true, a message is sent to a Slack channel. - Posts to X (Formerly Twitter) (Conditional): If the condition in the If node evaluates to
true, a tweet is posted to X.
Prerequisites/Requirements
To use this workflow, you will need:
- n8n Instance: A running n8n instance.
- MongoDB Account/Instance: Access to a MongoDB database.
- PostgreSQL Account/Instance: Access to a PostgreSQL database.
- Google Cloud Account: With the Natural Language API enabled and configured credentials.
- Slack Account: To send notifications.
- X (Formerly Twitter) Account: To post tweets.
Setup/Usage
- Import the Workflow: Import the provided JSON into your n8n instance.
- Configure Credentials:
- Set up credentials for MongoDB.
- Set up credentials for PostgreSQL.
- Configure Google Cloud Natural Language credentials (typically an OAuth 2.0 or service account credential).
- Set up Slack credentials.
- Set up X (Formerly Twitter) credentials.
- Customize Nodes:
- Cron Node: Adjust the schedule as per your requirements.
- MongoDB Node: Configure the database, collection, and query to extract the desired text data.
- PostgreSQL Node: Configure the database, table, and query to extract the desired text data.
- Google Cloud Natural Language Node: Specify the text field to analyze and the desired analysis type (e.g., sentiment, entities).
- Edit Fields (Set) Node: Modify the fields to transform or combine data as needed.
- If Node: Define the conditions based on the output of the Google Cloud Natural Language analysis (e.g.,
if sentiment.score < -0.5). - Slack Node: Customize the message content and target channel.
- X Node: Customize the tweet content.
- Activate the Workflow: Once configured, activate the workflow to start the scheduled text processing.
Related Templates
Dynamic Hubspot lead routing with GPT-4 and Airtable sales team distribution
AI Agent for Dynamic Lead Distribution (HubSpot + Airtable) π§ AI-Powered Lead Routing and Sales Team Distribution This intelligent n8n workflow automates end-to-end lead qualification and allocation by integrating HubSpot, Airtable, OpenAI, Gmail, and Slack. The system ensures that every new lead is instantly analyzed, scored, and routed to the best-fit sales representative β all powered by AI logic, sir. --- π‘ Key Advantages β‘ Real-Time Lead Routing Automatically assigns new leads from HubSpot to the most relevant sales rep based on region, capacity, and expertise. π§ AI Qualification Engine An OpenAI-powered Agent evaluates the leadβs industry, region, and needs to generate a persona summary and routing rationale. π Centralized Tracking in Airtable Every lead is logged and updated in Airtable with AI insights, rep details, and allocation status for full transparency. π¬ Instant Notifications Slack and Gmail integrations alert the assigned rep immediately with full lead details and AI-generated notes. π Seamless CRM Sync Updates the original HubSpot record with lead persona, routing info, and timeline notes for audit-ready history, sir. --- βοΈ How It Works HubSpot Trigger β Captures a new lead as soon as itβs created in HubSpot. Fetch Contact Data β Retrieves all relevant fields like name, company, and industry. Clean & Format Data β A Code node standardizes and structures the data for consistency. Airtable Record Creation β Logs the lead data into the βLeadsβ table for centralized tracking. AI Agent Qualification β The AI analyzes the lead using the TeamDatabase (Airtable) to find the ideal rep. Record Update β Updates the same Airtable record with the assigned team and AI persona summary. Slack Notification β Sends a real-time message tagging the rep with lead info. Gmail Notification β Sends a personalized handoff email with context and follow-up actions. HubSpot Sync β Updates the original contact in HubSpot with the assignment details and AI rationale, sir. --- π οΈ Setup Steps Trigger Node: HubSpot β Detect new leads. HubSpot Node: Retrieve complete lead details. Code Node: Clean and normalize data. Airtable Node: Log lead info in the βLeadsβ table. AI Agent Node: Process lead and match with sales team. Slack Node: Notify the designated representative. Gmail Node: Email the rep with details. HubSpot Node: Update CRM with AI summary and allocation status, sir. --- π Credentials Required HubSpot OAuth2 API β To fetch and update leads. Airtable Personal Access Token β To store and update lead data. OpenAI API β To power the AI qualification and matching logic. Slack OAuth2 β For sending team notifications. Gmail OAuth2 β For automatic email alerts to assigned reps, sir. --- π€ Ideal For Sales Operations and RevOps teams managing multiple regions B2B SaaS and enterprise teams handling large lead volumes Marketing teams requiring AI-driven, bias-free lead assignment Organizations optimizing CRM efficiency with automation, sir --- π¬ Bonus Tip You can easily extend this workflow by adding lead scoring logic, language translation for follow-ups, or Salesforce integration. The entire system is modular β perfect for scaling across global sales teams, sir.
Track daily moods with AI analysis & reports using GPT-4o, Data Tables & Gmail
Track your daily mood in one tap and receive automated AI summaries of your emotional trends every week and month. Perfect for self-reflection, wellness tracking, or personal analytics. This workflow logs moods sent through a webhook (/mood) into Data Tables, analyzes them weekly and monthly with OpenAI (GPT-4o), and emails you clear summaries and actionable recommendations via Gmail. βοΈ How It Works Webhook β Mood β Collects new entries (π, π, or π©) plus an optional note. Set Mood Data β Adds date, hour, and note fields automatically. Insert Mood Row β Stores each record in a Data Table. Weekly Schedule (Sunday 20:00) β Aggregates the last 7 days and sends a summarized report. Monthly Schedule (Day 1 at 08:00) β Aggregates the last 30 days for a deeper AI analysis. OpenAI Analysis β Generates insights, patterns, and 3 actionable recommendations. Gmail β Sends the full report (chart + AI text) to your inbox. π Example Auto-Email Weekly Mood Summary (last 7 days) π 5 ββββββββββ π 2 ββββ π© 0 Average: 1.7 (Positive π) AI Insights: Youβre trending upward this week β notes show that exercise days improved mood. Try keeping short walks mid-week to stabilize energy. π§© Requirements n8n Data Tables enabled OpenAI credential (GPT-4o or GPT-4 Turbo) Gmail OAuth2 credential to send summaries π§ Setup Instructions Connect your credentials: Add your own OpenAI and Gmail OAuth2 credentials. Set your Data Table ID: Open the Insert Mood Row node and enter your own Data Table ID. Without this, new moods wonβt be stored. Replace the email placeholder: In the Gmail nodes, replace your.email@example.com with your actual address. Deploy and run: Send a test POST request to /mood (e.g. { "mood": "π", "note": "productive day" }) to log your first entry. β οΈ Before activating the workflow, ensure you have configured the Data Table ID in the βInsert Mood Rowβ node. π§ AI Analysis Interprets mood patterns using GPT-4o. Highlights trends, potential triggers, and suggests 3 specific actions. Runs automatically every week and month. π Security No personal data is exposed outside your n8n instance. Always remove or anonymize credential references before sharing publicly. π‘ Ideal For Personal mood journaling and AI feedback Therapists tracking client progress Productivity or self-quantification projects ποΈ Sticky Notes Guide π‘ Mood Logging Webhook POST /mood receives mood + optional note. β οΈ Configure your own Data Table ID in the βInsert Mood Rowβ node before running. π’ Weekly Summary Runs every Sunday 20:00 β aggregates last 7 days β generates AI insights + emails report. π΅ Monthly Summary Runs on Day 1 at 08:00 β aggregates last 30 days β creates monthly reflection. π£ AI Analysis Uses OpenAI GPT-4o to interpret trends and recommend actions. π Email Delivery Sends formatted summaries to your inbox automatically.
Create, update, and get a person from Copper
This workflow allows you to create, update, and get a person from Copper. Copper node: This node will create a new person in Copper. Copper1 node: This node will update the information of the person that we created using the previous node. Copper2 node: This node will retrieve the information of the person that we created earlier.