mirror of
https://github.com/nodemailer/wildduck.git
synced 2025-01-21 07:19:02 +08:00
61 lines
No EOL
2.8 KiB
Markdown
61 lines
No EOL
2.8 KiB
Markdown
# WildDuck Mail Server
|
|
|
|
WildDuck is a scalable no-SPOF IMAP/POP3 mail server. WildDuck uses a distributed database (sharded + replicated MongoDB) as a backend for storing all data,
|
|
including emails.
|
|
|
|
WildDuck tries to follow Gmail in product design. If there's a decision to be made then usually the answer is to do whatever Gmail has done.
|
|
|
|
## Contact
|
|
|
|
[![Gitter chat](https://img.shields.io/gitter/room/nodemailer/wildduck?color=orange)](https://gitter.im/nodemailer/wildduck)
|
|
|
|
## Requirements
|
|
|
|
- _MongoDB_ to store all data
|
|
- _Redis_ for pubsub and counters
|
|
- _Node.js_ at least version 10.0.0
|
|
|
|
**Optional requirements**
|
|
|
|
- Redis Sentinel for automatic Redis failover
|
|
- Build tools to install optional dependencies that need compiling
|
|
|
|
WildDuck can be installed on any Node.js compatible platform.
|
|
|
|
## No-SPOF architecture
|
|
|
|
Every component of the WildDuck mail server can be replicated which eliminates potential single point of failures.
|
|
|
|
![](https://raw.githubusercontent.com/nodemailer/wildduck/master/assets/wd.png)
|
|
|
|
## Storage
|
|
|
|
Attachment de-duplication and compression gives up to 56% of storage size reduction.
|
|
|
|
![](https://raw.githubusercontent.com/nodemailer/wildduck/master/assets/storage.png)
|
|
|
|
## Goals of the Project
|
|
|
|
1. Build a scalable and distributed IMAP/POP3 server that uses clustered database instead of single machine file system as mail store
|
|
2. Allow using internationalized email addresses
|
|
3. Provide Gmail-like features like pushing sent messages automatically to Sent Mail folder or notifying about messages moved to Junk folder so these could be
|
|
marked as spam
|
|
4. Provide parsed mailbox and message data over HTTP. This should make creating webmail interfaces super easy, no need to parse RFC822 messages to get text
|
|
content or attachments
|
|
|
|
## Future considerations
|
|
|
|
- Optimize FETCH queries to load only partial data for BODY subparts
|
|
- Parse incoming message into the mime tree as a stream. Currently the entire message is buffered in memory before being parsed.
|
|
- Maybe allow some kind of message manipulation through plugins
|
|
- WildDuck does not plan to be the most feature-rich IMAP client in the world. Most IMAP extensions are useless because there aren't too many clients that are
|
|
able to benefit from these extensions. There are a few extensions though that would make sense to be added to WildDuck:
|
|
|
|
- IMAP4 non-synchronizing literals, LITERAL- ([RFC7888](https://tools.ietf.org/html/rfc7888)). Synchronized literals are needed for APPEND to check mailbox
|
|
quota, small values could go with the non-synchronizing version.
|
|
- LIST-STATUS ([RFC5819](https://tools.ietf.org/html/rfc5819))
|
|
- _What else?_ (definitely not NOTIFY nor QRESYNC)
|
|
|
|
## License
|
|
|
|
WildDuck Mail Agent is licensed under the [European Union Public License 1.2](https://joinup.ec.europa.eu/collection/eupl/eupl-text-eupl-12) or later. |