smtp-mail-ng: An SMTP client EDSL

[ bsd3, library, network ] [ Propose Tags ]

An SMTP client EDSL

[Skip to Readme]
Versions [RSS] [faq],,
Dependencies attoparsec (>=0.12 && <0.14), base (>=4.7 && <4.9), base16-bytestring (==0.1.*), base64-bytestring (==1.0.*), bytestring (==0.10.*), crypto-random (==0.0.*), cryptohash (==0.11.*), filepath (>=1.3 && <1.5), haskeline (==0.7.*), mime-mail (==0.4.*), mtl (>=2.0 && <2.3), network (==2.6.*), stringsearch (>=, text (==1.2.*), tls (>=1.2 && <1.4), transformers (>=0.2), transformers-compat (>=0.3), x509-store (>=1.5 && <1.7), x509-system (>=1.5 && <1.7) [details]
License BSD-3-Clause
Author Alexander Vieth
Category Network
Home page
Source repo head: git clone
Uploaded by alexvieth at 2015-07-07T20:03:51Z
Distributions NixOS:
Downloads 1805 total (16 in the last 30 days)
Rating (no votes yet) [estimated by Bayesian average]
Your Rating
  • λ
  • λ
  • λ
Status Hackage Matrix CI
Docs not available [build log]
All reported builds failed as of 2016-12-08 [all 6 reports]


  • Network
    • Mail
      • SMTP
        • Network.Mail.SMTP.Auth
        • Network.Mail.SMTP.ReplyLine
        • Network.Mail.SMTP.SMTP
        • Network.Mail.SMTP.SMTPParameters
        • Network.Mail.SMTP.SMTPRaw
        • Network.Mail.SMTP.Send
        • Network.Mail.SMTP.Types


Maintainer's Corner

For package maintainers and hackage trustees


Readme for smtp-mail-ng-

[back to package description]


An SMTP client EDSL. If you want to interact with an SMTP server, this library may be able to help you. It even supports STARTTLS!

The star is the SMTP monad, terms of which (thanks to do notation) often resemble an SMTP session.

Sending with an SMTP server

{-# LANGUAGE OverloadedStrings #-}

import Network.BSD (getHostName)
import Network.Mail.SMTP.SMTP
import Network.Mail.SMTP.SMTPParameters
import Network.Mail.SMTP.Types
import Network.Mail.SMTP.Auth
import Network.Mail.SMTP.Send
import Network.Mail.Mime
import Control.Monad.IO.Class (liftIO)
import Data.ByteString.Char8 (pack)

main = smtp smtpParameters $ do
  hostname <- liftIO getHostName
  -- Send EHLO and expect a 250
  command $ EHLO (pack hostname)
  expectCode 250
  -- Upgrade the connection to TLS
  -- This is a kind of utility term that takes care of sending STARTTLS,
  -- expecting a 220, and then upgrading the underlying connection to TLS.
  -- Authenticate with LOGIN scheme
  authLogin "" "mySuperSecretPassword"
  -- Send the message
  send message
  -- End the session.
  -- Closing the connection is handled automatically by the function smtp
  command QUIT

-- We use datatypes from the mime-mail package to describe Mail.
message :: Mail
message = simpleMail' to from subject body
    from = Address (Just "John Jarndyce") ""
    to = Address (Just "Harold Skimpole") ""
    subject = "Hey!"
    body = "It works!"

smtpParameters :: SMTPParameters
smtpParameters = (defaultSMTPParameters "") {
    smtpVerbose = True

Moving forward

We must implement support for more AUTH schemes. Right now all that we facilitate is LOGIN, although other methods are possible via the bytes term.

There is an orphan datatype, Response, from before the fork. It may be good to use this instead of bare Ints.

It would be nice to give a convenient interface for simply sending some messages, in which the user must supply only a list of Mail values, an SMTPParameters, and a description of the authentication and encryption parameters of the mail server.


This library is forked from Jason Hickner's smtp-mail, but it has diverged significantly and bears little resemblance.