9 releases (5 stable)

1.1.1 Oct 28, 2023
1.1.0 Oct 24, 2023
1.0.1 Sep 10, 2023
0.1.7 Jul 25, 2023
0.1.6 Apr 19, 2023

#72 in Email

Download history 92/week @ 2024-07-22 65/week @ 2024-07-29 81/week @ 2024-08-05 182/week @ 2024-08-12 291/week @ 2024-08-19 85/week @ 2024-08-26 142/week @ 2024-09-02 55/week @ 2024-09-09 37/week @ 2024-09-16 116/week @ 2024-09-23 57/week @ 2024-09-30 26/week @ 2024-10-07 65/week @ 2024-10-14 36/week @ 2024-10-21 30/week @ 2024-10-28 55/week @ 2024-11-04

188 downloads per month
Used in 2 crates

MIT license

85KB
2K SLoC

Pop3 client

This is a simple Pop3 client that implements all of the features according to RFC 1939, written in Rust.

It is used in Dust-Mail to connect to Pop servers.

Usage

You can create a new session using the connect function or the connect_plain function.

connect expects a tls connector from the async-native-tls crate. In the future more tls options will be supported.

If you already have a connected socket, you can also create a new session using the new function.

Example

extern crate async_pop;
extern crate async_native_tls;
extern crate mailparse;

use async_native_tls::TlsConnector;
use mailparse::parse_mail;

#[tokio::main]
async fn main() {
    let tls = TlsConnector::new();

    let mut client = async_pop::connect(("pop.gmail.com", 995), "pop.gmail.com", &tls).await.unwrap();

    client.login("example@gmail.com", "password").await.unwrap();

    let bytes = client.retr(1).await.unwrap();

    let message = parse_mail(&bytes).unwrap();

    let subject = message.headers.get_first_value("Subject").unwrap();

    println!("{}", subject);

}

Dependencies

~4–16MB
~215K SLoC