18 releases (1 stable)

2.0.0-alpha.5 Sep 8, 2024
2.0.0-alpha.4 Jul 23, 2024
2.0.0-alpha.1 Jun 7, 2024
1.0.0 Aug 22, 2023
0.2.2 Feb 22, 2021

#179 in Parser implementations

Download history 154/week @ 2024-09-21 98/week @ 2024-09-28 149/week @ 2024-10-05 131/week @ 2024-10-12 76/week @ 2024-10-19 73/week @ 2024-10-26 90/week @ 2024-11-02 119/week @ 2024-11-09 297/week @ 2024-11-16 282/week @ 2024-11-23 236/week @ 2024-11-30 502/week @ 2024-12-07 301/week @ 2024-12-14 137/week @ 2024-12-21 86/week @ 2024-12-28 147/week @ 2025-01-04

699 downloads per month
Used in 6 crates (2 directly)

MIT/Apache

1MB
17K SLoC

imap-codec

%%{init: {'theme': 'neutral' } }%%
flowchart LR
    imap-types --> imap-codec
    imap-codec -.-> imap-next
    imap-next -.-> imap-proxy
    imap-next -.-> imap-client
    
    style imap-codec stroke-width:4px
    
    click imap-types href "https://github.com/duesee/imap-codec/tree/main/imap-types"
    click imap-codec href "https://github.com/duesee/imap-codec"
    click imap-next href "https://github.com/duesee/imap-next"
    click imap-proxy href "https://github.com/duesee/imap-proxy"
    click imap-client href "https://github.com/soywod/imap-client"

This library provides parsing and serialization for IMAP4rev1. It is based on imap-types and a rock-solid and well-documented building block for IMAP client and server implementations in Rust. The complete formal syntax of IMAP4rev1 and several IMAP extensions are implemented.

If you are looking for thin protocol handling, i.e., LITERAL handling, AUTHENTICATE, and IDLE, head over to imap-next.

Features

  • Parsing works in streaming mode. Incomplete is returned when there is insufficient data to make a final decision. No message will be truncated.
  • Parsing is zero-copy by default. Allocation is avoided during parsing, but all messages can explicitly be converted into more flexible owned variants.
  • Fuzzing and property-based tests exercise the library. The library is fuzz-tested never to produce a message it can't parse itself.

Usage

use imap_codec::{decode::Decoder, encode::Encoder, CommandCodec};

fn main() {
    let input = b"ABCD UID FETCH 1,2:* (BODY.PEEK[1.2.3.4.MIME]<42.1337>)\r\n";

    let codec = CommandCodec::new();
    let (remainder, command) = codec.decode(input).unwrap();
    println!("# Parsed\n\n{:#?}\n\n", command);

    let buffer = codec.encode(&command).dump();

    // Note: IMAP4rev1 may produce messages that are not valid UTF-8.
    println!("# Serialized\n\n{:?}", std::str::from_utf8(&buffer));
}

License

This crate is dual-licensed under Apache 2.0 and MIT terms.

Dependencies

~2.3–3.5MB
~67K SLoC