# mailgun-rs
An unofficial client library for the Mailgun API
```toml
# Cargo.toml
[dependencies]
mailgun-rs = "0.1.12"
```
### Examples
### Send with async
See [examples/async](examples/async)
```
$ cd examples/async
$ cargo run
```
#### Send a simple email
```rust
use mailgun_rs::{EmailAddress, Mailgun, MailgunRegion, Message};
use std::collections::HashMap;
fn main() {
let domain = "huatuo.xyz";
let key = "key-xxxxxx";
let recipient = "dongrium@gmail.com";
send_html(recipient, key, domain);
send_template(recipient, key, domain);
}
fn send_html(recipient: &str, key: &str, domain: &str) {
let recipient = EmailAddress::address(recipient);
let message = Message {
to: vec![recipient],
subject: String::from("mailgun-rs"),
html: String::from("
hello from mailgun
"),
..Default::default()
};
let client = Mailgun {
api_key: String::from(key),
domain: String::from(domain),
message,
};
let sender = EmailAddress::name_address("no-reply", "no-reply@hackerth.com");
match client.send(MailgunRegion::US, &sender) {
Ok(_) => {
println!("successful");
}
Err(err) => {
println!("Error: {err}");
}
}
}
```
### Send a template email
```rust
fn send_template(recipient: &str, key: &str, domain: &str) {
let mut template_vars = HashMap::new();
template_vars.insert(String::from("firstname"), String::from("Dongri"));
let recipient = EmailAddress::address(recipient);
let message = Message {
to: vec![recipient],
subject: String::from("mailgun-rs"),
template: String::from("template-1"),
template_vars,
..Default::default()
};
let client = Mailgun {
api_key: String::from(key),
domain: String::from(domain),
message,
};
let sender = EmailAddress::name_address("no-reply", "no-reply@hackerth.com");
match client.send(MailgunRegion::US, &sender) {
Ok(_) => {
println!("successful");
}
Err(err) => {
println!("Error: {err}");
}
}
}
```