sendgrid_thin

Crates.iosendgrid_thin
lib.rssendgrid_thin
version0.4.5
sourcesrc
created_at2022-11-09 01:05:01.372441
updated_at2023-04-28 23:27:01.512925
descriptionA small unofficial library to send emails using Sendgrid.
homepagehttps://sendgrid.com
repositoryhttps://github.com/OLoKo64/sendgrid_thin
max_upload_size
id708413
size28,189
Reinaldo Rozato Junior (oloko64)

documentation

README

sendgrid_thin

Tests

A thin wrapper around the SendGrid V3 API.

It exposes a simple API to send emails with SendGrid with a blocking or non-blocking way.

You can use it inside your Actix, Axum or Rocket application without any problems.

To get the API key, you need to create an account on SendGrid and create an API key.

I recommend the dotenvy crate to load the API key from an environment variable.

Usage

    use sendgrid_thin::{Sendgrid, ContentType};

    #[tokio::main]
    async fn main() {
        let sendgrid = Sendgrid::builder(
                "SENDGRID_API_KEY",
                "from_email@example.com",
                ["to_email_1@example.com","to_email_2@example.com"],
                "subject of email",
                "body of email",
            )
            .set_content_type(ContentType::Html)
            .set_send_at(1668281500)
            .set_request_timeout(std::time::Duration::from_secs(10))
            .set_cc_emails(["cc_email_1@example.com", "cc_email_2@example.com"])
            .build()
            .unwrap();

        // Send the email with a non-blocking client
        match sendgrid.send().await {
            Ok(message) => println!("{message}"),
            Err(err) => println!("Error sending email: {err}"),
        }

        // Send the email with a blocking client (in this case the main function cannot be async)
        match sendgrid.send_blocking() {
            Ok(message) => println!("{message}"),
            Err(err) => println!("Error sending email: {err}"),
        }
    }

Features

Default features

  • blocking - Enables the blocking client

You can disable the default features by adding the following to your Cargo.toml:

sendgrid_thin = { version = "x.x.x", default-features = false }

Or when adding the dependency via cargo add:

cargo add sendgrid_thin --no-default-features
Commit count: 89

cargo fmt