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.
company
and invoice
tablesTo 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.
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)
);
In n8n, add credentials for the email account that receives invoices:
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/... |
company
and invoice