The smtp-mail-ng package

[ Tags: bsd3, library, network ] [ Propose Tags ]

An SMTP client EDSL

[Skip to Readme]


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 BSD3
Author Alexander Vieth
Category Network
Home page
Source repository head: git clone
Uploaded Tue Jul 7 20:03:51 UTC 2015 by alexvieth
Distributions NixOS:
Downloads 411 total (3 in the last 30 days)
Rating 0.0 (0 ratings) [clear rating]
  • λ
  • λ
  • λ
Status Docs not available [build log]
All reported builds failed as of 2016-12-08 [all 6 reports]
Hackage Matrix CI


  • 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.