All feedback welcome. Feel free to file bugs, requests for documentation and any other feedback to the issue tracker or tweet me.
tokio-imap and imap-proto were created by and are maintained by Dirkjan Ochtman. If you are in a position to support ongoing maintenance and further development or use it in a for-profit context, please consider supporting my open source work on Patreon.
A Tokio stack-based, fully asynchronous IMAP library, with strong focus on following the relevant specs, mainly IMAP4rev1, but with limited support for the Conditional STORE extension. The type system is used to help enforce correctness where possible. So far, there is only client code and lots of infrastructure that supposedly could be shared -- no server yet. (If you want a tokio-based server, look at IMAPServer.)
- Fully asynchronous by using tokio-core and tokio-io
- Uses the type system to help enforce correct operation according to spec
- nom-based parser (in imap-proto), so far only used for server response messages
- Alpha-level implementation -- no tests yet, limited protocol coverage
- Server is totally unimplemented at this stage
Have a look at the mailsync crate for example usage.
imap-proto is a low-level IMAP protocol support crate, using the type system to provide a safe API. It was extracted from tokio-imap into a separate crate so that different protocol implementations can share it as common infrastructure (as proposed by rust-imap contributors). The code tries to closely follow the IMAP4rev1 RFC, plus extensions.
Protocol support is implemented in three parts:
- Types that attempt to closely reflect specification requirements
- A parser implementation to help consume protocol messages
- Builder types to help produce protocol messages
- Client
- Parser: many common server responses implemented
- Types: most common types implemented
- Message builder: most common commands implemented
- Server
- Parser: not started
- Types: not started
- Message builder: not started