1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
//! Create a dynamic mailer trait object depending on runtime mailer configuration.
//!
//! Microsoft Outlook and SMTP mailer variants are available.
//!
//! Example:
//!
//! ```no_run
//! // Create a `BoxMailer`.
//! //
//! // Alternative implementations can be used.
//!
//! let mailer = OutlookMailer::new(
//! "<Microsoft Identity service tenant>",
//! "<OAuth2 app GUID>",
//! "<OAuth2 app secret>"
//! ).await?;
//!
//! // Alternative:
//! let mailer = SmtpMailer::new(
//! "smtp.example.com",
//! 465,
//! SmtpInvalidCertsPolicy::Deny,
//! "<username>",
//! "<password>"
//! );
//!
//! // The implementation is `Send` and `Sync` and may be stored e.g. as part of your server state.
//!
//! // Build a message using the re-exported `mail_builder::MessageBuilder'.
//! // For blazingly fast rendering of beautiful HTML mail, I recommend combining `askama` with `mrml`.
//! let message = MessageBuilder::new()
//! .from(("From Name", "from@example.com"))
//! .to("to@example.com")
//! .subject("Subject")
//! .text_body("Mail body");
//!
//! // Send the message using the implementation-agnostic `dyn DynMailer`.
//! mailer.send_mail(&message).await?;
//! ```
pub use secrecy::Secret;
pub use async_mailer_core::mail_send;
pub use async_mailer_core::mail_send::mail_builder;
pub use async_mailer_core::mail_send::mail_builder::MessageBuilder;
pub use async_mailer_core::mail_send::smtp::message::Message;
pub use async_mailer_core::Mailer;
pub use async_mailer_core::ArcMailer;
pub use async_mailer_core::BoxMailer;
pub use async_mailer_core::DynMailer;
#[cfg(feature = "outlook")]
pub use async_mailer_outlook::*;
#[cfg(feature = "smtp")]
pub use async_mailer_smtp::*;