Gomail
This is an actively maintained fork of Gomail and includes fixes and
improvements for a number of outstanding issues. The current progress is
as follows:
See Transitioning Existing Codebases for more information on switching.
Introduction
Gomail is a simple and efficient package to send emails. It is well tested and
documented.
Gomail can only send emails using an SMTP server. But the API is flexible and it
is easy to implement other methods for sending emails using a local Postfix, an
API, etc.
It requires Go 1.2 or newer. With Go 1.5, no external dependencies are used.
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
Documentation
https://godoc.org/github.com/go-mail/mail
Download
If you're already using a dependency manager, like dep, use the following
import path:
github.com/go-mail/mail
If you aren't using vendoring, go get
the Gopkg.in
import path:
gopkg.in/mail.v2
Examples
See the examples in the documentation.
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
:
package main
import (
"crypto/tls"
"gopkg.in/mail.v2"
)
func main() {
d := mail.NewDialer("smtp.example.com", 587, "user", "123456")
d.TLSConfig = &tls.Config{InsecureSkipVerify: true}
}
Note, however, that this is insecure and should not be used in production.
Transitioning Existing Codebases
If you're already using the original Gomail, switching is as easy as updating
the import line to:
import gomail "gopkg.in/mail.v2"
Contribute
Contributions are more than welcome! See CONTRIBUTING.md for
more info.
Change log
See CHANGELOG.md.
License
MIT
Support & Contact
You can ask questions on the Gomail
thread
in the Go mailing-list.