Invoice Processing: Email to PostgreSQL Database with GPT-4o & Discord Alerts

AI-Powered Invoice Processing: from Email to Database & Chat Notifications

Automatically process PDF invoices directly from your email inbox. This workflow uses AI to extract key data, saves it to a PostgreSQL database, and instantly notifies you about the new document in your preferred chat application.

The workflow listens for new emails, fetches PDF attachments, and then passes their content to a Large Language Model (LLM) for intelligent recognition and data extraction. Finally, the information is securely archived in the database, and a summary of the invoice is sent as a notification.

> πŸ“ This workflow is highly customizable.
> It uses PostgreSQL, OpenAI (GPT), and Discord by default, but you can easily swap these components.
> Feel free to use a different database like MySQL or Airtable, another AI model provider, or send notifications to Slack, MS Teams, or any other chat platform.

> ⚠️ Note: If the workflow fails to extract data correctly from invoices issued by certain companies, you may need to adjust the prompt used in the Basic LLM Chain node to improve parsing accuracy.

Use Case

Automating accounts payable for small businesses and freelancers
Centralizing financial documents without manual data entry
Creating a searchable database of all incoming invoices
Receiving real-time notifications for new financial commitments

Features

πŸ“§ Email Trigger (IMAP):** Monitors a dedicated email inbox for new messages with attachments
πŸ“„ PDF Filtering:** Automatically identifies and processes only PDF attachments
πŸ€– AI-Powered Data Extraction:** Uses an LLM (e.g., GPT-4o-mini) to extract invoice number, buyer/seller details, amounts, currency, and due dates
βš™οΈ Structured Data Output:** Converts AI output to standardized JSON
πŸ” Database Write Logic:** Prevents duplicates by checking invoice/company combo
πŸ—„οΈ PostgreSQL Integration:** Stores extracted data into company and invoice tables
πŸ’¬ Chat Notifications:** Sends invoice summary as message to a designated channel

Setup Instructions

⚠️ API Access & Costs

To use the AI extraction feature, you need an API key from a provider like OpenAI.
Most providers charge for access to language models. You'll likely need a billing account.

  1. PostgreSQL Database Configuration

Ensure your database has the following tables:

-- Table for companies (invoice issuers) CREATE TABLE company ( id SERIAL PRIMARY KEY, tax_number VARCHAR(255) UNIQUE NOT NULL, name VARCHAR(255), address TEXT, created_at TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP );

-- Table for invoices CREATE TABLE invoice ( id SERIAL PRIMARY KEY, company_id INTEGER REFERENCES company(id), invoice_number VARCHAR(255) NOT NULL, -- Add other fields: total_to_pay, currency, due_date created_at TIMESTAMP WITH TIME ZONE DEFAULT CURRENT_TIMESTAMP, UNIQUE(company_id, invoice_number) );

Then, in n8n, create a credential for your PostgreSQL DB.

  1. Email (IMAP) Configuration

In n8n, add credentials for the email account that receives invoices:

IMAP host
IMAP port
Username
Password

  1. AI Provider Configuration

Log in to OpenAI (or similar provider)
Generate API key
In n8n, create credentials and paste the key

  1. Chat Notification (Discord)

Go to Discord > Server Settings > Integrations > Webhooks > New Webhook
Select channel
Copy Webhook URL
In n8n, paste URL into the Discord node

Placeholders and Fields to Fill

| Placeholder | Description | Example | |---------------------------|-------------------------------------------|------------------------------------------| | YOUR_EMAIL_CREDENTIALS | Your IMAP email account in n8n | My Invoice Mailbox | | YOUR_OPENAI_CREDENTIALS | API credentials for AI model | My OpenAI Key | | YOUR_POSTGRES_CREDENTIALS| Your PostgreSQL DB credentials in n8n | My Production DB | | YOUR_DISCORD_WEBHOOK | Webhook URL for your chat system | https://discord.com/api/webhooks/... |

Testing the Workflow

Send a test invoice to the inbox as a PDF attachment
Run the workflow manually in n8n and check if the IMAP node fetches the message
Verify AI Extraction – inspect the LLM output (e.g., GPT node) and confirm structured JSON
Check the DB – ensure new rows appear in company and invoice
Check the chat – verify the invoice summary appears in the chosen channel

Customization Tips

Change the DB:** Use MySQL, Airtable, or Google Sheets instead of PostgreSQL
Other notifications:** Swap Discord for Slack, MS Teams, Telegram, etc.
Expand AI logic:** Extract line items, prices, etc. by customizing the prompt
Add payment logic:** Allow marking invoices as paid via emoji or a separate webhook

0
Downloads
0
Views
8.54
Quality Score
intermediate
Complexity
Author:Halfbit πŸš€(View Original β†’)
Created:8/13/2025
Updated:8/25/2025

πŸ”’ Please log in to import templates to n8n and favorite templates

Workflow Visualization

Loading...

Preparing workflow renderer

Comments (0)

Login to post comments