Go to file
Alexandre Cesaro 07a1f385b7 Simplified some code 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 Bumbed version to v2-unstable 2015-07-29 22:47:37 +02:00
auth.go Removed LoginAuth and updated NewPlainDialer to handle LOGIN auth 2015-07-29 22:47:36 +02:00
auth_test.go Removed LoginAuth and updated NewPlainDialer to handle LOGIN auth 2015-07-29 22:47:36 +02:00
example_test.go Added an example 2015-07-29 22:47:37 +02:00
message.go Simplified some code 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 Simplified variable name of Message 2015-07-29 22:47:36 +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 Simplified some code 2015-07-29 22:47:37 +02:00

README.md

Gomail

Introduction

Gomail is a very simple and powerful package to send emails.

It requires Go 1.2 or newer.

Features

  • Dead-simple API
  • Highly flexible
  • Backward compatibility promise
  • Supports HTML and text templates
  • Attachments
  • Embedded images
  • SSL/TLS support
  • Automatic encoding of special characters
  • Well-documented
  • High test coverage

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.

foo