The smtp-mail-ng package

This is a package candidate release! Here you can preview how this package release will appear once published to the main package index (which can be accomplished via the 'maintain' link below). Please note that once a package has been published to the main package index it cannot be undone! Please consult the package uploading documentation for more information.


An SMTP client EDSL

[Skip to ReadMe]


Change logNone available
Dependenciesattoparsec (==0.12.*), base (==4.7.*), base16-bytestring (==0.1.*), base64-bytestring (==1.0.*), bytestring (==0.10.*), crypto-random (==0.0.*), cryptohash (==0.11.*), filepath (==1.3.*), haskeline (==0.7.*), mime-mail (==0.4.*), mtl (==2.2.*), network (==2.6.*), stringsearch (>=, text (==1.2.*), tls (==1.2.*), transformers (==0.4.*), x509-store (==1.5.*), x509-system (==1.5.*) [details]
AuthorAlexander Vieth
Home page
Source repositoryhead: git clone
UploadedWed Jan 28 01:18:35 UTC 2015 by alexvieth




Maintainers' corner

For package maintainers and hackage trustees

Readme for smtp-mail-ng-


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.