This workflow follows the Emailsend → HTTP Request 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 →
{
"name": "VeriGrade - Monthly Close Automation",
"nodes": [
{
"parameters": {
"rule": {
"interval": [
{
"field": "cronExpression",
"expression": "0 0 L * *"
}
]
}
},
"id": "monthly-trigger",
"name": "Last Day of Month",
"type": "n8n-nodes-base.scheduleTrigger",
"typeVersion": 1,
"position": [
240,
300
]
},
{
"parameters": {
"url": "https://backend-lspqvhnjp-robertotos-projects.vercel.app/api/reports/monthly",
"method": "POST",
"sendBody": true,
"bodyParameters": {
"parameters": [
{
"name": "month",
"value": "={{ $now.minus({months: 1}).toFormat('yyyy-MM') }}"
},
{
"name": "includeBalanceSheet",
"value": true
},
{
"name": "includeProfitLoss",
"value": true
},
{
"name": "includeCashFlow",
"value": true
}
]
}
},
"id": "generate-reports",
"name": "Generate Financial Reports",
"type": "n8n-nodes-base.httpRequest",
"typeVersion": 4.1,
"position": [
460,
300
]
},
{
"parameters": {
"url": "https://backend-lspqvhnjp-robertotos-projects.vercel.app/api/reconciliation/status",
"queryParameters": {
"parameters": [
{
"name": "month",
"value": "={{ $now.minus({months: 1}).toFormat('yyyy-MM') }}"
}
]
}
},
"id": "check-reconciliation",
"name": "Bank Reconciliation Check",
"type": "n8n-nodes-base.httpRequest",
"typeVersion": 4.1,
"position": [
680,
300
]
},
{
"parameters": {
"operation": "sendEmail",
"email": "={{ $json.clientEmail }}",
"subject": "Monthly Financial Report - {{ $now.minus({months: 1}).toFormat('MMMM yyyy') }}",
"emailFormat": "html",
"attachments": "data",
"html": "<h2>Monthly Financial Summary</h2><p>Please find attached your financial reports for {{ $now.minus({months: 1}).toFormat('MMMM yyyy') }}</p>"
},
"id": "send-client-reports",
"name": "Send Reports to Clients",
"type": "n8n-nodes-base.emailSend",
"typeVersion": 2,
"position": [
900,
300
]
},
{
"parameters": {
"content": "\ud83d\udcca Monthly Close Complete!\n\nMonth: {{ $now.minus({months: 1}).toFormat('MMMM yyyy') }}\n\n\u2705 Reports generated\n\u2705 Reconciliation verified\n\u2705 Client reports sent",
"channel": "#month-end"
},
"id": "notify-completion",
"name": "Notify Completion",
"type": "n8n-nodes-base.slack",
"typeVersion": 2.1,
"position": [
1120,
300
]
}
],
"connections": {
"Last Day of Month": {
"main": [
[
{
"node": "Generate Financial Reports",
"type": "main",
"index": 0
}
]
]
},
"Generate Financial Reports": {
"main": [
[
{
"node": "Bank Reconciliation Check",
"type": "main",
"index": 0
}
]
]
},
"Bank Reconciliation Check": {
"main": [
[
{
"node": "Send Reports to Clients",
"type": "main",
"index": 0
}
]
]
},
"Send Reports to Clients": {
"main": [
[
{
"node": "Notify Completion",
"type": "main",
"index": 0
}
]
]
}
},
"active": true,
"settings": {},
"versionId": "1",
"id": "verigrade-monthly-close"
}
For the full experience including quality scoring and batch install features for each workflow upgrade to Pro
About this workflow
VeriGrade - Monthly Close Automation. Uses httpRequest, emailSend, slack. Scheduled trigger; 5 nodes.
Source: https://github.com/robertotorres1222-beep/verigrade-bookkeeping-platform/blob/20eaf88ca92b73417b9cc8abe2b8ec17eec5ceaa/n8n-workflows/4-monthly-close.json — 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 workflow contains community nodes that are only compatible with the self-hosted version of n8n.
Simplify financial oversight with this automated n8n workflow. Triggered daily, it fetches cash flow and expense data from a Google Sheet, analyzes inflows and outflows, validates records, and generat
This workflow automatically monitors competitor affiliate programs twice daily using Bright Data's web scraping API to extract commission rates, cookie durations, average order values, and payout term
Real Estate Market Scanning. Uses scheduleTrigger, httpRequest, splitOut, emailSend. Scheduled trigger; 15 nodes.
Automate your payroll process with this efficient workflow. Triggered monthly on the 28th, it fetches employee data from a Google Sheet, uses AI to calculate net salaries with tax and deductions, stru