Author: Martin Krivosija - LinkedIn
A simple, efficient script that provides an SMTP server to receive emails, parse content (including headers), store attachments in Amazon S3, and forward email content to a webhook. Graceful handling of multiple concurrent SMTP sessions and webhook requests.
- SMTP server to receive emails concurrently
- Parses incoming emails using
mailparser
- Uploads attachments to Amazon S3
- Forwards parsed email content to a specified webhook
- Configurable via environment variables
- Handles large attachments gracefully
- Robust queue system for processing multiple emails and webhook requests simultaneously
- Node.js (v18 or later recommended)
- If saving attachments, an Amazon Web Services (AWS) account with S3 access or a compatible system
- A HTTP(s) webhook endpoint to receive the processed emails
-
Clone this repository:
git clone https://github.com/kriiv/inbound-email.git cd inbound-email
-
Install dependencies:
npm install
-
Copy the
.env.example
file to.env
and set the required configuration: (eg.mv .env.example .env
)Variable Description Required Default WEBHOOK_URL
The URL where parsed emails will be sent Yes null
PORT
The port for the SMTP server to listen on No 25
SMTP_SECURE
Set to 'true' for TLS support (requires key/cert setup) No false
WEBHOOK_CONCURRENCY
Number of concurrent webhook requests No 5
MAX_FILE_SIZE
Maximum attachment size in bytes (0 to disable S3 uploads) No 5242880
(5MB)AWS_REGION
Your AWS region If saving null
AWS_ACCESS_KEY_ID
Your AWS access key ID If saving null
AWS_SECRET_ACCESS_KEY
Your AWS secret access key If saving null
S3_BUCKET_NAME
The name of your S3 bucket for storing attachments If saving null
TLS_KEY_PATH
Path to the TLS private key file (if SMTP_SECURE=true
)If secure null
TLS_CERT_PATH
Path to the TLS certificate file (if SMTP_SECURE=true
)If secure null
Note: S3 credentials (
AWS_*
,S3_BUCKET_NAME
) are required ifMAX_FILE_SIZE
> 0.
Start the server:
npm start
The SMTP server will start and listen on the specified port (default: 25) on all network interfaces.
You can use pm2 or supervisor to keep the server running after restart. Example: pm2 start server.js
-
Email to Ticket System: Use this bridge to receive support emails and automatically create tickets in your helpdesk system via the webhook.
-
Document Processing: Receive emails with document attachments, store them in S3, and trigger a document processing pipeline through the webhook.
-
Email Marketing Analysis: Collect incoming emails from a campaign, store any images or attachments, and send the content to an analytics system for processing.
-
Automated Reporting: Set up an email address that receives automated reports, stores them in S3, and notifies your team via the webhook.
-
DMARC Reporting: Receive DMARC reports via email and store them in S3.
Using inbound parse for something interesting? Please let me know, I'd love to hear about it.
- Rate limiting
Log Storage(completed)
Contributions are welcome! Please feel free to submit a Pull Request or get in touch.
This project is licensed under the MIT License. This means you are free to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the software, including for commercial purposes.
Please ensure you have the necessary permissions and security measures in place when deploying an SMTP server. Depending on your firewall configuration, you may be exposing this service to the internet.
When deploying this SMTP server, please keep the following security considerations in mind:
- Ensure that your server is properly secured and that only authorized IPs can access the SMTP port.
- Use strong, unique passwords for your AWS credentials and keep them secure.
- Regularly update the Node.js runtime and all dependencies to their latest versions.
- Consider implementing additional authentication mechanisms for the SMTP server if needed.
The server logs information about received emails, webhook responses, and any errors that occur. The current logging setup includes:
- Console output for immediate visibility
- Daily rotating log files for persistent storage
- JSON formatting of log entries for easy parsing
- Timestamp inclusion for each log entry
Logging settings:
- Log files are stored in the
logs/
directory - Files are named
application-YYYY-MM-DD.log
- Log files are rotated daily and compressed
- Maximum log file size is set to 20MB
- Log files are kept for 90 days
I recommend:
- Review log files regularly for errors or unusual patterns.
- Consider setting up log aggregation and analysis tools (e.g., ELK stack, Splunk).
- Implement alerts for critical errors or unusual activity patterns.
- Monitor system resources (CPU, memory, disk space) to ensure smooth operation.
- Set up uptime monitoring for the SMTP server and webhook endpoint.
- Node.js v18 or later
- Sufficient disk space for temporary storage of attachments before S3 upload and 90 days of logging.
- Outbound internet access for S3 uploads and webhook calls
- Inbound access on the configured SMTP port. (Default: 25, or 587 if
SMTP_SECURE
is set to 'true')
If you encounter issues:
- Check the server logs for any error messages.
- Ensure all environment variables are correctly set.
- Verify that your AWS credentials have the necessary permissions for S3 operations.
- Check that the webhook endpoint is accessible and responding correctly.
- For attachment issues, verify that the
MAX_FILE_SIZE
setting is appropriate for your use case.
If problems persist, please open an issue on the GitHub repository with detailed information about the error and your setup.