Go to file
Alexandre Cesaro 394a6b2fcd Added examples 2015-07-29 22:47:37 +02:00
.travis.yml Added Travis and other badges 2015-07-29 22:47:37 +02:00
CHANGELOG.md Added CHANGELOG.md 2015-07-29 22:47:37 +02:00
CONTRIBUTING.md Added CONTRIBUTING.md 2015-07-29 22:47:37 +02:00
LICENSE Initial commit 2014-10-15 17:47:07 +02:00
README.md Fixed badges links 2015-07-29 22:47:37 +02:00
auth.go Fixed PLAIN authentication 2015-07-29 22:47:37 +02:00
auth_test.go Fixed PLAIN authentication 2015-07-29 22:47:37 +02:00
example_test.go Added examples 2015-07-29 22:47:37 +02:00
message.go Changed the internal representation of a part 2015-07-29 22:47:37 +02:00
message_test.go Simplified variable name of Message 2015-07-29 22:47:36 +02:00
mime.go Lowered Go version requirement from 1.5 to 1.2 2015-07-29 22:47:36 +02:00
mime_go14.go Lowered Go version requirement from 1.5 to 1.2 2015-07-29 22:47:36 +02:00
send.go Added a small performance tweak in getRecipients() 2015-07-29 22:47:37 +02:00
send_test.go Replaced Message.Export by Message.WriteTo 2015-07-29 22:47:36 +02:00
smtp.go Simplified variable name of Message 2015-07-29 22:47:36 +02:00
smtp_test.go Replaced Message.Export by Message.WriteTo 2015-07-29 22:47:36 +02:00
writeto.go Changed the internal representation of a part 2015-07-29 22:47:37 +02:00

README.md

Gomail

Build Status Code Coverage Documentation

Introduction

Gomail is a simple and efficient package to send emails. It is well tested and documented.

It is versioned using gopkg.in so I promise they will never be backward incompatible changes within each version.

It requires Go 1.2 or newer.

Features

Gomail supports:

  • Attachments
  • Embedded images
  • HTML and text templates
  • Automatic encoding of special characters
  • SSL and TLS
  • Sending multiple emails with the same SMTP connection
  • Any method to send emails: SMTP, postfix (not included but easily doable), etc

Documentation

https://godoc.org/gopkg.in/gomail.v2-unstable

Download

go get gopkg.in/gomail.v2-unstable

Example

package main

import (
	"gopkg.in/gomail.v2-unstable"
)

func main() {
	msg := gomail.NewMessage()
	msg.SetHeader("From", "alex@example.com")
	msg.SetHeader("To", "bob@example.com", "cora@example.com")
	msg.SetAddressHeader("Cc", "dan@example.com", "Dan")
	msg.SetHeader("Subject", "Hello!")
	msg.SetBody("text/html", "Hello <b>Bob</b> and <i>Cora</i>!")
	msg.Attach(gomail.NewFile("/home/Alex/lolcat.jpg"))

	d := gomail.NewPlainDialer("smtp.example.com", "user", "123456", 587)

	// Send the email to Bob, Cora and Dan
	if err := d.DialAndSend(msg); err != nil {
		panic(err)
	}
}

FAQ

x509: certificate signed by unknown authority

If you get this error it means the certificate used by the SMTP server is not considered valid by the client running Gomail. As a quick workaround you can bypass the verification of the server's certificate chain and host name by using SetTLSConfig:

d := gomail.NewPlainDialer("smtp.example.com", "user", "123456", 587)
d.TLSConfig = &tls.Config{InsecureSkipVerify: true}

Note, however, that this is insecure and should not be used in production.

Contribute

See CONTRIBUTING.md.

Change log

See CHANGELOG.md.

Contact

You can ask questions on the Gomail thread in the Go mailing-list.

Support

If you want to support the development of Gomail, I gladly accept donations.

I will give 100% of the money I receive to Enfants, Espoir Du Monde. EEDM is a French NGO which helps children in Bangladesh, Cameroun, Haiti, India and Madagascar. All its members are volunteers so its operating costs are only 1.9%. So your money will directly helps children of these countries.

As an added bonus, your donations will also tip me by lowering my taxes 😄 I will send an email with the receipt of the donation to EEDM annually to all donors.

Donate