Skip to main content

SmtpError

Enum SmtpError 

Source
pub enum SmtpError {
    Io(IoError),
    Protocol(ProtocolError),
    Auth(AuthError),
    InvalidInput(InvalidInputError),
    Policy(PolicyError),
}
Expand description

Top-level error type for all SMTP operations.

§Logging caveat

The Display output of SmtpError (and of the variants Protocol(ProtocolError) and Auth(AuthError) in particular) embeds the server’s reply text verbatim. SMTP servers commonly include the rejected envelope address in their reply — e.g. 550 5.1.1 <user@example.com>: recipient does not exist — and may include other PII the application would not log of its own accord. When emitting these errors to a shared log channel, consider:

  • Logging only the structured fields you care about (during, actual, enhanced, code) and not the free-text message field.
  • Truncating the message to a fixed length.
  • Filtering / redacting addresses with an application-level regex if your compliance posture requires it.

joined_text() (the source of the message fields) is documented to potentially contain \n; see crate::protocol::Reply::joined_text.

Variants§

§

Io(IoError)

Underlying transport (socket) failure, including connection close.

§

Protocol(ProtocolError)

Server response did not match SMTP grammar or expected code.

§

Auth(AuthError)

Authentication exchange failed or no compatible mechanism was offered.

§

InvalidInput(InvalidInputError)

Caller-supplied input violated SMTP constraints before any byte was sent on the wire.

§

Policy(PolicyError)

A crate::policy::SendPolicy rejected the send before any SMTP command was issued.

Trait Implementations§

Source§

impl Debug for SmtpError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for SmtpError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Error for SmtpError

Source§

fn source(&self) -> Option<&(dyn StdError + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<AuthError> for SmtpError

Source§

fn from(value: AuthError) -> Self

Converts to this type from the input type.
Source§

impl From<InvalidInputError> for SmtpError

Source§

fn from(value: InvalidInputError) -> Self

Converts to this type from the input type.
Source§

impl From<IoError> for SmtpError

Source§

fn from(value: IoError) -> Self

Converts to this type from the input type.
Source§

impl From<PolicyError> for SmtpError

Source§

fn from(value: PolicyError) -> Self

Converts to this type from the input type.
Source§

impl From<ProtocolError> for SmtpError

Source§

fn from(value: ProtocolError) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.